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.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: import org.jvnet.substance.watermark.SubstanceBinaryWatermark;
042:
043: /**
044: * Test application that shows the use of the
045: * {@link SubstanceLookAndFeel#WATERMARK_TO_BLEED} client property.
046: *
047: * @author Kirill Grouchnikov
048: * @see SubstanceLookAndFeel#WATERMARK_TO_BLEED
049: */
050: public class WatermarkToBleed extends JFrame {
051: /**
052: * Creates the main frame for <code>this</code> sample.
053: */
054: public WatermarkToBleed() {
055: super ("Watermark bleeding through the list");
056:
057: this .setLayout(new BorderLayout());
058:
059: // create list with a few values
060: final JList jlist = new JList(new Object[] { "value1",
061: "value2", "value3", "value4" });
062: this .add(jlist, BorderLayout.CENTER);
063:
064: JPanel controls = new JPanel(new FlowLayout(FlowLayout.RIGHT));
065: final JCheckBox isBleeding = new JCheckBox("watermark bleed");
066: isBleeding.addActionListener(new ActionListener() {
067: public void actionPerformed(ActionEvent e) {
068: SwingUtilities.invokeLater(new Runnable() {
069: public void run() {
070: // based on checkbox selection, mark the list to
071: // bleed the watermark
072: jlist
073: .putClientProperty(
074: SubstanceLookAndFeel.WATERMARK_TO_BLEED,
075: isBleeding.isSelected() ? Boolean.TRUE
076: : null);
077: repaint();
078: }
079: });
080: }
081: });
082: controls.add(isBleeding);
083: this .add(controls, BorderLayout.SOUTH);
084:
085: this .setSize(400, 200);
086: this .setLocationRelativeTo(null);
087: this .setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
088: }
089:
090: /**
091: * The main method for <code>this</code> sample. The arguments are
092: * ignored.
093: *
094: * @param args
095: * Ignored.
096: * @throws Exception
097: * If some exception occured. Note that there is no special
098: * treatment of exception conditions in <code>this</code>
099: * sample code.
100: */
101: public static void main(String[] args) throws Exception {
102: UIManager
103: .setLookAndFeel(new SubstanceBusinessBlackSteelLookAndFeel());
104: // set custom watermark
105: SubstanceLookAndFeel
106: .setCurrentWatermark(new SubstanceBinaryWatermark());
107: JFrame.setDefaultLookAndFeelDecorated(true);
108: SwingUtilities.invokeLater(new Runnable() {
109: public void run() {
110: new WatermarkToBleed().setVisible(true);
111: }
112: });
113: }
114: }
|