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.ActionEvent;
035: import java.awt.event.ActionListener;
036:
037: import javax.swing.*;
038:
039: import org.jvnet.substance.SubstanceLookAndFeel;
040: import org.jvnet.substance.skin.SubstanceBusinessBlackSteelLookAndFeel;
041:
042: /**
043: * Test application that shows the use of the
044: * {@link SubstanceLookAndFeel#setCurrentGradientPainter(String)} API.
045: *
046: * @author Kirill Grouchnikov
047: * @see SubstanceLookAndFeel#setCurrentGradientPainter(String)
048: */
049: public class SetCurrentGradientPainter_ClassName extends JFrame {
050: /**
051: * Creates the main frame for <code>this</code> sample.
052: */
053: public SetCurrentGradientPainter_ClassName() {
054: super ("Set current gradient painter");
055:
056: this .setLayout(new BorderLayout());
057:
058: JPanel controls = new JPanel(new FlowLayout(FlowLayout.RIGHT));
059: final JButton changeGradientPainter = new JButton(
060: "Change gradient painter");
061: changeGradientPainter.addActionListener(new ActionListener() {
062: public void actionPerformed(ActionEvent e) {
063: SwingUtilities.invokeLater(new Runnable() {
064: public void run() {
065: changeGradientPainter.setEnabled(false);
066: // set new gradient painter by class name
067: SubstanceLookAndFeel
068: .setCurrentGradientPainter("org.jvnet.substance.painter.SpecularGradientPainter");
069: repaint();
070: }
071: });
072: }
073: });
074: controls.add(changeGradientPainter);
075:
076: JButton getGradientPainterName = new JButton(
077: "Get current gradient painter name");
078: getGradientPainterName.addActionListener(new ActionListener() {
079: public void actionPerformed(ActionEvent e) {
080: JOptionPane
081: .showMessageDialog(
082: SetCurrentGradientPainter_ClassName.this ,
083: "Current gradient painter name is "
084: + SubstanceLookAndFeel
085: .getCurrentGradientPainterName());
086: }
087: });
088:
089: controls.add(getGradientPainterName);
090:
091: this .add(controls, BorderLayout.SOUTH);
092:
093: this .setSize(400, 200);
094: this .setLocationRelativeTo(null);
095: this .setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
096: }
097:
098: /**
099: * The main method for <code>this</code> sample. The arguments are
100: * ignored.
101: *
102: * @param args
103: * Ignored.
104: * @throws Exception
105: * If some exception occured. Note that there is no special
106: * treatment of exception conditions in <code>this</code>
107: * sample code.
108: */
109: public static void main(String[] args) throws Exception {
110: UIManager
111: .setLookAndFeel(new SubstanceBusinessBlackSteelLookAndFeel());
112: JFrame.setDefaultLookAndFeelDecorated(true);
113: JDialog.setDefaultLookAndFeelDecorated(true);
114: SwingUtilities.invokeLater(new Runnable() {
115: public void run() {
116: new SetCurrentGradientPainter_ClassName()
117: .setVisible(true);
118: }
119: });
120: }
121: }
|