Demonstrates how to build button bars with a fixed button order : FormLayout « Swing Components « Java






Demonstrates how to build button bars with a fixed button order

Demonstrates how to build button bars with a fixed button order

/*
 * Copyright (c) 2002-2004 JGoodies Karsten Lentzsch. All Rights Reserved.
 *
 * Redistribution and use in source and binary forms, with or without 
 * modification, are permitted provided that the following conditions are met:
 * 
 *  o Redistributions of source code must retain the above copyright notice, 
 *    this list of conditions and the following disclaimer. 
 *     
 *  o Redistributions in binary form must reproduce the above copyright notice, 
 *    this list of conditions and the following disclaimer in the documentation 
 *    and/or other materials provided with the distribution. 
 *     
 *  o Neither the name of JGoodies Karsten Lentzsch nor the names of 
 *    its contributors may be used to endorse or promote products derived 
 *    from this software without specific prior written permission. 
 *     
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 
 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR 
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 
 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE 
 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, 
 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
 */



import java.awt.Component;

import javax.swing.JButton;
import javax.swing.JComponent;
import javax.swing.JFrame;
import javax.swing.UIManager;
import javax.swing.WindowConstants;

import com.jgoodies.forms.builder.ButtonBarBuilder;
import com.jgoodies.forms.builder.DefaultFormBuilder;
import com.jgoodies.forms.layout.FormLayout;

/**
 * Demonstrates how to build button bars with a fixed button order 
 * or with a button order that honors the platform's style.
 * 
 * @author  Karsten Lentzsch
 * @version $Revision: 1.4 $
 * 
 * @see     ButtonBarBuilder
 * @see     com.jgoodies.forms.factories.ButtonBarFactory
 */
public class ButtonOrderExample {
    
    public static void main(String[] args) {
        try {
            UIManager.setLookAndFeel("com.jgoodies.plaf.plastic.PlasticXPLookAndFeel");
        } catch (Exception e) {
            // Likely PlasticXP is not in the class path; ignore.
        }
        JFrame frame = new JFrame();
        frame.setTitle("Forms Tutorial :: Button Order");
        frame.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
        JComponent panel = new ButtonOrderExample().buildPanel();
        frame.getContentPane().add(panel);
        frame.pack();
        frame.setVisible(true);
    }


    /**
     * Builds and returns a panel that consists of three paragraphs
     * that demonstrate different button orders. Each paragraph contains
     * a button bar that is built from a button sequence, and another
     * bar that is built from individual buttons.
     * 
     * @return a panel that demonstrates button order
     */
    public JComponent buildPanel() {
        FormLayout layout = new FormLayout("right:pref:grow, 4dlu, pref");
        DefaultFormBuilder rowBuilder = new DefaultFormBuilder(layout);
        rowBuilder.setDefaultDialogBorder();
        
        rowBuilder.appendSeparator("Left to Right");
        rowBuilder.append("Ordered", buildButtonSequence(ButtonBarBuilder.createLeftToRightBuilder()));
        rowBuilder.append("Fixed",   buildIndividualButtons(ButtonBarBuilder.createLeftToRightBuilder()));
        
        rowBuilder.appendSeparator("Right to Left");
        rowBuilder.append("Ordered", buildButtonSequence(createRightToLeftBuilder()));
        rowBuilder.append("Fixed",   buildIndividualButtons(createRightToLeftBuilder()));
        
        rowBuilder.appendSeparator("Platform Default Order");
        rowBuilder.append("Ordered", buildButtonSequence(new ButtonBarBuilder()));
        rowBuilder.append("Fixed",   buildIndividualButtons(new ButtonBarBuilder()));
        
        return rowBuilder.getPanel();
    }
    
    
    /**
     * Builds and returns a button bar honoring the builder's button order.
     * 
     * @param builder   the builder used to build the bar
     * @return a button bar that honors the builder's button order
     */
    private Component buildButtonSequence(ButtonBarBuilder builder) {
        builder.addGriddedButtons(new JButton[] {
                new JButton("One"),
                new JButton("Two"),
                new JButton("Three")
        });
        return builder.getPanel();
    }


    /**
     * Builds and returns a button bar ignoring the builder's button order.
     * Instead a fixed left to right order is used.
     * 
     * @param builder   the builder used to build the bar
     * @return a button bar with a fixed left to right button order
     */
    private Component buildIndividualButtons(ButtonBarBuilder builder) {
        builder.addGridded(new JButton("One"));
        builder.addRelatedGap();
        builder.addGridded(new JButton("Two"));
        builder.addRelatedGap();
        builder.addGridded(new JButton("Three"));
        return builder.getPanel();
    }

    
    /**
     * Creates and returns a button bar builder with a fixed
     * right-to-left button order. Unlike the factory method 
     * {@link ButtonBarBuilder#createLeftToRightBuilder()}
     * this method is useful for demonstration purposes only.
     *  
     * @return a ButtonBarBuilder with right-to-left button order
     */
    private static ButtonBarBuilder createRightToLeftBuilder() {
        ButtonBarBuilder builder = new ButtonBarBuilder();
        builder.setLeftToRightButtonOrder(false);
        return builder;
    }
    
}


           
       








forms.zip( 197 k)

Related examples in the same category

1.FormLayout: Default Alignment Example 2FormLayout: Default Alignment Example 2
2.FormLayout: Explicit Alignment Example 3FormLayout: Explicit Alignment Example 3
3.Demonstrates the different FormLayout alignmentsDemonstrates the different FormLayout alignments
4.The different sizing units provided by the FormLayoutThe different sizing units provided by the FormLayout
5.FormLayout: Size Specification Example 4FormLayout: Size Specification Example 4
6.Demonstrates sizes: constant, minimum, preferredDemonstrates sizes: constant, minimum, preferred
7.Demonstrates the basic FormLayout sizes: constant, minimum, preferredDemonstrates the basic FormLayout sizes: constant, minimum, preferred
8.Three FormLayout component sizes: minimum, default and preferredThree FormLayout component sizes: minimum, default and 
 preferred
9.FormLayout: Spacing Example 5FormLayout: Spacing Example 5
10.Panel Builder Example 1Panel Builder Example 1
11.Panel Builder Example 2Panel Builder Example 2
12.Columns and rows are specified before the panel is filled with componentsColumns and rows are specified before the panel is filled with components
13.Build a panel with a leading indent column using the DefaultFormBuilderBuild a panel with a leading
 indent column using the DefaultFormBuilder
14.FormLayout: Growable Example 8FormLayout: Growable Example 8
15.FormLayout: No Grouping Example 9FormLayout: No Grouping Example 9
16.FormLayout: Grouping Example 10FormLayout: Grouping Example 10
17.Demonstrates a pure use of the FormLayoutDemonstrates a pure use of the FormLayout
18.Columns and rows are specified before the panel is filled with components 1Columns and rows are specified before the panel is filled with components 1
19.How columns and rows can be grouped in FormLayoutHow columns and rows can be grouped in FormLayout
20.FormLayout growing options: none, default, weightedFormLayout growing options: none, default, weighted
21.FormLayout: Default Form Builder Example 1FormLayout: Default Form Builder Example 1
22.Uses the FormLayout and the DefaultFormBuilderUses the FormLayout and the DefaultFormBuilder
23.The use of Factories as provided by the Forms frameworkThe use of Factories as provided by the Forms framework
24.Demonstrates how to find bugs in the layout usingDemonstrates how to find bugs in the layout using
25.Build panels component orientation: left-to-right vs. right-to-leftBuild panels component orientation: left-to-right vs. right-to-left
26.Demonstrates a frequent pitfall when specifying a growing rowDemonstrates a frequent pitfall when specifying a growing row
27.Demonstrates how a JTextArea's preferred size grows with the container if no columns and rows are setDemonstrates how a JTextArea's preferred size grows with the container
 if no columns and rows are set
28.FormLayout: Button Bar Builder ExampleFormLayout: Button Bar Builder Example
29.FormLayout: Button Bar Builder Example 2FormLayout: Button Bar Builder Example 2
30.FormLayout: Button Bar Builder Example 3FormLayout: Button Bar Builder Example 3
31.FormLayout: Button Stack Builder Example 1FormLayout: Button Stack Builder Example 1
32.Build button stacks using the ButtonStackBuilderBuild button stacks using the ButtonStackBuilder
33.Demonstrates how to build button bars using a ButtonBarBuilderDemonstrates how to build button bars using a ButtonBarBuilder
34.FormLayout: Basic Example 1FormLayout: Basic Example 1
35.FormLayout: Bounds Example 6FormLayout: Bounds Example 6
36.Create and configure a layout, create a builder, add componentsCreate and configure a layout, create a builder, add components
37.Compares approaches how to append a custom area at the end of a panel built with the DefaultFormBuilderCompares approaches how to append a custom area at the end of
 a panel built with the DefaultFormBuilder
38.Shows three approaches how to add custom rows to a form that is built using a DefaultFormBuilderShows three approaches how to add custom rows to a form that is built
 using a DefaultFormBuilder
39.How FormLayout applies the default column andHow FormLayout applies the default column and
40.FormLayout: Spanning Example 7FormLayout: Spanning Example 7
41.How components can span multiple columns and rowsHow components can span multiple columns and rows