eclipse html 布局,EclipseForm设计指南之定制布局

b2400bde496f7fd4f490c3cfa70f6856.png

Eclipse Form提供了2个新的布局,TableWrapLayout 和ColumnLayout。

(1)TableWrapLayout

·问题:如果将上例中超链接的文本设置的足够长

link.setText("This is an example of a form that is much longer and will need to wrap.");

即使设置了SWT.WRAP,文本内容不会自动WRAP,这是因为体内容的布局是GridLayout

·Eclipse Form提供替代的布局TableWrapLayout:类似于GridLayout,但是具有象HTML表格一样自动WRAP功能

·下面是解决超链接文本自动WRAP的例子:

public void createPartControl(Composite parent) {

toolkit = new FormToolkit(parent.getDisplay());

form = toolkit.createScrolledForm(parent);

form.setText("Hello, Eclipse Forms");

Composite body = form.getBody();

TableWrapLayout layout = new TableWrapLayout();

body.setLayout(layout);

HyPerlink link = toolkit.createHyperlink(body, "Click here.", SWT.WRAP);

link.addHyperlinkListener(new HyperlinkAdapter() {

public void linkActivated(HyperlinkEvent e) {

System.out.println("Link activated!");

}

});

layout.numColumns = 2;

link.setText

("This is an example of a form that is much longer and will need to wrap.");

TableWrapData td = new TableWrapData();

td.colspan = 2;

link.setLayoutData(td);

Label label = toolkit.createLabel(body, "Text field label:");

Text text = toolkit.createText(body, "");

td = new TableWrapData(TableWrapData.FILL_GRAB);

text.setLayoutData(td);

text.setData(FormToolkit.KEY_DRAW_BORDER, FormToolkit.TEXT_BORDER);

Button button = toolkit.createButton(body,

"An example of a checkbox in a form", SWT.CHECK);

td = new TableWrapData();

td.colspan = 2;

button.setLayoutData(td);

toolkit.paintBordersFor(body);

}

·下面是程序变化的地方:

1) TableWrapLayout替代GridLayout

2) 使用TableWrapData来提供布局数据信息

3) 设置的属性使用colspan、rowspan等来源于HTML表格单元的属性

·要注意的是:需要自动WRAP的控件,需要设置成SWT.WRAP风格

(2)ColumnLayout

·ColumnLayout是Eclipse Form提供的另一个定制布局

·ColumnLayout的布局方式是从上到下,从左到右

·在变化Form的宽度时,会自动调整控件列数以适应Form的宽度

·ColumnLayout的设置很简单,通常只要设置列数的范围(缺省是1-3)

2829f2ca24f0d0090cbba57f30759f23.png

EclipseForm设计指南之定制布局.doc

下载Word文档到电脑,方便收藏和打印[全文共1201字]

编辑推荐:

8b95f2eb3d3f7ce4dc3bf1178c74941e.png

8b95f2eb3d3f7ce4dc3bf1178c74941e.png

8b95f2eb3d3f7ce4dc3bf1178c74941e.png

8b95f2eb3d3f7ce4dc3bf1178c74941e.png

8b95f2eb3d3f7ce4dc3bf1178c74941e.png

下载Word文档

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值