2021-03-11

Layout

在这里先不引入布局管理器的概念,我们从两个实例中发现它的作用和概念

public class Paneldome {
	public static void main(String[] args) {
		JFrame frame=new JFrame("哈");              //先建立一个Window
		JPanel a=new JPanel();                     //建立一个Panel
		a.add(new TextField("你好"));               //利用add方法在面板中加入一个文本框
		a.add(new Button("测试按钮"));               //在面板中加入一个按钮
		frame.add(a);                              //将Panel放Window中
		frame.setBounds(100, 100, 300, 500);       //设置window的位置和大小
		frame.setVisible(true);                    //设置可见
	}
}

运行结果如图:
在这里插入图片描述
我们发现,在这个窗口中有文本框,有按钮,两个组件的位置分布合理,我们再来看一个示例:

public class Scrolldome {
	public static void main(String[] args) {
		JFrame jframe=new JFrame("你好,世界");
		ScrollPane p=new ScrollPane(ScrollPane.SCROLLBARS_ALWAYS); //ScrollPane.SCROLLBARS_ALWAYS
	 	                                                           //让滚动条一直出现
		p.add(new TextField("这是测试文本"));
		p.add(new Button("这是测试按钮"));
		jframe.add(p);
		jframe.setBounds(100, 100, 350, 350);       //设置窗口的大小和位置
		jframe.setVisible(true);                    //设置窗口可见
	}
}

运行结果如图:
在这里插入图片描述
但是这次我们会发现,代码中让表示的测试文本不见了,只有按钮,这是由于组件位置和大小分布不合理所导致的,而Layout可以帮我们管理组件的位置以及组件的大小,这就是布局管理器,再来看下加入布局管理器的示例:

public class FlowLayoutdome {
	public static void main(String[] args) {
		JFrame frame=new JFrame("标题");
		//通过setLayout方法给frame设置布局管理器(FlowLayout)
		frame.setLayout(new FlowLayout(FlowLayout.LEFT,20,15));  //左对齐,水平间距20,垂直间距15
		for(int i=1;i<100;i++)
		frame.add(new Button("按钮"+i));
		frame.pack();                                            //通过pack方法来自动设置自动大小
		frame.setVisible(true);
	}
}

运行结果:
在这里插入图片描述
加入布局管理器后及时容器里面的组件再多,亦可以合理分布在容器中,我们可以随意设置组件的大小和位置,上面所示的布局管理器为FlowLayout(流式布局管理器)此外还有GridLayout网格布局、FlowLayout流式布局、CardLayout卡片布局、GridbagLayout网格包布局、BorderLayout边框布局等,他们的使用方法大同小异,所显示的结果也不尽相同。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值