- 浏览: 2055520 次
- 性别:
- 来自: 北京
-
文章分类
- 全部博客 (795)
- java (263)
- 聚类搜索引擎 (9)
- 经验之谈 (67)
- DSP (3)
- C++ (140)
- Linux (37)
- SNMP (6)
- Python (6)
- 数据库 (61)
- 网络 (20)
- 算法 (15)
- 设计模式 (4)
- 笔试题 (38)
- 散文 (35)
- 数据结构 (9)
- 银行知识 (0)
- 榜样 (9)
- Lucene (15)
- Heritrix (6)
- MetaSeeker (0)
- netbeans (12)
- php (3)
- 英语 (8)
- DB2 (0)
- java基础 (5)
- mongodb & hadoop (4)
- Javascript (7)
- Spring (4)
- ibatis & myibatis (1)
- velocity (1)
- 微服务 (0)
- paddle (1)
- 第三方 (0)
- 知识沉淀 (1)
- 建模 (0)
最新评论
-
0372:
标示对java很陌生!
中文乱码解决的4种方式 -
梦留心痕:
Java中\是转意字符, 可是你的这句话我没看懂,只要把得到的 ...
java中如何忽略字符串中的转义字符--转载 -
yanjianpengit:
[b][/b]
java为什么非静态内部类里面不能有静态成员 -
springdata-jpa:
可以参考最新的文档:如何在eclipse jee中检出项目并转 ...
eclipse 如何把java项目转成web项目 -
qq1130127172:
,非常好。
(转)SpringMVC 基于注解的Controller @RequestMapping @RequestParam..
控件变大了,框架也要变大。
1. FlowLayout: 拖动框架,组件大小不变。
2. BoxLayout:拖框架,组件大小不变。可以将组件由上至下或由左至右依次加入当前面板。
3. 绝对布局:拖框架,组件大小不变。用到setBounds()方法定位。
3. BorderLayout:拖动框架,组件大小变化。主要是中间控件变化。中间控件要设大小。
4. CardLayout:拖动框架,组件大小变化。
5. GridLayout:拖动框架,组件大小变化。
6. GridBagLayout:拖动框架,组件大小变化,也可让组件大小不变,即fill值。
(1) 同GridLayout一样,在容器中以网格形式来管理组件。
(2) 管理的所有行和列都可以是大小不同的。
(3) 组件在容器中可以占据任意大小的矩形区域。
(4) 通常由一个专用类来对他布局行为进行约束,该类叫GridBagConstraints。
GridBagConstraints有11个公有成员变量,它可以从这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)
6、ipadx,ipady,它们就是组件大小的设置。
7、有一些属性能影响到整个单元格,影响到其它组件,比如:ipadx,ipady,insets
package TestLayout;
import java.awt.Dimension;
import java.awt.GridBagConstraints;
import java.awt.GridBagLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import javax.swing.BorderFactory;
import javax.swing.DefaultListModel;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JList;
import javax.swing.JPanel;
import javax.swing.JTextField;
public class GridBagLayoutFrame extends JFrame {
private static final long serialVersionUID = 6819222900970457455L;
private JPanel mainPanel = new JPanel();
private JButton addButton = new JButton();
private JButton leftButton = new JButton();
private JButton rightButton = new JButton();
private JLabel label = new JLabel();
private JTextField field = new JTextField();
private DefaultListModel leftModel = new DefaultListModel();
private DefaultListModel rightMOdel = new DefaultListModel();
private JList leftList = new JList(leftModel);
private JList rightList = new JList(rightMOdel);
public GridBagLayoutFrame(String title) {
setTitle("GridBagLayoutFrameDemo");
setPreferredSize(new Dimension(600, 400));
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
initComponent();
addData();
pack();
setVisible(true);
}
private static void createAndShowGUI() {
new GridBagLayoutFrame("GridBagLayoutFrameDemo");
}
private void initComponent() {
label.setText("添加选项:");
addButton.setText("添加");
leftList.setPreferredSize(new Dimension(150, 150));
rightList.setPreferredSize(leftList.getPreferredSize());
leftButton.setText("向右添");
rightButton.setText("向左添");
mainPanel.setBorder(BorderFactory.createTitledBorder("左右选择框"));
mainPanel.setLayout(new GridBagLayout());
GridBagConstraints c = new GridBagConstraints();
c.gridx = 0; // 0行0列
c.gridy = 0;
c.gridwidth = 1;
c.gridheight = 1;
c.fill = GridBagConstraints.HORIZONTAL;
c.weightx = 0;
c.weighty = 0;
mainPanel.add(label, c);
c.gridx++;
c.weightx = 1;
mainPanel.add(field, c);
c.gridx++;
c.weightx = 0;
c.gridwidth = 1;
c.gridheight = 1;
// c.fill = GridBagConstraints.HORIZONTAL;
mainPanel.add(addButton, c);
c.gridx = 0;
c.gridy = 1;
c.weightx = 1;
c.weighty = 1;
c.gridwidth = 2;
c.gridheight = 2;
c.fill = GridBagConstraints.BOTH;
mainPanel.add(leftList, c);
c.gridx = 2;
c.gridy = 1;
c.gridwidth = 1;
c.gridheight = 1;
c.weightx = 0;
c.weighty = 0.5;
c.anchor = GridBagConstraints.SOUTH;
c.fill = GridBagConstraints.HORIZONTAL;
mainPanel.add(leftButton, c);
c.gridx = 2;
c.gridy = 2;
c.anchor = GridBagConstraints.NORTH;
c.fill = GridBagConstraints.HORIZONTAL;
mainPanel.add(rightButton, c);
c.gridx = 3;
c.gridy = 1;
c.gridwidth = 1;
c.gridheight = 2;
c.weightx = 1;
c.weighty = 1;
c.fill = GridBagConstraints.BOTH;
mainPanel.add(rightList, c);
this.getContentPane().add(mainPanel);
}
private void addData() {
addButton.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
addItem();
}
});
leftButton.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
leftItem();
}
});
rightButton.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
rightItem();
}
});
}
private void addItem() {
if (field.getText() != null && !field.getText().equals("")) {
((DefaultListModel) leftList.getModel())
.addElement(field.getText());
field.setText("");
}
}
private void leftItem() {
if (leftList.getSelectedIndex() != -1) {
Object o = leftList.getSelectedValue();
((DefaultListModel) leftList.getModel()).remove(leftList
.getSelectedIndex());
((DefaultListModel) rightList.getModel()).addElement(o);
}
}
private void rightItem() {
if (rightList.getSelectedIndex() != -1) {
Object o = rightList.getSelectedValue();
((DefaultListModel) rightList.getModel()).remove(rightList
.getSelectedIndex());
((DefaultListModel) leftList.getModel()).addElement(o);
}
}
public static void main(String[] args) {
javax.swing.SwingUtilities.invokeLater(new Runnable() {
public void run() {
createAndShowGUI();
}
});
}
}
1. FlowLayout: 拖动框架,组件大小不变。
2. BoxLayout:拖框架,组件大小不变。可以将组件由上至下或由左至右依次加入当前面板。
3. 绝对布局:拖框架,组件大小不变。用到setBounds()方法定位。
3. BorderLayout:拖动框架,组件大小变化。主要是中间控件变化。中间控件要设大小。
4. CardLayout:拖动框架,组件大小变化。
5. GridLayout:拖动框架,组件大小变化。
6. GridBagLayout:拖动框架,组件大小变化,也可让组件大小不变,即fill值。
(1) 同GridLayout一样,在容器中以网格形式来管理组件。
(2) 管理的所有行和列都可以是大小不同的。
(3) 组件在容器中可以占据任意大小的矩形区域。
(4) 通常由一个专用类来对他布局行为进行约束,该类叫GridBagConstraints。
GridBagConstraints有11个公有成员变量,它可以从这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)
6、ipadx,ipady,它们就是组件大小的设置。
7、有一些属性能影响到整个单元格,影响到其它组件,比如:ipadx,ipady,insets
package TestLayout;
import java.awt.Dimension;
import java.awt.GridBagConstraints;
import java.awt.GridBagLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import javax.swing.BorderFactory;
import javax.swing.DefaultListModel;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JList;
import javax.swing.JPanel;
import javax.swing.JTextField;
public class GridBagLayoutFrame extends JFrame {
private static final long serialVersionUID = 6819222900970457455L;
private JPanel mainPanel = new JPanel();
private JButton addButton = new JButton();
private JButton leftButton = new JButton();
private JButton rightButton = new JButton();
private JLabel label = new JLabel();
private JTextField field = new JTextField();
private DefaultListModel leftModel = new DefaultListModel();
private DefaultListModel rightMOdel = new DefaultListModel();
private JList leftList = new JList(leftModel);
private JList rightList = new JList(rightMOdel);
public GridBagLayoutFrame(String title) {
setTitle("GridBagLayoutFrameDemo");
setPreferredSize(new Dimension(600, 400));
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
initComponent();
addData();
pack();
setVisible(true);
}
private static void createAndShowGUI() {
new GridBagLayoutFrame("GridBagLayoutFrameDemo");
}
private void initComponent() {
label.setText("添加选项:");
addButton.setText("添加");
leftList.setPreferredSize(new Dimension(150, 150));
rightList.setPreferredSize(leftList.getPreferredSize());
leftButton.setText("向右添");
rightButton.setText("向左添");
mainPanel.setBorder(BorderFactory.createTitledBorder("左右选择框"));
mainPanel.setLayout(new GridBagLayout());
GridBagConstraints c = new GridBagConstraints();
c.gridx = 0; // 0行0列
c.gridy = 0;
c.gridwidth = 1;
c.gridheight = 1;
c.fill = GridBagConstraints.HORIZONTAL;
c.weightx = 0;
c.weighty = 0;
mainPanel.add(label, c);
c.gridx++;
c.weightx = 1;
mainPanel.add(field, c);
c.gridx++;
c.weightx = 0;
c.gridwidth = 1;
c.gridheight = 1;
// c.fill = GridBagConstraints.HORIZONTAL;
mainPanel.add(addButton, c);
c.gridx = 0;
c.gridy = 1;
c.weightx = 1;
c.weighty = 1;
c.gridwidth = 2;
c.gridheight = 2;
c.fill = GridBagConstraints.BOTH;
mainPanel.add(leftList, c);
c.gridx = 2;
c.gridy = 1;
c.gridwidth = 1;
c.gridheight = 1;
c.weightx = 0;
c.weighty = 0.5;
c.anchor = GridBagConstraints.SOUTH;
c.fill = GridBagConstraints.HORIZONTAL;
mainPanel.add(leftButton, c);
c.gridx = 2;
c.gridy = 2;
c.anchor = GridBagConstraints.NORTH;
c.fill = GridBagConstraints.HORIZONTAL;
mainPanel.add(rightButton, c);
c.gridx = 3;
c.gridy = 1;
c.gridwidth = 1;
c.gridheight = 2;
c.weightx = 1;
c.weighty = 1;
c.fill = GridBagConstraints.BOTH;
mainPanel.add(rightList, c);
this.getContentPane().add(mainPanel);
}
private void addData() {
addButton.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
addItem();
}
});
leftButton.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
leftItem();
}
});
rightButton.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
rightItem();
}
});
}
private void addItem() {
if (field.getText() != null && !field.getText().equals("")) {
((DefaultListModel) leftList.getModel())
.addElement(field.getText());
field.setText("");
}
}
private void leftItem() {
if (leftList.getSelectedIndex() != -1) {
Object o = leftList.getSelectedValue();
((DefaultListModel) leftList.getModel()).remove(leftList
.getSelectedIndex());
((DefaultListModel) rightList.getModel()).addElement(o);
}
}
private void rightItem() {
if (rightList.getSelectedIndex() != -1) {
Object o = rightList.getSelectedValue();
((DefaultListModel) rightList.getModel()).remove(rightList
.getSelectedIndex());
((DefaultListModel) leftList.getModel()).addElement(o);
}
}
public static void main(String[] args) {
javax.swing.SwingUtilities.invokeLater(new Runnable() {
public void run() {
createAndShowGUI();
}
});
}
}
发表评论
-
流式计算
2022-02-07 14:31 298private void postHandle(List& ... -
消息队列使用的四种场景介绍
2018-08-09 16:34 2493以下介绍消息队列在实际应用中常用的使用场 ... -
设计模式
2018-04-11 16:49 9961.桥梁模式,将抽象部分与实现部分隔离开,抽象部分持有实现 ... -
Spring boot web可以访问Service和Mapper层
2018-03-26 16:42 2898Spring boot的web层可以访问Service层,然 ... -
FreeMarker的基础语法使用 && 心得和技巧
2018-01-10 10:03 2095FreeMarker是一个模板引 ... -
webService----wss4j+cxf实现WS-Security(基于UsernameToken)
2017-10-23 18:58 1577分享一下wss4j+cxf基于UsernameToken的安 ... -
Spring MVC之LocaleResolver(解析用户区域)
2017-09-23 15:55 2557为了让web应用程序支持国际化,必须识别每个用户的首选区域, ... -
(转)java泛型
2016-11-12 20:29 1659http://www.cnblogs.com/lwbqqyu ... -
java中如何忽略字符串中的转义字符--转载
2016-06-28 16:42 9940原文地址:http://my ... -
(转)关于JAP FetchType.LAZY(hibernate实现)的理解 .
2016-04-27 15:22 5117JPA定义实体之间的关系有如下几种: @OneToOne ... -
(转)hibernate annotation注解方式来处理映射关系
2016-04-26 16:52 1847http://www.cnblogs.com/xiao ... -
代码片段,导出的文件头
2015-11-18 20:34 1620public static void setDownload ... -
(转)为什么要两次调用encodeURI来解决乱码问题
2015-08-03 20:19 2503地址:http://blog.csdn.net/howla ... -
杀死进程
2015-07-21 14:54 1300sudo lsof -i :9000 COMMAND P ... -
批处理batch,执行多个SQL语句
2015-07-15 19:21 10631批处理batch,执行多个SQL语句。 ... -
中文乱码解决的4种方式
2015-07-03 14:20 2640目前收集到4中方法,中文传参一documentPath为例: ... -
GET请求的中文乱码问题及处理意义
2015-07-03 13:47 6645首先看一段乱码的程序 ... -
java.ByteArrayInputStream与ByteArrayOutputStream再次理解
2015-03-16 17:59 3252第一次看到ByteArrayOutputStream的时 ... -
(转)SpringMVC 基于注解的Controller @RequestMapping @RequestParam..
2014-07-28 17:42 2395概述 继 Spring 2.0 对 Spring MVC ... -
java中序列化的serialVersionUID解释
2014-07-25 09:26 1905serialVersionUID: 字面意思上是序列化的版本号 ...
相关推荐
### Swing常见布局管理器总结 #### 1. BorderLayout - 边界布局管理器 边界布局管理器(`BorderLayout`)是一种非常常见的布局管理器,主要用于处理容器内组件的定位,将其分布在容器的五个基本区域:北(North)...
总结来说,Java的边界布局管理器是构建GUI时非常实用的工具,它提供了简单而灵活的方式来组织和调整组件的位置。通过理解其特点和方法,开发者可以创建出适应不同需求的用户界面。在实际开发中,可以结合使用其他...
总结起来,MFC窗口布局管理器是一个关键组件,用于组织和调整窗口内控件的布局。`ETSLayout.cpp`和`ETSLayout.h`文件提供了一个自定义布局管理器的实现,通过这个自定义的布局管理器,开发者可以更精确地控制窗口的...
Android Studio 之布局管理器之间的互相嵌套 Android Studio 中的布局管理器是指用于安排 UI 组件的容器,它们可以单独使用,也可以互相嵌套以满足复杂的布局需求。在本文中,我们将探讨 Android Studio 中布局...
Java提供了多种内置的布局管理器,如FlowLayout、BorderLayout、GridLayout、CardLayout和GridBagLayout,每种都有其特定的布局策略。开发者可以根据需求选择合适的布局管理器,以实现美观且功能完善的用户界面。 *...
总结来说,"Android蜂巢布局管理器"是一个用于创建六边形网格布局的自定义布局管理器,它增强了UI的视觉效果,并提供了动态操作元素的动画。通过研究其源码和使用指南,开发者可以学习到如何自定义布局管理器以满足...
总结起来,Qt布局管理是构建用户界面的重要工具,它简化了界面设计的复杂性,提供了灵活性和响应性。理解并熟练掌握各种布局类型以及它们的配置选项,对于开发高质量的Qt应用程序至关重要。通过实践和实验,开发者...
在Android开发中,表格布局管理器(TableLayout)是一种常用且强大的组件,它允许开发者创建类似于HTML中的表格的布局。TableLayout是LinearLayout的扩展,它通过行和列的方式来组织子视图(Views)。本篇学习笔记将...
Java Swing 是 Java ...总结来说,Java Swing 的布局管理是一个强大的工具,帮助开发者构建有组织、适应性强的用户界面。理解并熟练运用各种布局管理器,以及它们的组合与定制,是提升Java Swing应用用户体验的关键。
总结来说,Java GUI布局管理是提升用户体验的重要手段,通过理解并灵活运用布局管理器,开发者可以创建出既美观又易于使用的应用程序界面。无论是使用内置的布局管理器,还是选择空布局或自定义布局,都需根据具体...
总结来说,Android的布局管理器是构建用户界面的基础工具,开发者可以根据需求选择合适的布局类型。RelativeLayout提供了灵活的相对定位,MusicLayoutDemo可能涉及到自定义布局和资源管理,而TableLayout则适合于...
总结来说,Qt Creator的布局管理器提供了强大的工具,使得开发者能够轻松创建适应性强、用户体验良好的界面。通过理解并熟练运用垂直布局管理器、QSplitter部件以及图标资源,开发者可以设计出符合用户需求且具有...
应用帧布局管理器居中显示层叠的正方形 在 Android 开发中,FrameLayout 是一个常用的布局管理器,用于管理屏幕上的控件布局。今天,我们将学习如何使用 FrameLayout 实现居中的显示层叠的正方形实验。 知识点一:...
在Android开发中,布局...总结,Android布局管理是构建高效、美观用户界面的基础。理解并熟练掌握各种布局及其属性,以及优化技巧,对于提升应用质量至关重要。在实践中不断探索和优化,才能打造出优秀的Android应用。
LinearLayout 线性布局 控制组件 横向 或者 纵向 排列 RelativeLayout 相对布局 子组件的位置总是相对兄弟...AbsoluteLayout 绝对布局 组件位置通过x, y坐标来控制, 布局容器不再管理组件位置, 大小, 这些都可以自定义;
总结起来,`CardLayout`布局管理器提供了一种优雅的方式,让用户可以在有限的空间内切换多个组件,非常适合创建选项面板或动态视图。通过监听按钮事件并调用`show`方法,我们可以轻松地实现在按钮被点击时显示下一张...
【Java边界布局管理器详解】...总结,这个练习涵盖了Java GUI编程中的基础元素,包括布局管理、组件创建、事件处理和窗口管理。通过这个练习,开发者可以更好地理解和掌握如何在Java中构建具有特定布局的图形用户界面。
【JAVA布局管理详解】 ...总结,Java的布局管理器为开发人员提供了强大的工具,可以根据需求选择合适的布局,创建出各种复杂的用户界面。理解并熟练掌握这些布局管理器是构建专业GUI应用程序的基础。
在Android开发中,布局管理器是构建用户界面的关键部分,它们负责组织和定位视图(View)或视图组(ViewGroup)。本篇我们将深入探讨`FrameLayout`,这是一个非常基础但灵活的布局管理器,它允许你在屏幕上精确地...