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.FlowLayout;
033:
034: import javax.swing.*;
035:
036: import org.jvnet.substance.SubstanceLookAndFeel;
037: import org.jvnet.substance.skin.SubstanceBusinessBlackSteelLookAndFeel;
038: import org.jvnet.substance.utils.SubstanceConstants;
039:
040: /**
041: * Test application that shows the use of the
042: * {@link SubstanceLookAndFeel#BUTTON_SIDE_PROPERTY} client property.
043: *
044: * @author Kirill Grouchnikov
045: * @see SubstanceLookAndFeel#BUTTON_SIDE_PROPERTY
046: */
047: public class ButtonSideProperty extends JFrame {
048: /**
049: * Creates the main frame for <code>this</code> sample.
050: */
051: public ButtonSideProperty() {
052: super ("Buttons with straight sides");
053:
054: this .setLayout(new FlowLayout());
055:
056: JButton buttonA = new JButton("left only");
057: // Mark button to have straight left side
058: // using side name
059: buttonA.putClientProperty(
060: SubstanceLookAndFeel.BUTTON_SIDE_PROPERTY,
061: SubstanceConstants.Side.LEFT.name());
062:
063: JButton buttonB = new JButton("right only");
064: // Mark button to have straight right side
065: // using side constant
066: buttonB.putClientProperty(
067: SubstanceLookAndFeel.BUTTON_SIDE_PROPERTY,
068: SubstanceConstants.Side.RIGHT);
069:
070: JButton buttonC = new JButton("left+top");
071: // Mark button to have straight left and top sides
072: // using array of side names
073: buttonC.putClientProperty(
074: SubstanceLookAndFeel.BUTTON_SIDE_PROPERTY,
075: new String[] { SubstanceConstants.Side.LEFT.name(),
076: SubstanceConstants.Side.TOP.name() });
077:
078: JButton buttonD = new JButton("right+bottom");
079: // Mark button to have straight right and bottom sides
080: // using array of side constants
081: buttonD.putClientProperty(
082: SubstanceLookAndFeel.BUTTON_SIDE_PROPERTY,
083: new SubstanceConstants.Side[] {
084: SubstanceConstants.Side.RIGHT,
085: SubstanceConstants.Side.BOTTOM });
086:
087: this .add(buttonA);
088: this .add(buttonB);
089: this .add(buttonC);
090: this .add(buttonD);
091:
092: this .setSize(400, 200);
093: this .setLocationRelativeTo(null);
094: this .setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
095: }
096:
097: /**
098: * The main method for <code>this</code> sample. The arguments are
099: * ignored.
100: *
101: * @param args
102: * Ignored.
103: * @throws Exception
104: * If some exception occured. Note that there is no special
105: * treatment of exception conditions in <code>this</code>
106: * sample code.
107: */
108: public static void main(String[] args) throws Exception {
109: UIManager
110: .setLookAndFeel(new SubstanceBusinessBlackSteelLookAndFeel());
111: JFrame.setDefaultLookAndFeelDecorated(true);
112: SwingUtilities.invokeLater(new Runnable() {
113: public void run() {
114: new ButtonSideProperty().setVisible(true);
115: }
116: });
117: }
118: }
|