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.api;
031:
032: import java.awt.BorderLayout;
033: import java.awt.FlowLayout;
034: import java.awt.event.ItemEvent;
035: import java.awt.event.ItemListener;
036: import java.util.Vector;
037:
038: import javax.swing.*;
039:
040: import org.jvnet.substance.SubstanceLookAndFeel;
041: import org.jvnet.substance.skin.*;
042:
043: /**
044: * Test application that shows the use of the
045: * {@link SubstanceLookAndFeel#registerSkinChangeListener(SkinChangeListener)}
046: * API.
047: *
048: * @author Kirill Grouchnikov
049: * @see SubstanceLookAndFeel#registerSkinChangeListener(SkinChangeListener)
050: */
051: public class RegisterSkinChangeListener extends JFrame {
052: /**
053: * Creates the main frame for <code>this</code> sample.
054: */
055: public RegisterSkinChangeListener() {
056: super ("Register skin change listener");
057:
058: this .setLayout(new BorderLayout());
059:
060: JPanel panel = new JPanel(new FlowLayout());
061:
062: // Get all skin display names and set the vector as a model
063: // for combobox.
064: final JComboBox cb = new JComboBox(new Vector<String>(
065: SubstanceLookAndFeel.getAllSkins().keySet()));
066: cb.setSelectedIndex(-1);
067:
068: cb.addItemListener(new ItemListener() {
069: public void itemStateChanged(ItemEvent evt) {
070: // Get the affected item
071: final Object item = evt.getItem();
072:
073: if (evt.getStateChange() == ItemEvent.SELECTED) {
074: SwingUtilities.invokeLater(new Runnable() {
075: public void run() {
076: try {
077: // Get the skin info object based on
078: // the selected skin display name
079: SkinInfo skinInfo = SubstanceLookAndFeel
080: .getAllSkins().get(
081: (String) item);
082: // Set the global skin based on the
083: // skin class name.
084: SubstanceLookAndFeel.setSkin(skinInfo
085: .getClassName());
086: SwingUtilities
087: .updateComponentTreeUI(RegisterSkinChangeListener.this );
088: } catch (Exception exc) {
089: }
090: };
091: });
092: }
093: }
094: });
095:
096: panel.add(new JLabel("All skins:"));
097: panel.add(cb);
098:
099: this .add(panel, BorderLayout.CENTER);
100:
101: // register listener
102: SubstanceLookAndFeel
103: .registerSkinChangeListener(new SkinChangeListener() {
104: public void skinChanged() {
105: // show dialog with skin changed message.
106: SwingUtilities.invokeLater(new Runnable() {
107: public void run() {
108: JOptionPane
109: .showMessageDialog(
110: RegisterSkinChangeListener.this ,
111: "Skin changed");
112: }
113: });
114: }
115: });
116:
117: this .setSize(400, 200);
118: this .setLocationRelativeTo(null);
119: this .setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
120: }
121:
122: /**
123: * The main method for <code>this</code> sample. The arguments are
124: * ignored.
125: *
126: * @param args
127: * Ignored.
128: * @throws Exception
129: * If some exception occured. Note that there is no special
130: * treatment of exception conditions in <code>this</code>
131: * sample code.
132: */
133: public static void main(String[] args) throws Exception {
134: UIManager
135: .setLookAndFeel(new SubstanceBusinessBlackSteelLookAndFeel());
136: JFrame.setDefaultLookAndFeelDecorated(true);
137: JDialog.setDefaultLookAndFeelDecorated(true);
138: SwingUtilities.invokeLater(new Runnable() {
139: public void run() {
140: new RegisterSkinChangeListener().setVisible(true);
141: }
142: });
143: }
144: }
|