001: /*
002: * Copyright (c) 2005-2008 Substance Kirill Grouchnikov. All Rights Reserved.
003: *
004: * Redistribution and use in source and binary forms, with or without
005: * modification, are permitted provided that the following conditions are met:
006: *
007: * o Redistributions of source code must retain the above copyright notice,
008: * this list of conditions and the following disclaimer.
009: *
010: * o Redistributions in binary form must reproduce the above copyright notice,
011: * this list of conditions and the following disclaimer in the documentation
012: * and/or other materials provided with the distribution.
013: *
014: * o Neither the name of Substance Kirill Grouchnikov nor the names of
015: * its contributors may be used to endorse or promote products derived
016: * from this software without specific prior written permission.
017: *
018: * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
019: * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
020: * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
021: * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
022: * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
023: * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
024: * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
025: * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
026: * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
027: * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
028: * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
029: */
030: package test.samples.substance.clientprop;
031:
032: import java.awt.*;
033: import java.awt.event.ActionEvent;
034: import java.awt.event.ActionListener;
035: import java.util.Vector;
036:
037: import javax.swing.*;
038:
039: import org.jvnet.substance.SubstanceDefaultComboBoxRenderer;
040: import org.jvnet.substance.SubstanceLookAndFeel;
041: import org.jvnet.substance.skin.SubstanceBusinessBlackSteelLookAndFeel;
042: import org.jvnet.substance.theme.ThemeInfo;
043:
044: /**
045: * Test application that shows the use of the
046: * {@link SubstanceLookAndFeel#ENABLE_NEGATED_THEMES} client property.
047: *
048: * @author Kirill Grouchnikov
049: * @see SubstanceLookAndFeel#ENABLE_NEGATED_THEMES
050: */
051: public class EnableNegatedThemes extends JFrame {
052: /**
053: * Creates the main frame for <code>this</code> sample.
054: */
055: public EnableNegatedThemes() {
056: super ("Enable negated themes");
057:
058: setLayout(new BorderLayout());
059:
060: final JPanel panel = new JPanel(new FlowLayout());
061: final JComboBox cb = new JComboBox(new Vector<ThemeInfo>(
062: SubstanceLookAndFeel.getAllThemes().values()));
063: cb.setRenderer(new SubstanceDefaultComboBoxRenderer(cb) {
064: @Override
065: public Component getListCellRendererComponent(JList list,
066: Object value, int index, boolean isSelected,
067: boolean cellHasFocus) {
068: ThemeInfo ti = (ThemeInfo) value;
069: return super .getListCellRendererComponent(list, ti
070: .getDisplayName(), index, isSelected,
071: cellHasFocus);
072: }
073: });
074: panel.add(new JLabel("All themes:"));
075: panel.add(cb);
076:
077: this .add(panel, BorderLayout.CENTER);
078:
079: JPanel controls = new JPanel(new FlowLayout(FlowLayout.RIGHT));
080: final JCheckBox enableNegatedThemes = new JCheckBox(
081: "enable negated themes");
082: enableNegatedThemes.addActionListener(new ActionListener() {
083: public void actionPerformed(ActionEvent e) {
084: SwingUtilities.invokeLater(new Runnable() {
085: public void run() {
086: // based on the checkbox selection status, enable
087: // negated themes
088: UIManager
089: .put(
090: SubstanceLookAndFeel.ENABLE_NEGATED_THEMES,
091: enableNegatedThemes
092: .isSelected() ? Boolean.TRUE
093: : null);
094: // reset the combobox model to all available Substance
095: // themes
096: cb.setModel(new DefaultComboBoxModel(
097: new Vector<ThemeInfo>(
098: SubstanceLookAndFeel
099: .getAllThemes()
100: .values())));
101: }
102: });
103: }
104: });
105: controls.add(enableNegatedThemes);
106: this .add(controls, BorderLayout.SOUTH);
107:
108: this .setSize(400, 200);
109: setLocationRelativeTo(null);
110: setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
111: }
112:
113: /**
114: * The main method for <code>this</code> sample. The arguments are
115: * ignored.
116: *
117: * @param args
118: * Ignored.
119: * @throws Exception
120: * If some exception occured. Note that there is no special
121: * treatment of exception conditions in <code>this</code>
122: * sample code.
123: */
124: public static void main(String[] args) throws Exception {
125: UIManager
126: .setLookAndFeel(new SubstanceBusinessBlackSteelLookAndFeel());
127: JFrame.setDefaultLookAndFeelDecorated(true);
128: SwingUtilities.invokeLater(new Runnable() {
129: public void run() {
130: new EnableNegatedThemes().setVisible(true);
131: }
132: });
133: }
134: }
|