摘自http://blog.csdn.net/zcsearching/article/details/50808446

BorderLayout控件大小的设置

使用BorderLayout时,中间的面板会随着窗体的变化而变化,其他区域的大小根据添加组件多少而变化。举个例子,现在想将一个面板固定到上边,高度为固定值,这是我们需要设置面板的高度。但是调用面板的 setSize()方法根本没有效果。调用 setMaximumSize()setMinimumSize()都没有用。

最后才发现应该调用的是 setPreferredSize()才能达到效果。

请看栗子。

 

 package com.wst.bj;

 import java.awt.BorderLayout;
import java.awt.Dimension;
import java.awt.Toolkit; import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JTextArea;
import javax.swing.JTextField; public class LayoutDemo { public static void main(String[] args) {
new myFrame();
}
} /**
* @author liuyan
*
*/
class myFrame { JFrame jframe = new JFrame("搜索");
JTextField textField = new JTextField(20);
JButton jButton = new JButton("转到");
JButton jButton2 = new JButton("转到2");
JButton jButton3 = new JButton("转到3");
JButton jButton4 = new JButton("转到4");
JTextArea textArea = new JTextArea();
JPanel jPanel = new JPanel(new BorderLayout(5,20));
JPanel jPanel2 = new JPanel(new BorderLayout());
JPanel jPanel3 = new JPanel(new BorderLayout());
JPanel jPanel4 = new JPanel(new BorderLayout()); /**
*
*/
public myFrame() { init();
} /**
*
*/
private void init()
{
jframe.setLayout(new BorderLayout());
jframe.add(jPanel2, BorderLayout.SOUTH);
jframe.add(jPanel3, BorderLayout.EAST);
jframe.add(jPanel4, BorderLayout.WEST);
jframe.add(jPanel, BorderLayout.NORTH); jPanel.add(jButton, BorderLayout.EAST);
jPanel.add(textField, BorderLayout.CENTER); jPanel2.add(jButton2);
jPanel3.add(jButton3);
jPanel4.add(jButton4); jPanel.setPreferredSize(new Dimension(0, 150));
jPanel2.setPreferredSize(new Dimension(0, 150));
jPanel3.setPreferredSize(new Dimension(150, 0));
jPanel4.setPreferredSize(new Dimension(150, 0)); jframe.add(textArea, BorderLayout.CENTER); jframe.setVisible(true);
FrameUtil.initFram(jframe, 500, 700);
}
} class FrameUtil
{
public static void initFram(JFrame f, int width, int height)
{
Toolkit toolkit = Toolkit.getDefaultToolkit();
f.setVisible(true);
f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
Dimension d = toolkit.getScreenSize();
int x = (int)d.getWidth();
int y = (int)d.getHeight();
f.setBounds((x-width)/2, (y - height )/2, width, height);
}
}

 package com.wst.bj;

 import java.awt.BorderLayout;
import java.awt.Dimension;
import java.awt.Toolkit; import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JTextArea;
import javax.swing.JTextField; public class LayoutDemo { public static void main(String[] args) {
new myFrame();
}
} /**
* @author liuyan
*
*/
class myFrame { JFrame jframe = new JFrame("搜索");
JTextField textField = new JTextField(20);
JButton jButton = new JButton("转到");
JButton jButton2 = new JButton("转到2");
JButton jButton3 = new JButton("转到3");
JButton jButton4 = new JButton("转到4");
JTextArea textArea = new JTextArea();
JPanel jPanel = new JPanel(new BorderLayout(5,20));
JPanel jPanel2 = new JPanel(new BorderLayout());
JPanel jPanel3 = new JPanel(new BorderLayout());
JPanel jPanel4 = new JPanel(new BorderLayout()); /**
*
*/
public myFrame() { init();
} /**
*
*/
private void init()
{
jframe.setLayout(new BorderLayout());
jframe.add(jPanel2, BorderLayout.SOUTH);
jframe.add(jPanel3, BorderLayout.EAST);
jframe.add(jPanel4, BorderLayout.WEST);
jframe.add(jPanel, BorderLayout.NORTH); jPanel.add(jButton, BorderLayout.EAST);
jPanel.add(textField, BorderLayout.CENTER); jPanel2.add(jButton2);
jPanel3.add(jButton3);
jPanel4.add(jButton4); // jPanel.setPreferredSize(new Dimension(0, 150));
// jPanel2.setPreferredSize(new Dimension(0, 150));
// jPanel3.setPreferredSize(new Dimension(150, 0));
// jPanel4.setPreferredSize(new Dimension(150, 0)); jframe.add(textArea, BorderLayout.CENTER); jframe.setVisible(true);
FrameUtil.initFram(jframe, 500, 700);
}
} class FrameUtil
{
public static void initFram(JFrame f, int width, int height)
{
Toolkit toolkit = Toolkit.getDefaultToolkit();
f.setVisible(true);
f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
Dimension d = toolkit.getScreenSize();
int x = (int)d.getWidth();
int y = (int)d.getHeight();
f.setBounds((x-width)/2, (y - height )/2, width, height);
}
}

BorderLayout布局,修改各个区域大小办法的更多相关文章

  1. java在线聊天项目0.2版本 制作客户端窗体,使用swing(用户界面开发工具包)和awt(抽象窗口工具包) BorderLayout布局与GridLayout布局不同之处 JPanel设置大小

    代码如下: package com.swift; import java.awt.BorderLayout; import java.awt.Color; import javax.swing.JBu ...

  2. 安卓布局修改基础常识篇之TextView属性

    [天使]安卓布局修改基础常识篇之TextView属性 在修改布局xml文件时需要熟练掌握一些属性,以下是TextView也就是文本的属性:android:autoLink 是否自动链接网址或邮箱地址: ...

  3. Javascript进阶篇——(DOM—节点---获取浏览器窗口可视区域大小+获取网页尺寸)—笔记整理

    浏览器窗口可视区域大小获得浏览器窗口的尺寸(浏览器的视口,不包括工具栏和滚动条)的方法:一.对于IE9+.Chrome.Firefox.Opera 以及 Safari: • window.innerH ...

  4. VS2015编译FFMPEG,修改FFmpeg缓冲区大小解决实时流解码丢包问题,FFmpeg错误rtsp流地址卡死的问题,设置超时

    之前尝试过很多网上利用Windows编译FFmpeg的文章,都没有办法编译X64位的FFmpeg,有些教程中有专门提到编译64位的FFmpeg需要下载mingw-w64-install,但是编译的过程 ...

  5. css中height 100vh的应用场景,动态高度百分比布局,浏览器视区大小单位

    css中height 100vh的应用场景,动态高度百分比布局,浏览器视区大小单位 height:100vh 一些只能vw, vh才能完成的应用场景: 1. 场景之:元素的尺寸限制 vw vh 主要是 ...

  6. 修改tomcat JVM 大小

    参考:https://blog.csdn.net/mynamepg/article/details/80591348 1.Xms表示初始分配给jvm的内存大小,-Xmx表示最大可分配给jvm的内存大小 ...

  7. Wpf修改控制的大小

    Wpf修改控制的大小 随窗体的改变而改变 在WINFORM中设置控件的Anchor属性就行了 在WPF中没有Anchor属性 但可以在布局中设置 相关属性实现同样的效果 相关属性 Horizontal ...

  8. JavaScript--DOM浏览器窗口可视区域大小

    浏览器窗口可视区域大小 获得浏览器窗口的尺寸(浏览器的视口,不包括工具栏和滚动条)的方法: 一.对于IE9+.Chrome.Firefox.Opera 以及 Safari: •  window.inn ...

  9. 【博客美化】08.添加"扩大/缩小浏览区域大小" 按钮

    博客园美化相关文章目录: [博客美化]01.推荐和反对炫酷样式 [博客美化]02.公告栏显示个性化时间 [博客美化]03.分享按钮 [博客美化]04.自定义地址栏logo [博客美化]05.添加Git ...

随机推荐

  1. 【转】基于DM8168的视频智能分析系统的设计方案

        [导读] 为了实现高清视频的智能分析功能,本文介绍了一种以TI公司的DM8168为核心的高清视频智能分析系统的设计方案,该方案从硬件设计和软件设计两个方面介绍了硬件组成.工作流程.软件架构,并 ...

  2. Spring Tool Suit 在Eclipse上的安装

    登录http://spring.io/tools/sts/all 下载所需的Spring Tool Suit安装包 我用的是springsource-tool-suite-3.6.1.RELEASE- ...

  3. XTU OJ 1209 Alice and Bob 2014(嘉杰信息杯ACM/ICPC湖南程序设计邀请赛暨第六届湘潭市程序设计竞赛)

    Problem Description The famous "Alice and Bob" are playing a game again. So now comes the ...

  4. iOS面试题集

    现在寒假时间在家里面无法敲代码了,但是自己总要找些事情来做,回头想想马上就要开始就业了,所以不免要参加面试,于是便开始了面试题集的浏览和探索,今天下午我看了一部分的面试题感觉还是挺实用的,所以以后还是 ...

  5. css_day5

  6. git学习笔记(五)

    ---恢复内容开始--- 嗯 今天又看到一个非常不错的入门git教程 Mark一下 阮一峰Git操作详解 主要讲解了五个常用的git命令 git clone git remote git fetch ...

  7. 《JavaScript 闯关记》之 DOM(上)

    DOM(文档对象模型)是针对 HTML 和 XML 文档的一个 API.DOM 描绘了一个层次化的节点树,允许开发人员添加.移除和修改页面的某一部分. 节点层次 DOM 可以将任何 HTML 或 XM ...

  8. css-盒模型

    <!DOCTYPE html>CSS3-盒模型 盒模型属性: width 宽度 height 高度 margin 外边距 border 边框 padding 内边距.test{width: ...

  9. Javascript进阶篇——浏览器对象—JavaScript计时器

    ---恢复内容开始--- JavaScript 计时器在JavaScript中,我们可以在设定的时间间隔之后来执行代码,而不是在函数被调用后立即执行.计时器类型:一次性计时器:仅在指定的延迟时间之后触 ...

  10. Asp.net Mvc 请求是如何到达 MvcHandler的——UrlRoutingModule、MvcRouteHandler分析,并造个轮子

    这个是转载自:http://www.cnblogs.com/keyindex/archive/2012/08/11/2634005.html(那个比较容易忘记,希望博主不要生气的) 前言 本文假定读者 ...