首先我们要了解布局管理器的作用
Java布局管理器作用:
跨平台时,当一个窗体中有文本控件,又有标签,还有按钮,这时你怎么控制它们在窗体中的排列顺序和位置呢,JAVA定义了布局管理器来处理这个问题的
三大常用布局管理器:
1.BorderLayout
将版面划分成东、西、南、北、中五个区域,将添加的组件按指定位置放置。
BorderLayout.EAST
BorderLayout.WEST
BorderLayout.SOUTH
BorderLayout.NORTH
BorderLayout.CENTER
构造函数:
BorderLayout()
注意事项:
1、不是五个部分都必须添加
2、中部组件会自动调节大小(在其他部位没有的时候)
3、JFrame,JDialog 默认布局管理器就是BorderLayout
案例:
<span style="font-family:KaiTi_GB2312;font-size:18px;">/*
* BorderLayout演示
* 1.继承JFrame
* 2.定义你需要的组件
* 3.创建组件(构造函数)
* 4.添加组件
* 5.对窗体设置
* 6.显示窗体
*/
package com.test1;
import java.awt.*;
import javax.swing.*;
//继承JFrame类(窗体)和VB窗体相似
public class Demo8_2 extends JFrame{
//定义组件
JButton jb1,jb2,jb3,jb4,jb5;
public static void main(String[] args) {
// TODO Auto-generated method stub
Demo8_2 demo8_2=new Demo8_2();
}
public Demo8_2()
{
//创建组件
jb1=new JButton("中部");
jb2=new JButton("北部");
jb3=new JButton("东部");
jb4=new JButton("南部");
jb5=new JButton("西部");
//添加各个组件,定位
this.add(jb1,BorderLayout.CENTER);
this.add(jb2,BorderLayout.NORTH);
this.add(jb3,BorderLayout.EAST);
this.add(jb4,BorderLayout.SOUTH);
this.add(jb5,BorderLayout.WEST);
//设置窗体属性
this.setTitle("边界布局案例");
this.setSize(300,200);//大小
this.setLocation(200,300);//初始位置
this.setResizable(false);//禁止用户改变窗体大小
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);//关闭窗体时关闭java虚拟机,以免占用内存
//显示窗体
this.setVisible(true);
}
}
</span>
效果:
2.FlowLayout(流式布局)
组件按从左到右而后从上到下的顺序依次排列,一行不能放完则折到下一行。
构造函数:
FlowLayout()
建立一个默认为居中对齐,组件彼此有5单位的水平与垂直间距的FlowLayout
FlowLayout(int align)
建立一个可设置排列方式且组件彼此有5单位的水平与垂直间距的FlowLayout
FlowLayout(int align,int hgap,int vgap)
建立一个可设置排列方式与组件间距的FlowLayout
注意事项:
1、不限制它所管理的组件大小,允许它们有最佳大小
2、当容器被缩放时,组件的位置可能变化,但组件的大小不变(在窗体属性那里加如下代码即可)
案例:代码和上面一样除添加各个组件,定位那里,如下
组件按从左到右而后从上到下的顺序依次排列,一行不能放完则折到下一行。
构造函数:
FlowLayout()
建立一个默认为居中对齐,组件彼此有5单位的水平与垂直间距的FlowLayout
FlowLayout(int align)
建立一个可设置排列方式且组件彼此有5单位的水平与垂直间距的FlowLayout
FlowLayout(int align,int hgap,int vgap)
建立一个可设置排列方式与组件间距的FlowLayout
注意事项:
1、不限制它所管理的组件大小,允许它们有最佳大小
2、当容器被缩放时,组件的位置可能变化,但组件的大小不变(在窗体属性那里加如下代码即可)
<span style="font-family:KaiTi_GB2312;font-size:18px;">//禁止用户改变窗体大小
this.setResizable(false);</span>
3、默认组件是居中对齐,可以通过FlowLayout(int align)函数来指定对齐方式(如下图)案例:代码和上面一样除添加各个组件,定位那里,如下
<span style="font-family:KaiTi_GB2312;font-size:18px;">//添加组件
this.add(jb1);
this.add(jb2);
this.add(jb3);
this.add(jb4);
this.add(jb5);
this.add(jb6);
//设置布局管理器
this.setLayout(new FlowLayout(FlowLayout.LEFT));//这里定位也有多个方案,如下图 </span>
效果:(我选的是左对齐)先填满第一排,然后再左对齐
3.GridLayout(网格布局)
矩形网格形式对容器的组件进行布置
构造函数:
GridLayout()
建立一个默认为一行一列的GridLayout
GridLayout(int rows,int cols)
建立一个指定行(rows)和列(cols)的GridLayout
GridLayout(int rows,int cols,int hgap,int vgap)
建立一个指定行(rows)和列(cols),且组件间水平间距为hgap、垂直间距为vgap的GridLayout
矩形网格形式对容器的组件进行布置
构造函数:
GridLayout()
建立一个默认为一行一列的GridLayout
GridLayout(int rows,int cols)
建立一个指定行(rows)和列(cols)的GridLayout
GridLayout(int rows,int cols,int hgap,int vgap)
建立一个指定行(rows)和列(cols),且组件间水平间距为hgap、垂直间距为vgap的GridLayout
案例:
<span style="font-family:KaiTi_GB2312;font-size:18px;">/*
* 功能:网格布局演示
*
*/
package com.test1;
import java.awt.*;
import javax.swing.*;
public class Demo8_4 extends JFrame{
//定义一个按钮数组(9个)
int size=9;
JButton jbs[]=new JButton[size];
public static void main(String[] args) {
// TODO Auto-generated method stub
Demo8_4 demo8_4=new Demo8_4();
}
public Demo8_4()
{
//创建组件(按钮)
for(int i=0;i<size;i++)
{
jbs[i]=new JButton(String.valueOf(i));
}
//设置网格布局(3行3列)(int rows,int cols) 后面两个10是水平垂直距离
this.setLayout(new GridLayout(3,3,10,10));
//添加组件
for (int i=0;i<size;i++)
{
this.add(jbs[i]);
}
//设置窗体
this.setTitle("网格布局案例");
this.setSize(300,200);
this.setLocation(200,300);
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);//关闭窗体时关闭java虚拟机
this.setVisible(true);
}
}</span>
效果:
那我们就来做个计算器吧
<span style="font-family:KaiTi_GB2312;font-size:18px;">package com.test1;
import java.awt.*;
import javax.swing.*;
public class Demo8_5 extends JFrame{
//定义字符串数组,为按钮的显示文本赋值
//注意字符元素的顺序与循环添加按钮保持一致
String str[]={"7","8","9","/","4","5","6","*","1","2","3","-","0",".","=","+"};
JButton btn[]=new JButton[str.length]; //声明按钮组件
//定义面板,并设置为网格布局,4行4列,组件水平、垂直间距均为3
JPanel p=new JPanel(new GridLayout(4,4,3,3)); //面板组件Jpanel
JTextArea t=new JTextArea(); //定义文本框
public static void main(String[] args){
Demo8_5 demo8_5 =new Demo8_5();
}
public Demo8_5(){
//创建组件
for(int i=0;i<str.length;i++){
btn[i]=new JButton(str[i]);
p.add(btn[i]);
}
setLayout(new BorderLayout()); //定义窗体布局为边界布局
getContentPane().add(t,BorderLayout.NORTH); //将文本框放置在窗体NORTH位置
getContentPane().add(p,BorderLayout.CENTER); //将面板放置在窗体CENTER位置
//设置窗体属性
this.setTitle("计算器布局案例");
this.setSize(250,200);
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
this.setLocationRelativeTo(null); //让窗体居中显示
this.setVisible(true);
}
}
</span>
效果: