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