1. flowlayout(流式布局)
- 特点:
flowlayout
是最简单的布局管理器之一,它按照从左到右、从上到下的顺序排列组件。当一行放不下更多的组件时,会自动换行。 - 适用场景:适用于组件数量不多,且不需要复杂对齐的情况。
- 示例代码:
import javax.swing.*; import java.awt.*; public class flowlayoutexample { public static void main(string[] args) { jframe frame = new jframe("flowlayout example"); frame.setdefaultcloseoperation(jframe.exit_on_close); frame.setsize(300, 200); // 设置布局管理器为flowlayout frame.setlayout(new flowlayout()); // 添加组件 frame.add(new jbutton("button 1")); frame.add(new jbutton("button 2")); frame.add(new jbutton("button 3")); // 显示窗口 frame.setvisible(true); } }
2. borderlayout(边界布局)
- 特点:
borderlayout
将容器划分为五个区域:北(north)、南(south)、东(east)、西(west)和中心(center)。每个区域最多只能放置一个组件。 - 适用场景:适用于需要在窗口的固定位置放置组件的情况,如标题栏、状态栏等。
- 示例代码:
import javax.swing.*; import java.awt.*; public class borderlayoutexample { public static void main(string[] args) { jframe frame = new jframe("borderlayout example"); frame.setdefaultcloseoperation(jframe.exit_on_close); frame.setsize(300, 200); // 设置布局管理器为borderlayout frame.setlayout(new borderlayout()); // 添加组件 frame.add(new jbutton("north"), borderlayout.north); frame.add(new jbutton("south"), borderlayout.south); frame.add(new jbutton("east"), borderlayout.east); frame.add(new jbutton("west"), borderlayout.west); frame.add(new jbutton("center"), borderlayout.center); // 显示窗口 frame.setvisible(true); } }
3. gridlayout(网格布局)
- 特点:
gridlayout
将容器划分为一个矩形网格,每个组件占据一个单元格,所有单元格的大小相同。 - 适用场景:适用于需要将组件均匀分布在一个网格中的情况,如计算器界面。
- 示例代码:
import javax.swing.*; import java.awt.*; public class gridlayoutexample { public static void main(string[] args) { jframe frame = new jframe("gridlayout example"); frame.setdefaultcloseoperation(jframe.exit_on_close); frame.setsize(300, 200); // 设置布局管理器为gridlayout,3行3列 frame.setlayout(new gridlayout(3, 3)); // 添加组件 for (int i = 1; i <= 9; i++) { frame.add(new jbutton("button " + i)); } // 显示窗口 frame.setvisible(true); } }
总结
- flowlayout:简单易用,适合组件较少且不需要复杂对齐的情况。
- borderlayout:适用于需要在固定位置放置组件的情况。
- gridlayout:适用于需要将组件均匀分布在网格中的情况。
到此这篇关于java中三种常用布局方式小结的文章就介绍到这了,更多相关java常用布局方式内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论