GridLayout
GridLayout是一个非常强大的布局管理器,它可以实现很多复杂的布局,名字中暗示它将所有控件放置在类似网格的布局中.^__^GridLayout有两个构造函数.
GridLayout的构造函数
构造函数 |
描述 |
public GridLayout() |
建立一个默认的GridLayout布局. |
public GridLayout(int numColumns, boolean makeColumnsEqualWidth) |
建立一个GridLayout布局,拥有numColumns列,如果makeColumnsEqualWidth为true,则全部组件将拥有相同的宽度. |
GridLayout有6个公共的数据成员,相对重要的是numColumns.
GridLayout数据成员
属性 |
描述 |
int horizontalSpacing |
控制一行中两个网格间组件的宽度,像素为单位. |
boolean makeColumnsEqualWidth |
如果为true,强制全部的列拥有相同的宽度. |
int marginHeight |
控制顶部和底部组件离边缘的距离空间,以像素为单位. |
int marginWidth |
控制左边和右边组件离边缘的距离空间,以像素为单位. |
int numColumns |
此GridLayout的列数目. |
int verticalSpacing |
控制一列中两个网络间组件的宽度,像素为单位. |
你能使用GridLayout设置GridData类来布局更多的复杂组件.GridData有两个构造函数.
GridData构造函数
构造函数 |
描述 |
public GridData() |
创建默认一个默认的GridData对象. |
public GridData(int style) |
初始化指定的style风格布局. |
和其它的布局类一样,GridLayout也提供一些公共的数据成员控制它的状态,它也提供一些常量,你可以在在构造成函数中使用.你可以用过位标志"|"来连接几个不同的效果,但请注意风格不要起冲突.
GridData数据成员
属性 |
描述 |
boolean grabExcessHorizontalSpace |
如果为true,指示布局器中网格自动填充多余的水平空间,默认为false.
|
boolean grabExcessVerticalSpace |
如果为true,指示布局器中网格自动填写多余的垂直空间,默认为false.
|
int heightHint |
该行中最小的高度,以像素为单位,默认为SWT.DEFAULT.
|
int horizontalAlignment |
网格中组件水平对齐方式,可能的值为BEGINNING, CENTER, END,和FILL.
|
int horizontalIndent |
与左边网格的水平缩进,默认为0 |
int horizontalSpan |
设置网格占有的列数目,默认为1 |
int verticalAlignment |
网格中组件垂直对齐方式,可能的值为BEGINNING, CENTER, END,和FILL.
|
int verticalSpan |
设置网格占有的行数目,默认为1 |
int widthHint |
该列中最小的宽度,以像素为单位,默认为SWT.DEFAULT.
|
GridData常量
常量 |
描述 |
BEGINNING |
非style值,指定水平或垂直的对齐方式. |
CENTER |
非style值,指定组件在网格中居中,水平或垂直. |
END |
非style值,指定水平或垂直的对齐方式. |
FILL |
非style值,指定组件填充网格,水平或垂直. |
FILL_BOTH |
设置horizontalAlignment和verticalAlignment为FILL,设置grabExcessHorizontalSpace和grabExcessVerticalSpace为true.
|
FILL_HORIZONTAL |
设置horizontalAlignment为FILL,和设置grabExcessHorizontalSpace为true.
|
FILL_VERTICAL |
设置verticalAlignment为FILL,和设置grabExcessVerticalSpace为true.
|
GRAB_HORIZONTAL |
设置grabExcessHorizontalSpace为true.
|
GRAB_VERTICAL |
设置grabExcessVerticalSpace为true.
|
HORIZONTAL_ALIGN_BEGINNING |
设置horizontalAlignment为BEGINNING.
|
HORIZONTAL_ALIGN_CENTER |
设置horizontalAlignment为CENTER.
|
HORIZONTAL_ALIGN_END |
设置horizontalAlignment为END.
|
HORIZONTAL_ALIGN_FILL |
设置horizontalAlignment为FILL.
|
VERTICAL_ALIGN_BEGINNING |
设置verticalAlignment为BEGINNING.
|
VERTICAL_ALIGN_CENTER |
设置verticalAlignment为CENTER.
|
VERTICAL_ALIGN_END |
设置verticalAlignment为END.
|
VERTICAL_ALIGN_FILL |
设置verticalAlignment为FILL.
|
下面我们来看几个例子: |
代码片段:
GridLayout gridLayout = new GridLayout();
gridLayout.numColumns = 2;
shell.setLayout(gridLayout);
new Button(shell, SWT.PUSH).setText("one");
new Button(shell, SWT.PUSH).setText("two");
new Button(shell, SWT.PUSH).setText("three");
new Button(shell, SWT.PUSH).setText("four");
运行效果:
|
图中可以看到各个Button的宽度是依靠字体长度来自动设定的,假如你想设置所有的Button都使用相同的大小该怎么办?使用makeColumnsEqualWidth = true;吗?不,这样做不行,它回会将各网格的大小设为相同,我们该使用GridData中相关属性来设置Button.下面程序中使用了GridData.FILL_BOTH属性,它将填充所在网格水平或垂直空间,并将多余空间占有,这样不论窗口调整多大,四个Button都会有相同空间.
当然GridLayout能做的不只是这些,要更复杂的效果,可能多个Composite配合使用,具体请参见原书第二部分第四章:Apress.The.Definitive.Guide.to.SWT.and.JFace.eBook-LiB.chm
运行效果
初始化:
调整大小后:
package chapter4;
import org.eclipse.swt.SWT;
import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.layout.GridLayout;
import org.eclipse.swt.widgets.Button;
import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.Shell;
/**//**
* @author HexUzHoNG Created on 2005-6-23
*
*/
public class GridLayoutDemo {
public static void main(String[] args) {
Display display = new Display();
Shell shell = new Shell(display);
GridLayout gridLayout = new GridLayout();
//设置为2列
gridLayout.numColumns = 2;
gridLayout.makeColumnsEqualWidth = true;
shell.setLayout(gridLayout);
GridData gd = new GridData(GridData.FILL_BOTH);
Button butOne = new Button(shell, SWT.PUSH);
butOne.setText("one");
butOne.setLayoutData(gd);
gd = new GridData(GridData.FILL_BOTH);
Button butTwo = new Button(shell, SWT.PUSH);
butTwo.setText("two");
butTwo.setLayoutData(gd);
gd = new GridData(GridData.FILL_BOTH);
Button butThree = new Button(shell, SWT.PUSH);
butThree.setText("three");
butThree.setLayoutData(gd);
gd = new GridData(GridData.FILL_BOTH);
Button butFour = new Button(shell, SWT.PUSH);
butFour.setText("four");
butFour.setLayoutData(gd);
shell.pack();
shell.open();
while (!shell.isDisposed()) {
if (!display.readAndDispatch()) {
display.sleep();
}
}
display.dispose();
}
}
分享到:
相关推荐
网格布局标签是GridLayout。这个布局是android4.0新增的布局。这个布局只有4.0之后的版本才能使用。本文给大家介绍Android布局之GridLayout网格布局相关知识,感兴趣的朋友一起学习吧
主要介绍了JavaSwing GridLayout 网格布局的实现代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
Android移动应用开发网格布局GridLayout的特点.pdf 学习资料 复习资料 教学资源
Android使用GridLayout布局完成简易计算器界面设计的任务要求.pdf 学习资料 复习资料 教学资源
主要介绍了Android中使用GridLayout网格布局来制作简单的计算器App的实例,GridLayout比表格布局TabelLayout更容易用来制作计算器这样的多按钮排列的界面,需要的朋友可以参考下
三十一、Java 图形化界面设计——布局管理器之 GridLayout(网格布局) 网格布局特点: l 使容器中的各组件呈 M 行×N 列的网格状分布。 l 网格每列宽度相同,等于容器的宽度除以网格的列数。 l 网格每行高度相同,...
Android移动应用开发网格布局GridLayout的常用属性.pdf 学习资料 复习资料 教学资源
10.2.2 GridLayout网格布局管理器 ; 10.2.2 GridLayout网格布局管理器 ; 10.2.3 BoraderLayout边框布局管理器 ; 10.2.3 BoraderLayout边框布局管理器 ;10.2.4 学生实践练习;10.2.4 学生实践练习;10.3 常用...
GridLayout提供了很多的属性,可以灵活设置网格的信息。另外,GridLayout 布局提供了GridData类,子组件可以设置相应的GridData,例如 “dogPhoto.setLayoutData(gridData)”,GridData可以设置每个组件当做单元格的...
LinearLayout 线性布局 控制组件 横向 或者 纵向 排列 ...GridLayout 网格布局 设置行列来装填控件 AbsoluteLayout 绝对布局 组件位置通过x, y坐标来控制, 布局容器不再管理组件位置, 大小, 这些都可以自定义;
GridLayout 布局管理 格子布局 详细解析应该很有用
Android基础入门教程——2.2.5 GridLayout(网格布局)-附件资源
React-Grid-Layout:网格布局(grid layout)系统,但专为 React 服务
1编写Application程序,在Frame中加入80个按钮,分20行4列,用GridLayout布局方式,按钮背景为黄色(Color.yellow),按钮文字颜色为红色(Color.red)。 2.设计一个简单计算器,如下图所示。在“操作数”标签右侧的两个...
Java布局管理的好例子,包括GridLayOut BorderLayOut CardLayOut等布局管理的实现
看看把 对你有好处的 新手经常用到的 运用他进行布局