`
hizhangqi
  • 浏览: 89431 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

swing layout-demo

 
阅读更多
source http://zhangjunhd.blog.51cto.com/113473/128174/

v\:* {behavior:url(#default#VML);} o\:* {behavior:url(#default#VML);} w\:* {behavior:url(#default#VML);} .shape {behavior:url(#default#VML);} 当选择使用JPanel和顶层容器的content pane时,需要考虑布局管理。JPanel缺省是初始化一个FlowLayout,而content pane缺省是初始化一个BorderLayout。
下面将分别介绍几种最常用的布局管理器:FlowLayout、BorderLayout、BoxLayout、CardLayout、GridLayout和GridBagLayout。
代码演示每一个布局管理器都会有一个代码演示,xxxLayoutDemo.java(见附件)。这些文件主要有三个方法组成:
addComponentsToPane()提供布局逻辑(依据不同的布局管理器和UI内容)。
public static void addComponentsToPane(Container pane) {。。。}

createAndShowGUI()实例化一个JFrame,通过它的ContentPane加载布局逻辑内容。private static void createAndShowGUI() {    // Create and set up the window.    JFrame frame = new JFrame("FlowLayoutDemo");    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);    // Set up the content pane.    addComponentsToPane(frame.getContentPane());    // Display the window.    frame.pack();    frame.setVisible(true);}

main()程序入口,单独起一个线程,实例化UI。
public static void main(String[] args) {    javax.swing.SwingUtilities.invokeLater(new Runnable() {       public void run() {           createAndShowGUI();       }    });}

FlowLayoutFlowLayout类是最简单的布局管理器。它按照和页面上排列单词的类似方式来安排组件----从左到右,直至没有多余的空间,然后转到下一行。
效果:

内容面板代码:
public static void addComponentsToPane(Container pane) {    pane.setLayout(new FlowLayout());    pane.add(new JButton("Button 1"));    pane.add(new JButton("Button 2"));    pane.add(new JButton("Button 3"));    pane.add(new JButton("Long-Named Button 4"));    pane.add(new JButton("5"));}

BorderLayout一个BorderLayout对象将界面分成五大区域,分别用BorderLayout类的静态常量指定:
-PAGE_START
-PAGE_END
-LINE_START
-LINE_END
-CENTER
效果:

内容面板代码:
public static void addComponentsToPane(Container pane) {           JButton button = new JButton("Button 1 (PAGE_START)");    pane.add(button, BorderLayout.PAGE_START);          button = new JButton("Button 2 (CENTER)");    button.setPreferredSize(new Dimension(200, 100));    pane.add(button, BorderLayout.CENTER);        button = new JButton("Button 3 (LINE_START)");    pane.add(button, BorderLayout.LINE_START);          button = new JButton("Long-Named Button 4 (PAGE_END)");    pane.add(button, BorderLayout.PAGE_END);           button = new JButton("5 (LINE_END)");    pane.add(button, BorderLayout.LINE_END);}

BoxLayoutBoxLayout可以将组件由上至下或由左至右依次加入当前面板。
效果:

内容面板代码:
public static void addComponentsToPane(Container pane) {    JPanel xPanel = new JPanel();    xPanel.setLayout(new BoxLayout(xPanel, BoxLayout.X_AXIS));    addButtons(xPanel);    JPanel yPanel = new JPanel();    yPanel.setLayout(new BoxLayout(yPanel, BoxLayout.Y_AXIS));    addButtons(yPanel);        pane.add(yPanel, BorderLayout.PAGE_START);    pane.add(xPanel, BorderLayout.PAGE_END);} private static void addAButton(String text, Container container) {    JButton button = new JButton(text);    button.setAlignmentX(Component.CENTER_ALIGNMENT);    container.add(button);} private static void addButtons(Container container) {    addAButton("Button 1", container);    addAButton("Button 2", container);    addAButton("Button 3", container);    addAButton("Long-Named Button 4", container);    addAButton("5", container);}

CardLayout卡片布局和其他布局不同,因为它隐藏了一些组件。卡片布局就是一组容器或者组件,它们一次仅仅显是一个,组中的每个容器称为卡片。
效果:

内容面板代码:
public void addComponentToPane(Container pane) {    final JPanel contentPanel = new JPanel();    JPanel controlPanel = new JPanel();    final CardLayout cardLayout=new CardLayout();;    pane.setLayout(new BorderLayout());    pane.add(contentPanel, BorderLayout.CENTER);    pane.add(controlPanel, BorderLayout.PAGE_END);    controlPanel.setLayout(new FlowLayout());     JButton[] b = new JButton[10];    for (int i = 0; i < 10; i++) {       b[i] = new JButton("No." + i);       contentPanel.add(b[i]);    }    contentPanel.setLayout(cardLayout);    JButton nextButton = new JButton("next");    nextButton.addActionListener(new ActionListener(){       public void actionPerformed(ActionEvent e) {           cardLayout.next(contentPanel);       }});    controlPanel.add(nextButton);}

GridLayoutGridLayout让你建立一个组件表格,并且当组件加入时,会依序又左至右,由上至下填充到每个格子,它不能由你指定想放那个格子就放那个格子
效果:

内容面板代码:
public static void addComponentsToPane(Container pane) {    JButton[] buttons = new JButton[9];    pane.setLayout(new GridLayout(3, 3));    for (int i = 0; i < buttons.length; i++) {       buttons[i] = new JButton(i + "");       pane.add(buttons[i]);    }}

GridBagLayoutGridBagLayout是所有AWT布局管理器当中最复杂的,同时他的功能也是最强大的。GridBagLayout同GridLayout一样,在容器中以网格形式来管理组件。但GridBagLayout功能要来得强大得多。1、GridBagLayout管理的所有行和列都可以是大小不同的;2、GridLayout把每个组件限制到一个单元格,而GridBagLayout并不这样:组件在容器中可以占据任意大小的矩形区域。GridBagLayout通常由一个专用类来对他布局行为进行约束,该类叫GridBagConstraints。其中有11个公有成员变量,GridBagConstraints可以从这11个方面来进行控制和操纵。这些内容是:
1、gridx—组件的横向坐标;
2、girdy—组件的纵向坐标;
3、gridwidth—组件的横向宽度,也就是指组件占用的列数;
4、gridheight—组件的纵向长度,也就是指组件占用的行数;
5、weightx—指行的权重,告诉布局管理器如何分配额外的水平空间;
6、weighty—指列的权重,告诉布局管理器如何分配额外的垂直空间;
7、anchor—当组件小于其显示区域时使用此字段;
8、fill—如果显示区域比组件的区域大的时候,可以用来控制组件的行为。控制组件是垂直填充,还是水平填充,或者两个方向一起填充;
9、insets—指组件与表格空间四周边缘的空白区域的大小;
10、ipadx— 组件间的横向间距,组件的宽度就是这个组件的最小宽度加上ipadx值;
11、ipady— 组件间的纵向间距,组件的高度就是这个组件的最小高度加上ipady值。
说明:
1、gridx,gridy:其实就是组件行列的设置,注意都是从0开始的,比如 gridx=0,gridy=1时放在0行1列;
2、gridwidth,gridheight:默认值为1;GridBagConstraints.REMAINDER常量,代表此组件为此行或此列的最后一个组件,会占据所有剩余的空间;
3、weightx,weighty:当窗口变大时,设置各组件跟着变大的比例。比如组件A的weightx=0.5,组件B的weightx=1,那么窗口X轴变大时剩余的空间就会以1:2的比例分配给组件A和B;
4、anchor:当组件空间大于组件本身时,要将组件置于何处。 有CENTER(默认值)、NORTH、NORTHEAST、EAST、SOUTHEAST、WEST、NORTHWEST选择。
5、insets:设置组件之间彼此的间距。它有四个参数,分别是上,左,下,右,默认为(0,0,0,0)。
效果:

内容面板代码:
public static void addComponentsToPane(Container pane) {    JButton button;    pane.setLayout(new GridBagLayout());    GridBagConstraints c = new GridBagConstraints();     button = new JButton("Button 1");    c.fill = GridBagConstraints.HORIZONTAL;    c.gridx = 0;    c.gridy = 0;    pane.add(button, c);     button = new JButton("Button 2");    c.fill = GridBagConstraints.HORIZONTAL;    c.weightx = 0.5;    c.gridx = 1;    c.gridy = 0;    pane.add(button, c);     button = new JButton("Button 3");    c.fill = GridBagConstraints.HORIZONTAL;    c.weightx = 0.5;    c.gridx = 2;    c.gridy = 0;    pane.add(button, c);     button = new JButton("Long-Named Button 4");    c.fill = GridBagConstraints.HORIZONTAL;    c.ipady = 40; // make this component tall    c.weightx = 0.0;    c.gridwidth = 3;    c.gridx = 0;    c.gridy = 1;    pane.add(button, c);     button = new JButton("5");    c.fill = GridBagConstraints.HORIZONTAL;    c.ipady = 0; // reset to default    c.weighty = 1.0; // request any extra vertical space    c.anchor = GridBagConstraints.PAGE_END; // bottom of space    c.insets = new Insets(10, 0, 0, 0); // top padding    c.gridx = 1; // aligned with button 2    c.gridwidth = 2; // 2 columns wide    c.gridy = 2; // third row    pane.add(button, c);    }

一个GardBagLayout布局的左右选择框,代码GridBagLayoutFrame.java见附件,效果:

本文出自 “子 孑” 博客,请务必保留此出处http://zhangjunhd.blog.51cto.com/113473/128174

分享到:
评论

相关推荐

    swing-layout-1.0.3

    swing-layout-1.0.3swing-layout-1.0.3swing-layout-1.0.3swing-layout-1.0.3swing-layout-1.0.3swing-layout-1.0.3swing-layout-1.0.3swing-layout-1.0.3swing-layout-1.0.3swing-layout-1.0.3swing-layout-1.0.3...

    swing做的漂亮Demo

    本Demo展示了Swing如何创建出美观且功能丰富的界面,其中包括了结构图和流程图等高级布局管理器的应用,非常适合开发者进行学习和参考。 在Swing中,组件(Components)是构建界面的基本单元,例如按钮(JButton)...

    第七个范例——布局之LayoutContainer

    LayoutContainer可能是某个特定编程框架或库的一部分,比如Java Swing、JavaFX、HTML/CSS中的div布局、Android的LinearLayout等。它允许开发者以声明式的方式定义组件的排列方式,如网格布局、流式布局、卡片布局、...

    有向图自动布局-JGraph--demo

    - **可嵌入性**:可以轻松地集成到各种Java应用程序中,如Swing或JavaFX应用。 文件名"Jgraph"可能是指JGraph的示例代码或者文档,通过查看这个文件,你可以学习如何使用JGraph库来创建和管理有向图,包括导入和...

    myLabel-demo

    在各种编程语言和框架中(如Java Swing、C# WinForms、Python PyQt、iOS UIKit、Android等),都有相应的`label`类或者组件供开发者使用。 在这个"myLabel-demo"中,我们关注的核心特性是`label`的尺寸调整策略。在...

    关于Swing的几个小Demo

    10. **Layout Managers**:Swing提供了多种布局管理器,如FlowLayout、BorderLayout、GridLayout、GridBagLayout等,它们负责自动安排组件在容器中的布局。 11. **Event Handling**:Swing通过事件监听器模型来处理...

    Open Swing Demo

    6. **Layout Managers**: Swing提供了多种布局管理器,如FlowLayout、GridLayout、BorderLayout和BoxLayout等,用于控制组件在容器中的排列方式。了解和熟练使用布局管理器是创建整洁、响应式的GUI的关键。 7. **...

    reference for swing and code generator demo

    这个“reference for swing and code generator demo”显然指向一个关于Swing使用和代码生成器演示的资源集合。Swing提供了丰富的组件,用于创建桌面应用程序,包括按钮、文本框、菜单等,而且它的组件是轻量级的,...

    jgraphx-1_9_1_2.zip jar包与Swing Demo

    6. **示例和Demo**:压缩包中可能包含了 **Swing Demo**,这是一个演示如何在Swing应用中使用jgraphx的实例,开发者可以通过这些示例快速上手。 在Swing应用中集成 **jgraphx**,开发者需要做以下步骤: 1. 解压 *...

    swing小黑点移动

    在Java GUI中,BoxLayoutDemo可能是一个使用BoxLayout布局管理器的示例。BoxLayout允许我们将组件沿X轴或Y轴线性排列。为了实现小黑点移动,我们可能不使用布局管理器来定位小黑点,而是直接在组件的 paintComponent...

    emrecanderin_swing_demo:摇摆演示

    在【压缩包子文件的文件名称列表】中,"emrecanderin_swing_demo-main"可能是项目的主目录或者入口点,它包含着整个应用的源代码、资源文件和配置信息。一般情况下,"main"常常与`main`函数相关联,这是Java程序执行...

    java gui demo

    2. **布局管理器(Layout Managers)**:Java GUI支持不同的布局管理器,如FlowLayout、BorderLayout、GridLayout、CardLayout和GridBagLayout,用于自动调整组件的位置和大小。 3. **事件处理(Event Handling)**...

    SwiftGantt_0.3.7_withdemo

    8. swing-layout-1.0.3.jar:这是一个Swing布局管理器的扩展,帮助优化和定制Swing组件的布局,使得甘特图在界面上更加美观和易用。 9. swiftganttdemo.jar:这是SwiftGantt的演示程序主jar文件,包含了甘特图实例...

    (完整word版)Java-swing布局详解(附示例图).doc

    例如,在 BoxLayoutDemo 代码中,我们使用 BoxLayout 布局管理器来排列按钮组件: ```java public static void addComponentsToPane(Container pane) { Box box = Box.createHorizontalBox(); box.add(new JButton...

    ControlDemo:一些控件的基础Demo

    下面将详细阐述Java GUI编程中的关键知识点,并结合`ControlDemo-master`这个项目的背景进行讲解。 1. **Java Swing和AWT**:Java GUI编程主要基于两种库,Abstract Window Toolkit (AWT) 和 Swing。AWT是Java早期...

    java Swing布局管理之BoxLayout布局

    public class BoxLayoutDemo { public static void main(String[] args) { try { UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName()); } catch (Exception e) { // Handle exception } ...

    Java Swing组件BoxLayout布局用法示例

    public class BoxLayoutDemo extends JPanel { JPanel sportPanel; JPanel queryPanel; JPanel middlePanel; public BoxLayoutDemo() { // 主面板由3个子面板组成,在水平方向排列 setLayout(new BoxLayout...

    swingui:演示Java Swing UI代码的组件,窗格和布局的一部分

    SwingUI Demo for learning 学习Swing UI的时候,写的小示例。不包括很基础的组件说明(比如文本框、文件选择等) 大部分代码参考自: Demo包括 layout DemoBorderLayout DemoBoxLayout DemoCardLayout ...

    java-界面组件案例大全(内含139个完整Demo)

    1. **布局管理器**(layout):在"layout"目录下,你将找到关于布局管理器的示例,如FlowLayout、BorderLayout、GridLayout、CardLayout和GridBagLayout等。布局管理器决定了组件在容器中的排列方式,是GUI设计的...

Global site tag (gtag.js) - Google Analytics