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.*;
035: import java.util.Vector;
036:
037: import javax.swing.*;
038:
039: import org.jvnet.substance.SubstanceLookAndFeel;
040: import org.jvnet.substance.border.BorderPainterInfo;
041: import org.jvnet.substance.skin.SubstanceBusinessBlackSteelLookAndFeel;
042:
043: /**
044: * Test application that shows the use of the
045: * {@link SubstanceLookAndFeel#getCurrentBorderPainter()} API.
046: *
047: * @author Kirill Grouchnikov
048: * @see SubstanceLookAndFeel#getCurrentBorderPainter()
049: */
050: public class GetCurrentBorderPainter extends JFrame {
051: /**
052: * Creates the main frame for <code>this</code> sample.
053: */
054: public GetCurrentBorderPainter() {
055: super ("Get current border painter");
056:
057: this .setLayout(new BorderLayout());
058:
059: JPanel panel = new JPanel(new FlowLayout());
060:
061: // Get all border painter display names and set the vector as a model
062: // for combobox.
063: final JComboBox cb = new JComboBox(new Vector<String>(
064: SubstanceLookAndFeel.getAllBorderPainters().keySet()));
065: cb.setSelectedItem(SubstanceLookAndFeel
066: .getCurrentBorderPainterName());
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 border painter info object based on
078: // the selected border painter display name
079: BorderPainterInfo painterInfo = SubstanceLookAndFeel
080: .getAllBorderPainters().get(
081: (String) item);
082: // Set the global border painter based on the
083: // gradient border class name.
084: SubstanceLookAndFeel
085: .setCurrentBorderPainter(painterInfo
086: .getClassName());
087: SwingUtilities
088: .updateComponentTreeUI(GetCurrentBorderPainter.this );
089: } catch (Exception exc) {
090: }
091: };
092: });
093: }
094: }
095: });
096:
097: panel.add(new JLabel("All border painters:"));
098: panel.add(cb);
099:
100: this .add(panel, BorderLayout.CENTER);
101:
102: JPanel controls = new JPanel(new FlowLayout(FlowLayout.RIGHT));
103:
104: JButton getBorderPainter = new JButton(
105: "Get current border painter");
106: getBorderPainter.addActionListener(new ActionListener() {
107: public void actionPerformed(ActionEvent e) {
108: JOptionPane.showMessageDialog(
109: GetCurrentBorderPainter.this ,
110: "Current border painter is of class "
111: + SubstanceLookAndFeel
112: .getCurrentBorderPainter()
113: .getClass().getName());
114: }
115: });
116:
117: controls.add(getBorderPainter);
118: this .add(controls, BorderLayout.SOUTH);
119:
120: this .setSize(400, 200);
121: this .setLocationRelativeTo(null);
122: this .setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
123: }
124:
125: /**
126: * The main method for <code>this</code> sample. The arguments are
127: * ignored.
128: *
129: * @param args
130: * Ignored.
131: * @throws Exception
132: * If some exception occured. Note that there is no special
133: * treatment of exception conditions in <code>this</code>
134: * sample code.
135: */
136: public static void main(String[] args) throws Exception {
137: UIManager
138: .setLookAndFeel(new SubstanceBusinessBlackSteelLookAndFeel());
139: JFrame.setDefaultLookAndFeelDecorated(true);
140: JDialog.setDefaultLookAndFeelDecorated(true);
141: SwingUtilities.invokeLater(new Runnable() {
142: public void run() {
143: new GetCurrentBorderPainter().setVisible(true);
144: }
145: });
146: }
147: }
|