很多情况下,我们已经不需要通过编写代码来实现一个应用程序的图形界面,而是通过强大的IDE工具通过拖拽辅以简单的事件处理代码即可很轻松的完成。但是我们不得不面对这样操作存在的一些问题,有时候我们希望能够自由改变一个程序界面的大小,通过托拽生成的界面往往是不提供这个功能的,因为定制的界面一旦改变形状,组件间的布局会变得杂乱无章。

Java中的布局管理器应用了策略者模式(Strategy),为不同类型的组件布局提供了很好的模型。而其中的网格组布局管理器(GridBagLayout)被认为是所有布局管理器中最强大的。下面将通过一个例子讲述它的使用方法。

1.实现一个WindowsXP下画图板的框架,下面是设计模型图

我们可以将GridBagLayout看作没有任何约束或限制的网格布局(GridLayout),一个组件可以占据若干行和列,而且大小设定也是自由的。从上图我们可以清晰的看到整个画图板界面被划分为4行2列的一个表格,我们先不用管某个单元格的大小,只管划分。

这样五个具体的面板(我们使用JPanel对象进行填充)就构成了整个界面,上侧占据1行2列的工具选择面板(toolSelectPanel),左侧1行1列的某个工具的选项面板(toolConcretePanel),右侧的drawPanel,下侧的colorPanel和statePanel

2.我们通过以下步骤为界面进行GridBagLayout布局

1).设置主界面的布局管理器为GridBagLayout(不用指定行和列)

2).为界面中的每一个组件(这里是JPanel对象)指定一个GridBagConstraints对象,通过设置该对象的属性值指出组件在

管理器中的布局方案

3).通过下面的调用添加组件极其约束条件(GridBagConstraints对象)

add(Component,constraints);

我们有必要了解一下GridBagConstraints中各个属性的具体含义以便我们更好的进行个性化的布局

@gridx,gridy:

组件左上角所在的位置,如上图中左侧的面板在1行0列,则gridy=0,gridx=1。读者请注意这里的行对应的是gridy,列对应的是gridx

@gridwidth,gridheight

组件占据的行数和列数,如最上面的那个面板占了1行2列,则gridwidth=2,gridheight=1

@weightx,weighty

可以简单理解为组件大小变化的增量值,如设置weightx=100,组件会随着单元格而变化,设置weightx=0时,组件大小不会发生变化。当然weightx,weighty也可以设置成其他的值,不过意义不大,就不再详细介绍。

@fill

组件在所处格子(分配区域)内的填充方式

如fill= HORIZONTAL,组件就只在水平方向上填充满单元格,取fill= BOTH则会填满整个格子。

@anchor

组件在所处格子内的对其方式,取anchor=EAST就是指右对齐

@ipadx,ipady

内部填充,是指在组件首选大小的基础上x方向上加上ipadx,y方向上加上ipady,这样做就可以保证组件不会收缩到ipadx,ipady所确定的大小以下,因此我们可以用ipadx,ipady的值来指定组件的大小,而不必指定组件的大小否则会有意想不到的效果

@insets

外部填充,填充的区域是组件与所处格子边框之间的部分,有left,top,right,bottom四个参数,不过当组件的fill=NONE时,指定insects值是无意义的

3.下面就是代码实现了,先看下效果图吧

这是运行生成的界面

这是拉伸之后的界面

关键代码如下

  1. private void addGridBagPanes() {
  2. //上侧的工具选择面板
  3. JPanel toolSelectPanel = new JPanel();
  4. toolSelectPanel.setBackground(Color.green);
  5. ,0,2,1).
  6. , 50).setWeight(100, 0));
  7. //左侧的具体工具面板
  8. JPanel toolConcretePanel = new JPanel();
  9. toolConcretePanel.setBackground(Color.YELLOW);
  10. ,1).
  11. , 90).setWeight(0, 100));
  12. //右侧的绘图面板
  13. JPanel drawPanel = new JPanel();
  14. drawPanel.setBackground(Color.WHITE);
  15. ,1).setFill(GBC.BOTH));
  16. //下侧的颜色选择面板
  17. JPanel colorPanel = new JPanel();
  18. colorPanel.setBackground(Color.LIGHT_GRAY);
  19. ,2,2,1).
  20. ,50).setWeight(100, 0));
  21. //下侧的状态面板
  22. JPanel statePanel = new JPanel();
  23. statePanel.setBackground(Color.CYAN);
  24. ,3,2,1).
  25. , 20).setWeight(100, 0));
  26. }

其中的GBC类继承于GridBagConstraints这样做的目的是简化每次对GridBagConstraints对象的直接操作带来的繁琐,而GBC的各个set方法返回的都是一个GBC对象因此可以接连调用set方法。GBC类的代码如下:

  1. public class GBC extends GridBagConstraints
  2. {
  3. //初始化左上角位置
  4. public GBC(int gridx, int gridy)
  5. {
  6. this.gridx = gridx;
  7. this.gridy = gridy;
  8. }
  9. //初始化左上角位置和所占行数和列数
  10. public GBC(int gridx, int gridy, int gridwidth, int gridheight)
  11. {
  12. this.gridx = gridx;
  13. this.gridy = gridy;
  14. this.gridwidth = gridwidth;
  15. this.gridheight = gridheight;
  16. }
  17. //对齐方式
  18. public GBC setAnchor(int anchor)
  19. {
  20. this.anchor = anchor;
  21. return this;
  22. }
  23. //是否拉伸及拉伸方向
  24. public GBC setFill(int fill)
  25. {
  26. this.fill = fill;
  27. return this;
  28. }
  29. //x和y方向上的增量
  30. public GBC setWeight(double weightx, double weighty)
  31. {
  32. this.weightx = weightx;
  33. this.weighty = weighty;
  34. return this;
  35. }
  36. //外部填充
  37. public GBC setInsets(int distance)
  38. {
  39. this.insets = new Insets(distance, distance, distance, distance);
  40. return this;
  41. }
  42. //外填充
  43. public GBC setInsets(int top, int left, int bottom, int right)
  44. {
  45. this.insets = new Insets(top, left, bottom, right);
  46. return this;
  47. }
  48. //内填充
  49. public GBC setIpad(int ipadx, int ipady)
  50. {
  51. this.ipadx = ipadx;
  52. this.ipady = ipady;
  53. return this;
  54. }
  55. }

JAVA中GridBagLayout布局管理器应用详解的更多相关文章

  1. GridBagLayout布局管理器应用详解

    http://www.cnblogs.com/kungfupanda/p/7220217.html GridBagLayout布局管理器应用详解 很多情况下,我们已经不需要通过编写代码来实现一个应用程 ...

  2. Python Tkinter模块 Grid(grid)布局管理器参数详解

    在使用Tkinter模块编写图像界面时,经常用到pack()和grid()进行布局管理,pack()参数较少,使用方便,是最简单的布局,但是当控件数量较多时,可能需要使用grid()进行布局(不要在同 ...

  3. 【java】浅析java组件中的布局管理器

    这篇博文笔者介绍一下java组件中,常用的布局管理器.java组件中的布局方式有好几十种,所有的这些布局管理器都实现了java.awt.LayoutManager接口.接下来笔者介绍一下常用的5种布局 ...

  4. JAVA流式布局管理器--JAVA基础

    JAVA流式布局管理器的使用: FlowLayoutDeme.java: import java.awt.*;import javax.swing.*;public class FlowLayoutD ...

  5. Java中堆内存和栈内存详解2

    Java中堆内存和栈内存详解   Java把内存分成两种,一种叫做栈内存,一种叫做堆内存 在函数中定义的一些基本类型的变量和对象的引用变量都是在函数的栈内存中分配.当在一段代码块中定义一个变量时,ja ...

  6. 系统批量运维管理器Fabric详解

    系统批量运维管理器Fabric详解 Fabrici 是基于python现实的SSH命令行工具,简化了SSH的应用程序部署及系统管理任务,它提供了系统基础的操作组件,可以实现本地或远程shell命令,包 ...

  7. Java中的equals和hashCode方法详解

    Java中的equals和hashCode方法详解  转自 https://www.cnblogs.com/crazylqy/category/655181.html 参考:http://blog.c ...

  8. java中List的用法和实例详解

    java中List的用法和实例详解 List的用法List包括List接口以及List接口的所有实现类.因为List接口实现了Collection接口,所以List接口拥有Collection接口提供 ...

  9. 转:Java中的equals和hashCode方法详解

    转自:Java中的equals和hashCode方法详解 Java中的equals方法和hashCode方法是Object中的,所以每个对象都是有这两个方法的,有时候我们需要实现特定需求,可能要重写这 ...

随机推荐

  1. CASE WHEN用法

    问题:假如说这个条件有一条数据不满足,那么那条数据就不会读出来,,那么,我怎么才能把它读出并且赋值为空呢 方法: SELECT `s`.*, ( CASE THEN SUM(a.total_numbe ...

  2. 游戏中实现粒子碰撞,纯java

    package com.totoo.TouhouMassLight;import android.content.Context;import android.graphics.Bitmap;impo ...

  3. tp5 日志文件名称问题

    原文:http://www.upwqy.com/details/17.html 我的项目在运行一段时间后 我发现在日志中生成了 1508467147-20.log 这种文件名的日志 开始还以为是bug ...

  4. IDEA的配置

    一.使用配置 转自:http://blog.csdn.net/qq_27093465/article/details/52918873 setting: 设置外观和字体: 设置编辑器快捷键:   自动 ...

  5. NancyFX 第十二章 通道截拦

    所有的好的Web框架都有一套好的通道截拦的机制,Nancy在我看来是处理最好的.那什么是请求通道那?下面的图可能说的比较清楚些: 正如名称中描述的,一个典型的Web请求在到达最终响应前会穿过一定数量的 ...

  6. Redis进阶实践之十八 使用管道模式加速Redis查询

    一.引言             学习redis 也有一段时间了,该接触的也差不多了.后来有一天,以为同事问我,如何向redis中批量的增加数据,肯定是大批量的,为了这主题,我从新找起了解决方案.目前 ...

  7. 11.python线程

    基本概念 1.进程       定义: 进程就是一个程序在一个数据集上的一次动态执行过程. 组成:  进程一般由程序.数据集.进程控制块三部分组成. 程序:  我们编写的程序用来描述进程要完成哪些功能 ...

  8. js改变盒子大小(上下左右)分析

    js改变盒子大小 知识点 三个mouse事件:mousedown mousemove mouseup css的定位和cursor 思路 先解决单边问题识别范围,得到所选区域 event. 根据距离,判 ...

  9. char码值对应列表大全

    Char("0") 为0的字符Char("1") Char("2") Char("3") Char("4&qu ...

  10. 如何在eclipse中添加ADT

    工具: Eclipse:官网下载地址:http://www.eclipse.org/downloads/下载SE或者EE版本的都可以 ADT:因为涉及到FQ问题,所以这里我给出一个参考网址:http: ...