Compares approaches how to append a custom area at the end of a panel built with the DefaultFormBuilder : FormLayout « Swing Components « Java






Compares approaches how to append a custom area at the end of a panel built with the DefaultFormBuilder

Compares approaches how to append a custom area at the end of
 a panel built with the DefaultFormBuilder
/*
 * 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 javax.swing.*;

import com.jgoodies.forms.builder.DefaultFormBuilder;
import com.jgoodies.forms.layout.CellConstraints;
import com.jgoodies.forms.layout.FormLayout;
import com.jgoodies.forms.layout.RowSpec;

/**
 * Compares approaches how to append a custom area at the end of
 * a panel built with the DefaultFormBuilder:<ol>
 * <li> using two custom rows to align the leading label,
 * <li> using a single custom row with label on top,
 * <li> using a separator.
 * </ol>
 * These differ in the position of the leading 'Feedback" label,
 * and in turn in the alignment of font baselines between label
 * and the text area. 
 *
 * @author  Karsten Lentzsch
 * @version $Revision: 1.8 $
 * 
 * @see     DefaultFormBuilder
 * @see     DefaultFormWithCustomRowsExample
 */

public class DefaultFormWithCustomAreasExample {

    

    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 :: Custom Areas");
        frame.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
        JComponent panel = new DefaultFormWithCustomAreasExample().buildPanel();
        frame.getContentPane().add(panel);
        frame.pack();
        frame.setVisible(true);
    }



    // Building ***************************************************************

    public JComponent buildPanel() {
        JTabbedPane tabbedPane = new JTabbedPane();
        tabbedPane.putClientProperty("jgoodies.noContentBorder", Boolean.TRUE);

        tabbedPane.add(buildCustomAreaWithAlignedLabelPanel(), "Aligned label");
        tabbedPane.add(buildCustomAreaWithTopLabelPanel(),     "Top label");
        tabbedPane.add(buildCustomAreaWithSeparatorPanel(),    "Separator");
        return tabbedPane;
    }
    
    
    private DefaultFormBuilder buildPanelHeader() {
        FormLayout layout = new FormLayout(
                "right:pref, 3dlu, min:grow", 
                "");
        DefaultFormBuilder builder = new DefaultFormBuilder(layout);
        builder.setDefaultDialogBorder();
        builder.setRowGroupingEnabled(true);
        
        builder.appendSeparator("Customer Data");
        builder.append("Last Name",  new JTextField());
        builder.append("First Name", new JTextField());
        builder.append("Street",     new JTextField());
        builder.append("Email",      new JTextField());

        return builder;
    }
    
    
    /**
     * Demonstrates how to append a larger custom area at the end of
     * a panel that is build with a {@link DefaultFormBuilder}.<p>
     * 
     * We add a gap and a single custom row that grows and that
     * is filled vertically (where the default is center vertically).
     * The area uses a standard leading label.
     * 
     * @return the custom area panel with aligned labels
     */
    private JComponent buildCustomAreaWithAlignedLabelPanel() {
        DefaultFormBuilder builder = buildPanelHeader();

        CellConstraints cc = new CellConstraints();
        builder.append("Feedback");
        builder.appendRow(new RowSpec("0:grow"));
        builder.add(new JScrollPane(new JTextArea("Feedback - font baselines shall be aligned")),
                    cc.xywh(builder.getColumn(), builder.getRow(), 1, 2, "fill, fill"));

        return builder.getPanel();
    }


    /**
     * Demonstrates how to append two custom areas at the end of
     * a panel that is build with a DefaultFormBuilder.
     * 
     * @return the custom area panel with label in the top
     */
    private JComponent buildCustomAreaWithTopLabelPanel() {
        DefaultFormBuilder builder = buildPanelHeader();

        CellConstraints cc = new CellConstraints();
        builder.appendRow(builder.getLineGapSpec());
        builder.appendRow(new RowSpec("top:28dlu:grow"));
        builder.nextLine(2);
        builder.append("Feedback");
        builder.add(new JScrollPane(new JTextArea("Feedback - likely the baselines are not aligned")),
                    cc.xy(builder.getColumn(), builder.getRow(), "fill, fill"));

        return builder.getPanel();
    }
    

    /**
     * Demonstrates how to append a larger custom area at the end of
     * a panel that is build with a DefaultFormBuilder.<p>
     * 
     * We add a gap and a single custom row that grows and that
     * is filled vertically (where the default is center vertically).
     * The area is separated by a titled separator and it is indented
     * using an empty leading label.
     * 
     * @return the custom area panel with separators
     */
    private JComponent buildCustomAreaWithSeparatorPanel() {
        DefaultFormBuilder builder = buildPanelHeader();
        
        builder.appendSeparator("Customer Feedback");
        builder.appendRow(builder.getLineGapSpec());
        builder.appendRow(new RowSpec("fill:28dlu:grow"));
        builder.nextLine(2);
        builder.append("", new JScrollPane(new JTextArea()));

        return builder.getPanel();
    }


 }

           
       








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.Demonstrates how to build button bars with a fixed button orderDemonstrates how to build button bars with a fixed button order
35.FormLayout: Basic Example 1FormLayout: Basic Example 1
36.FormLayout: Bounds Example 6FormLayout: Bounds Example 6
37.Create and configure a layout, create a builder, add componentsCreate and configure a layout, create a builder, add components
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