groovy.swing.LookAndFeelHelper.groovy Maven / Gradle / Ivy
/*
* Copyright 2007 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package groovy.swing
import javax.swing.LookAndFeel
import javax.swing.UIManager
import javax.swing.plaf.metal.DefaultMetalTheme
import javax.swing.plaf.metal.MetalLookAndFeel
import javax.swing.plaf.metal.MetalTheme
class LookAndFeelHelper {
// protected so you can subclass and replace the singleton
protected static LookAndFeelHelper instance;
private LookAndFeelHelper() {
// linux GTK bug : http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=6389282
UIManager.getInstalledLookAndFeels();
}
public static LookAndFeelHelper getInstance() {
return instance ?: (instance = new LookAndFeelHelper())
}
private Map lafCodeNames = [
// stuff built into various JDKs
metal : 'javax.swing.plaf.metal.MetalLookAndFeel',
nimbus : getNimbusLAFName(),
mac : getAquaLAFName(),
motif : 'com.sun.java.swing.plaf.motif.MotifLookAndFeel',
windows : 'com.sun.java.swing.plaf.windows.WindowsLookAndFeel',
win2k : 'com.sun.java.swing.plaf.windows.WindowsClassicLookAndFeel',
gtk : 'com.sun.java.swing.plaf.gtk.GTKLookAndFeel',
synth : 'javax.swing.plaf.synth.SynthLookAndFeel',
// generic aliases in UIManager
system : UIManager.getSystemLookAndFeelClassName(),
crossPlatform : UIManager.getCrossPlatformLookAndFeelClassName(),
// jgoodies, requires external library
plastic : 'com.jgoodies.looks.plastic.PlasticLookAndFeel',
plastic3D : 'com.jgoodies.looks.plastic.Plastic3DLookAndFeel',
plasticXP : 'com.jgoodies.looks.plastic.PlasticXPLookAndFeel',
// substance, requires external library
substance : getSubstanceLAFName(),
// napkin, requires external library
napkin : 'net.sourceforge.napkinlaf.NapkinLookAndFeel'
]
public String addLookAndFeelAlias(String alias, String className) {
lafCodeNames[alias] = className
}
private Map extendedAttributes = [
'javax.swing.plaf.metal.MetalLookAndFeel' : [
theme : { laf, theme ->
if (!(theme instanceof MetalTheme)) {
if (theme == 'ocean') {
theme = Class.forName('javax.swing.plaf.metal.OceanTheme').newInstance()
} else if (theme == 'steel') {
theme = new DefaultMetalTheme();
} else {
theme = Class.forName(theme as String).newInstance()
}
};
MetalLookAndFeel.currentTheme = theme
},
boldFonts : { laf, bold -> UIManager.put('swing.boldMetal', bold as Boolean) },
noxp : { laf, xp -> UIManager.put('swing.noxp', bold as Boolean) },
],
'org.jvnet.substance.SubstanceLookAndFeel' : [
// use setters instead of properties to get multi-dispatch
theme: { laf, theme -> laf.setCurrentTheme(theme) },
skin: { laf, skin -> laf.setSkin(skin) },
watermark : { laf, watermark -> laf.setCurrentWatermark(watermark) },
],
]
public String addLookAndFeelAttributeHandler(String className, String attr, Closure handler) {
Map attrs = extendedAttributes[className]
if (attrs == null) {
attrs = [:]
extendedAttributes[className] = attrs
}
attrs[attr] = handler
}
public boolean isLeaf() {
return true
}
public LookAndFeel lookAndFeel(Object value, Map attributes, Closure initClosure) {
LookAndFeel lafInstance
String lafClassName
if ((value instanceof Closure) && (initClosure == null)) {
initClosure = value
value = null
}
if (value == null) {
value = attributes.remove('lookAndFeel')
}
if (value instanceof GString) value = value as String
if (FactoryBuilderSupport.checkValueIsTypeNotString(value, 'lookAndFeel', LookAndFeel)) {
lafInstance = value
lafClassName = lafInstance.class.name
} else if (value != null) {
lafClassName = lafCodeNames[value] ?: value
lafInstance = Class.forName(lafClassName, true, getClass().classLoader).newInstance()
}
// assume all configuration must be done prior to LAF being installed
Map possibleAttributes = extendedAttributes[lafClassName] ?: [:]
attributes.each {k, v ->
if (possibleAttributes[k]) {
possibleAttributes[k](lafInstance, v)
} else {
try {
lafInstance."$k" = v
} catch (MissingPropertyException mpe) {
throw new RuntimeException("SwingBuilder initialization for the Look and Feel Class $lafClassName does accept the attribute $k")
}
}
}
if (initClosure) {
initClosure.call(lafInstance)
}
UIManager.setLookAndFeel(lafInstance)
return lafInstance
}
static String getNimbusLAFName() {
for (klass in [
'com.sun.java.swing.plaf.nimbus.NimbusLookAndFeel',
'sun.swing.plaf.nimbus.NimbusLookAndFeel',
'org.jdesktop.swingx.plaf.nimbus.NimbusLookAndFeel'
]) {
try {
return Class.forName(klass).getName()
} catch (Throwable t) {
// ignore it, try the next on the list
}
}
return null;
}
static String getAquaLAFName() {
for (klass in [
'com.apple.laf.AquaLookAndFeel',
'apple.laf.AquaLookAndFeel'
]) {
try {
return Class.forName(klass).getName()
} catch (Throwable t) {
// ignore it, try the next on the list
}
}
return null;
}
static String getSubstanceLAFName() {
for (klass in [
'org.pushingpixels.substance.api.SubstanceLookAndFeel',
'org.jvnet.substance.SubstanceLookAndFeel'
]) {
try {
return Class.forName(klass).getName()
} catch (Throwable t) {
// ignore it, try the next on the list
}
}
return null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy