Shows three approaches how to add custom rows to a form that is built using a DefaultFormBuilder : FormLayout « Swing Components « Java






Shows three approaches how to add custom rows to a form that is built using a DefaultFormBuilder

Shows three approaches how to add custom rows to a form that is built
 using a 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;

/**
 * Shows three approaches how to add custom rows to a form that is built
 * using a DefaultFormBuilder.<ol> 
 * <li> single custom row, 
 * <li> standard + custom row, 
 * <li> multiple standard rows.
 * </ol>
 * These differ in the position of the 'Comment' label, the alignment 
 * of font baselines and the height of the custom row. 
 *
 * @author Karsten Lentzsch
 * @version $Revision: 1.7 $
 * 
 * @see    DefaultFormBuilder
 * @see    DefaultFormWithCustomAreasExample
 */

public class DefaultFormWithCustomRowsExample {

    private JTextField name1Field;
    private JTextArea  comment1Area;
    private JTextField name2Field;
    private JTextArea  comment2Area;
    private JTextField name3Field;
    private JTextArea  comment3Area;
    

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


    // Component Creation and Initialization **********************************

    /**
     *  Creates and intializes the UI components.
     */
    private void initComponents() {
        name1Field     = new JTextField("Name - font baselines shall be aligned");
        name2Field     = new JTextField("Name - font baselines shall be aligned");
        name3Field     = new JTextField("Name - font baselines shall be aligned");
        comment1Area   = new JTextArea(2, 20);
        comment2Area   = new JTextArea(2, 20);
        comment3Area   = new JTextArea(2, 20);
        comment1Area.setText("Comment - likely baselines are unaligned");
        comment2Area.setText("Comment - baselines shall be aligned");
        comment3Area.setText("Comment - baselines shall be aligned");
    }


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

    /**
     * Demonstrates three different ways to add custom rows to a form
     * that is build with a {@link DefaultFormBuilder}.
     * 
     * @return the built panel
     */
    public JComponent buildPanel() {
        initComponents();

        FormLayout layout = new FormLayout(
                "right:pref, 3dlu, min:grow", 
                "");
        DefaultFormBuilder builder = new DefaultFormBuilder(layout);
        builder.setDefaultDialogBorder();
        builder.setRowGroupingEnabled(true);
        
        CellConstraints cc = new CellConstraints();

        // In this approach, we add a gap and a custom row.
        // The advantage of this approach is, that we can express
        // the row spec and comment area cell constraints freely.
        // The disadvantage is the misalignment of the leading label.
        // Also the row's height may be inconsistent with other rows. 
        builder.appendSeparator("Single Custom Row");
        builder.append("Name", name1Field); 
        builder.appendRow(builder.getLineGapSpec());
        builder.appendRow(new RowSpec("top:31dlu")); // Assumes line is 14, gap is 3
        builder.nextLine(2);
        builder.append("Comment");
        builder.add(new JScrollPane(comment1Area), 
                    cc.xy(builder.getColumn(), builder.getRow(), "fill, fill"));
        builder.nextLine();

        // In this approach, we append a standard row with gap before it.
        // The advantage is, that the leading label is aligned well.
        // The disadvantage is that the comment area now spans
        // multiple cells and is slightly less flexible.
        // Also the row's height may be inconsistent with other rows. 
        builder.appendSeparator("Standard + Custom Row");
        builder.append("Name", name2Field); 
        builder.append("Comment");
        builder.appendRow(new RowSpec("17dlu")); // Assumes line is 14, gap is 3
        builder.add(new JScrollPane(comment2Area), 
                    cc.xywh(builder.getColumn(), builder.getRow(), 1, 2));
        builder.nextLine(2);

        // In this approach, we append two standard rows with associated gaps.
        // The advantage is, that the leading label is aligned well, 
        // and the height is consistent with other rows.
        // The disadvantage is that the comment area now spans
        // multiple cells and is slightly less flexible.
        builder.appendSeparator("Two Standard Rows");
        builder.append("Name", name3Field); 
        builder.append("Comment");
        builder.nextLine();
        builder.append("");
        builder.nextRow(-2);
        builder.add(new JScrollPane(comment3Area), 
                    cc.xywh(builder.getColumn(), builder.getRow(), 1, 3));

        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.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
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