I thought that I'd follow up with a few of my own thoughts:
- Painters would be awesome, being able to plug in your own painting code for defined parts of a component without doing dirty LnF hacks would save lots of my time. They do however have their problems, namely sizing. The painting logic of a component is intrisicly linked to the size of that component, the space needed for the component to paint its self should also be part of the painter. Adding an API like the fitInto API in the sclabaleicon project to painters would allow this to happen.
- While I'm at it adding this API to component its self would also remove the two confising minimum and maximum size APIs
- Now I don't know if this one is possible or not but some way to make UIDefaults type safe would be great, maybe the decorator pattern or something like that. I have no idea if that would work or not but it could facilitate making more of a seperaton between the controller and the ui, I mean text-icon gap should really be in the ui, come to thing of it so should font, foreground/background colour, text alignment, cell spacing, and most of the other properties found in the swing components. Imagine being able to do something like component.getUI(TextUI.class) to get text related ui properties like antialiasing or decoration or font, or component.getUI(NimbusUI.class) to get type-safe properties for the numbus look and feel.
Hey Matt - thanks for the link to my blog. Did you post these thoughts as a comment on my site - if not please consider doing so. This way we have a single site aggregating everyones thoughts on this issue.
ReplyDeleteCheers,
Jonathan