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: import test.Check;
043:
044: /**
045: * Test application that shows the use of the
046: * {@link SubstanceLookAndFeel#hideMenuSearchPanels()} and
047: * {@link SubstanceLookAndFeel#showMenuSearchPanels()} APIs.
048: *
049: * @author Kirill Grouchnikov
050: * @see SubstanceLookAndFeel#hideMenuSearchPanels()
051: * @see SubstanceLookAndFeel#showMenuSearchPanels()
052: */
053: public class HideShowMenuSearchPanels extends JFrame {
054: /**
055: * Creates the main frame for <code>this</code> sample.
056: */
057: public HideShowMenuSearchPanels() {
058: super ("Hide / show menu search panels");
059:
060: this .setLayout(new BorderLayout());
061:
062: // create sample menu bar with two menus
063: JMenuBar jmb = new JMenuBar();
064: JMenu menu = new JMenu("menu");
065: menu.add(new JMenuItem("test item 1", Check
066: .getIcon("flag_mexico")));
067: menu.add(new JMenuItem("test item 2"));
068: menu.add(new JMenuItem("test item 3"));
069: menu.addSeparator();
070: menu.add(new JMenuItem("test menu item 4"));
071: menu.add(new JMenuItem("test menu item 5", Check
072: .getIcon("flag_sweden")));
073: menu.add(new JMenuItem("test menu item 6"));
074: jmb.add(menu);
075:
076: JMenu menu2 = new JMenu("big");
077: for (int i = 0; i < 35; i++)
078: menu2.add(new JMenuItem("menu item " + i));
079: jmb.add(menu2);
080:
081: this .setJMenuBar(jmb);
082:
083: JPanel controls = new JPanel(new FlowLayout(FlowLayout.RIGHT));
084: final JCheckBox showMenuSearchPanels = new JCheckBox(
085: "Show menu search panels");
086: showMenuSearchPanels.setSelected(true);
087: showMenuSearchPanels.addActionListener(new ActionListener() {
088: public void actionPerformed(ActionEvent e) {
089: SwingUtilities.invokeLater(new Runnable() {
090: public void run() {
091: if (showMenuSearchPanels.isSelected()) {
092: SubstanceLookAndFeel.showMenuSearchPanels();
093: } else {
094: SubstanceLookAndFeel.hideMenuSearchPanels();
095: }
096: }
097: });
098: }
099: });
100: controls.add(showMenuSearchPanels);
101: this .add(controls, BorderLayout.SOUTH);
102:
103: this .setSize(400, 200);
104: this .setLocationRelativeTo(null);
105: this .setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
106: }
107:
108: /**
109: * The main method for <code>this</code> sample. The arguments are
110: * ignored.
111: *
112: * @param args
113: * Ignored.
114: * @throws Exception
115: * If some exception occured. Note that there is no special
116: * treatment of exception conditions in <code>this</code>
117: * sample code.
118: */
119: public static void main(String[] args) throws Exception {
120: UIManager
121: .setLookAndFeel(new SubstanceBusinessBlackSteelLookAndFeel());
122: JFrame.setDefaultLookAndFeelDecorated(true);
123: SwingUtilities.invokeLater(new Runnable() {
124: public void run() {
125: new HideShowMenuSearchPanels().setVisible(true);
126: }
127: });
128: }
129: }
|