Build panels component orientation: left-to-right vs. right-to-left : FormLayout实例 « Swing组件 « Java

En
Java
1. 图形用户界面
2. 三维图形动画
3. 高级图形
4. 蚂蚁编译
5. Apache类库
6. 统计图
7. 
8. 集合数据结构
9. 数据类型
10. 数据库JDBC
11. 设计模式
12. 开发相关类
13. EJB3
14. 电子邮件
15. 事件
16. 文件输入输出
17. 游戏
18. 泛型
19. GWT
20. Hibernate
21. 本地化
22. J2EE平台
23. 基于J2ME
24. JDK-6
25. JNDI的LDAP
26. JPA
27. JSP技术
28. JSTL
29. 语言基础知识
30. 网络协议
31. PDF格式RTF格式
32. 映射
33. 常规表达式
34. 脚本
35. 安全
36. Servlets
37. Spring
38. Swing组件
39. 图形用户界面
40. SWT-JFace-Eclipse
41. 线程
42. 应用程序
43. Velocity
44. Web服务SOA
45. 可扩展标记语言
Java 教程
Java » Swing组件 » FormLayout实例屏幕截图 
Build panels component orientation: left-to-right vs. right-to-left
Build panels component orientation: left-to-right vs. right-to-left

/*
 * 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 java.awt.Insets;

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

import com.jgoodies.forms.builder.DefaultFormBuilder;
import com.jgoodies.forms.builder.PanelBuilder;
import com.jgoodies.forms.layout.CellConstraints;
import com.jgoodies.forms.layout.ColumnSpec;
import com.jgoodies.forms.layout.FormLayout;
import com.jgoodies.forms.layout.RowSpec;
import com.jgoodies.forms.layout.FormSpec.DefaultAlignment;

/**
 * Demonstrates how to build panels that honor or ignore the current
 * component orientation: left-to-right vs. right-to-left.<p>
 
 * This example uses a utility class that may be moved to the extras or 
 * to the Forms core in a future version. The tricky part is the abstract 
 * definition of column specifications and cell constraints.<p>
 *  
 * The example below utilizes the <code>OrientationUtils</code> to flip
 * column specification defaul alignments and to reverse the order of
 * column specifications. Cell constraints need to be adjusted too; this
 * example avoids the problem by using a builder that creates <em>all</em>
 * cell constraints.<p>
 
 * You can find information about the latest additions regarding the
 * Forms support for different component orientations in the comments for 
 * <a href="http://forms.dev.java.net/issues/show_bug.cgi?id=2">issue #2</a>.  
 
 @author  Karsten Lentzsch
 @version $Revision: 1.6 $
 
 @see     com.jgoodies.forms.builder.AbstractFormBuilder
 @see     com.jgoodies.forms.builder.DefaultFormBuilder
 */
public class ComponentOrientationExample {
    
    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 :: Component Orientation");
        frame.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
        JComponent panel = new ComponentOrientationExample().buildPanel();
        frame.getContentPane().add(panel);
        frame.pack();
        frame.setVisible(true);
    }


    public JComponent buildPanel() {
        FormLayout layout = new FormLayout("pref:grow");
        DefaultFormBuilder rowBuilder = new DefaultFormBuilder(layout);
        rowBuilder.setDefaultDialogBorder();
        
        rowBuilder.append(buildSample("Left to Right",       true));
        rowBuilder.append(buildSample("Right to Left",       false));
        rowBuilder.append(buildSample("Default Orientation"
                new PanelBuilder(layout).isLeftToRight()));
        
        return rowBuilder.getPanel();
    }
    
    /**
     * Creates and returns a sample panel that consists of a titled
     * separator and two component lines each with a 'leading' label.
     * Honors the specified component orientation.<p>
     
     * The builder code avoids creating individual cell constraints;
     * all cell constraints used in the example below will be created
     * on-the-fly by the builder layer.<p>
     
     * Note that cell constraints should be flipped and repositioned
     * if they are intended for being used with left-to-right and
     * right-to-left layouts.
     
     @return the sample panel
     */
    private Component buildSample(String title, boolean leftToRight) {
        String leftToRightSpecs = "right:pref, 4dlu, pref:grow, 3dlu, pref:grow";
        FormLayout layout = leftToRight 
                   new FormLayout(leftToRightSpecs)
                   new FormLayout(OrientationUtils.flipped(leftToRightSpecs),
                                    new RowSpec[] {});
        DefaultFormBuilder builder = new DefaultFormBuilder(layout);
        builder.setLeftToRight(leftToRight);
        builder.setDefaultDialogBorder();
        
        builder.appendSeparator(title);
        builder.append("Level")
        builder.append(new JTextField(10)3);
        
        builder.append("Radar"new JTextField(10));
        builder.append(new JTextField(10));
        return builder.getPanel();
    }
    
    
    // Helper Code ************************************************************
    
    /**
     * Provides some convenience behavior for flipping side in column
     * specifications, arrays of column specifications and encoded
     * column specs.
     */
    private static class OrientationUtils {
    
        /**
         * Flips the default alignment of the given column specification 
         * and returns a new column specification object with the flipped
         * alignment and the same size and growing behavior as the original.
         
         @param spec    the original column specification
         @return the column specification with flipped default alignment
         */
        static ColumnSpec flipped(ColumnSpec spec) {
            DefaultAlignment alignment = spec.getDefaultAlignment();
            if (alignment == ColumnSpec.LEFT)
                alignment = ColumnSpec.RIGHT;
            else if (alignment == ColumnSpec.RIGHT)
                alignment = ColumnSpec.LEFT;
            return new ColumnSpec(alignment, spec.getSize(), spec.getResizeWeight());
        }
        
        /**
         * Returns an array of column specifications that is built from the
         * given array by flipping each column spec and reversing their order.
         
         @param original  the original array of column specifications
         @return an array of flipped column specs in reversed order
         */
        static ColumnSpec[] flipped(ColumnSpec[] original) {
            int length = original.length;
            ColumnSpec[] flipped = new ColumnSpec[length];
            for (int i = 0; i < length; i++) {
                flipped[i= flipped(original[length -- i]);
            }
            return flipped;
        }
        
        /**
         * Returns an array of column specifications that is built from the
         * given encoded column specifications by flipping each column spec 
         * and reversing their order.
         
         @param encodedColumnSpecs  the original comma-separated encoded 
         *     column specifications
         @return an array of flipped column specs in reversed order
         */
        static ColumnSpec[] flipped(String encodedColumnSpecs) {
            return flipped(ColumnSpec.decodeSpecs(encodedColumnSpecs));
        }
        
        /**
         * Creates and returns a horizontally flipped clone of the 
         * given cell constraints object. Flips the horizontal alignment
         * and the left and right insets.
         
         @param cc   the original cell constraints object
         @return the flipped cell constraints with flipped horizontal 
         *     alignment, and flipped left and right insets - if any
         */
        static CellConstraints flipHorizontally(CellConstraints cc) {
            CellConstraints.Alignment flippedHAlign = cc.hAlign;
            if (flippedHAlign == CellConstraints.LEFT)
                flippedHAlign = CellConstraints.RIGHT;
            else if (flippedHAlign == CellConstraints.RIGHT)
                flippedHAlign = CellConstraints.LEFT;
            
            CellConstraints flipped = new CellConstraints(
                    cc.gridX, 
                    cc.gridY,
                    cc.gridWidth,
                    cc.gridHeight,
                    flippedHAlign,
                    cc.vAlign);
            if (cc.insets != null) {
                flipped.insets = new Insets(
                        cc.insets.top, 
                        cc.insets.right, 
                        cc.insets.bottom, 
                        cc.insets.left);
            }
            return flipped;
        }
        
        /**
         * Creates and returns a horizontally flipped clone of the 
         * given cell constraints object with the grid position adjusted
         * to the given column count. Flips the horizontal alignment
         * and the left and right insets. And swaps the left and right
         * cell positions according to the specified column count.
         
         @param cc   the original cell constraints object
         @param columnCount the number of columns; 
         *     used to swap the left and right cell bounds
         @return the flipped cell constraints with flipped horizontal 
         *     alignment, and flipped left and right insets - if any
         */
        static CellConstraints flipHorizontally(CellConstraints cc, int columnCount) {
            CellConstraints flipped = flipHorizontally(cc);
            flipped.gridX = columnCount + - cc.gridX;
            return flipped;
        }
    }

}



           
       
forms.zip( 197 k)
Related examples in the same category
1. FormLayout :默认对齐范例2FormLayout :默认对齐范例2
2. FormLayout :明确对齐范例3FormLayout :明确对齐范例3
3. 体现了不同的FormLayout对齐体现了不同的FormLayout对齐
4. FormLayout提供不同大小的单位FormLayout提供不同大小的单位
5. FormLayout:尺寸规格范例4FormLayout:尺寸规格范例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:间距范例5FormLayout:间距范例5
10. 面板生成示例1面板生成示例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 :增长范例8FormLayout :增长范例8
15. FormLayout :没有分组实例9FormLayout :没有分组实例9
16. FormLayout :分组例如10FormLayout :分组例如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. 如何在FormLayout为列和行如何在FormLayout为列和行
20. FormLayout增长选项:无,默认情况下,加权FormLayout增长选项:无,默认情况下,加权
21. FormLayout :默认格式生成示例1FormLayout :默认格式生成示例1
22. 使用FormLayout和DefaultFormBuilder使用FormLayout和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. Demonstrates a frequent pitfall when specifying a growing rowDemonstrates a frequent pitfall when specifying a growing row
26. 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
27. FormLayout :按钮栏中构建范例FormLayout :按钮栏中构建范例
28. FormLayout :按钮栏中生成范例2FormLayout :按钮栏中生成范例2
29. FormLayout :按钮栏中生成范例3FormLayout :按钮栏中生成范例3
30. FormLayout :按钮构建范例1FormLayout :按钮构建范例1
31. 使用ButtonStackBuilder演示如何建立按钮栈使用ButtonStackBuilder演示如何建立按钮栈
32. Demonstrates how to build button bars using a ButtonBarBuilderDemonstrates how to build button bars using a ButtonBarBuilder
33. Demonstrates how to build button bars with a fixed button orderDemonstrates how to build button bars with a fixed button order
34. FormLayout :基本范例1FormLayout :基本范例1
35. FormLayout :捆绑范例6FormLayout :捆绑范例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. 如何FormLayout适用默认栏和如何FormLayout适用默认栏和
40. FormLayout :生成树实例7FormLayout :生成树实例7
41. 组件如何可以跨多个列和行组件如何可以跨多个列和行
www.java2java.com | Contact Us
Copyright 2010 - 2030 Java Source and Support. All rights reserved.
All other trademarks are property of their respective owners.