SWT GridLayout 网格布局

发表于: java/j2ee | 作者: | 日期: 2013/6/06 07:06
标签: ,

GridLayout是一个非常强大的布局管理器,它可以实现很多复杂的布局,名字中暗示它将所有控件放置在类似网格的布局中。
GridLayout的构造函数

public GridLayout()

建立一个默认的GridLayout布局。

public GridLayout(int numColumns, boolean makeColumnsEqualWidth)

建立一个GridLayout布局,拥有numColumns列,如果makeColumnsEqualWidth为true,则全部组件将拥有相同的宽度。
GridLayout有6个公共的数据成员,相对重要的是numColumns。对于margin和spacing的设置可以参考CSS及html中对于table的设置,概念上非常类似,以下是6个数据成员列表:
int numColumns
此GridLayout的列数目。
boolean makeColumnsEqualWidth
如果为true,强制全部的列拥有相同的宽度。
int horizontalSpacing
控制一行中两个网格间组件之间的间隙,像素为单位。
int verticalSpacing
控制一列中两个网格间组件之间的间隙,像素为单位。
int marginHeight
控制顶部和底部组件离边缘的距离空间,以像素为单位。
int marginWidth
控制左边和右边组件离边缘的距离空间,以像素为单位。
你能使用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 widthHint
该列中最小的宽度,以像素为单位,默认为SWT.DEFAULT。
int horizontalAlignment
网格中组件水平对齐方式,可能的值为BEGINNING, CENTER, END,和FILL。
int horizontalIndent
与左边网格的水平缩进,默认为0
int horizontalSpan
设置网格占有的列数目,默认为1
int verticalAlignment
网格中组件垂直对齐方式,可能的值为BEGINNING, CENTER, END,和FILL。
int verticalSpan
设置网格占有的行数目,默认为1
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”);

效果如下:
2013-06-06_105908
图中可以看到各个Button的宽度是依靠字体长度来自动设定的,假如你想设置所有的Button都使用相同的大小该怎么办?使用makeColumnsEqualWidth = true;吗?不,这样做不行,它只会将各网格的大小设为相同,我们该使用GridData中相关属性来设置Button。下面程序中使用了GridData.FILL_BOTH属性,它将填充所在网格水平或垂直空间,并将多余空间占有,这样不论窗口调整多大,四个Button都会有相同空间。
当然GridLayout能做的不只是这些,要更复杂的效果,可能多个Composite配合使用。
button可以自动调整大小的完整代码:

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();
}
}

[整理自网络]

: https://blog.darkmi.com/2013/06/06/3271.html

本文相关评论 - 1条评论都没有呢
Post a comment now » 本文目前不可评论

No comments yet.

Sorry, the comment form is closed at this time.