我创建了一个自定义窗口小部件 - 一个SWT组,它包含几个按钮,标签,图像以及我将来可能需要添加的其他几个窗口小部件。我想将这个自定义小部件作为树项,以便我可以获得树的缩进和展开/折叠功能。
这是一张图片,展示了我想要实现的目标:
我使用Google Web Toolkit创建了这个示例,我想用SWT实现它。
SWT TreeItem具有设置文本和图像的方法,但我找不到使树项成为自定义窗口小部件的方法。如果无法将自定义窗口小部件与SWT树项关联,那么在树中使用缩进和展开/折叠功能组织自定义窗口小部件的其他方法的建议也将非常有用。谢谢!
答案 0 :(得分:1)
Eclipse Nebula项目中的PGroup小部件完成了这项工作。它允许您包含SWT复合材料并支持折叠和展开。缩进可以通过对PGroup的内容使用布局(例如,GridLayout)和布局数据(例如,GridData)来指定PGroup内的组件的缩进来实现。
ExpandBar(标准SWT widget)似乎也是一种可能的解决方案,但我还没有尝试过。
答案 1 :(得分:0)
似乎可以使用事件SWT.PaintItem
添加自定义绘图:
https://www.eclipse.org/articles/Article-CustomDrawingTableAndTreeItems/customDraw.htm
来源: Embed custom widget in SWT Tree or Table
1 Display display = new Display();
2 Shell shell = new Shell(display);
3 shell.setBounds(10, 10, 350, 200);
4 Image xImage = new Image (display, 16, 16);
5 GC gc = new GC(xImage);
6 gc.setForeground(display.getSystemColor(SWT.COLOR_RED));
7 gc.drawLine(1, 1, 14, 14);
8 gc.drawLine(1, 14, 14, 1);
9 gc.drawOval(2, 2, 11, 11);
10 gc.dispose();
11 final int IMAGE_MARGIN = 2;
12 final Tree tree = new Tree(shell, SWT.CHECK);
13 tree.setBounds(10, 10, 300, 150);
14 TreeItem item = new TreeItem(tree, SWT.NONE);
15 item.setText("root item");
16 for (int i = 0; i < 4; i++) {
17 TreeItem newItem = new TreeItem(item, SWT.NONE);
18 newItem.setText("descendent " + i);
19 if (i % 2 == 0) newItem.setData(xImage);
20 item.setExpanded(true);
21 item = newItem;
22 }
23 tree.addListener(SWT.MeasureItem, new Listener() {
24 public void handleEvent(Event event) {
25 TreeItem item = (TreeItem)event.item;
26 Image trailingImage = (Image)item.getData();
27 if (trailingImage != null) {
28 event.width += trailingImage.getBounds().width + IMAGE_MARGIN;
29 }
30 }
31 });
32 tree.addListener(SWT.PaintItem, new Listener() {
33 public void handleEvent(Event event) {
34 TreeItem item = (TreeItem)event.item;
35 Image trailingImage = (Image)item.getData();
36 if (trailingImage != null) {
37 int x = event.x + event.width + IMAGE_MARGIN;
38 int itemHeight = tree.getItemHeight();
39 int imageHeight = trailingImage.getBounds().height;
40 int y = event.y + (itemHeight - imageHeight) / 2;
41 event.gc.drawImage(trailingImage, x, y);
42 }
43 }
44 });
45 shell.open();
46 while (!shell.isDisposed()) {
47 if (!display.readAndDispatch()) display.sleep();
48 }
49 xImage.dispose();
50 display.dispose();