如何在SWT中将自定义小部件与TreeItems相关联?

时间:2013-08-27 15:00:11

标签: java user-interface widget swt

我创建了一个自定义窗口小部件 - 一个SWT组,它包含几个按钮,标签,图像以及我将来可能需要添加的其他几个窗口小部件。我想将这个自定义小部件作为树项,以便我可以获得树的缩进和展开/折叠功能。

这是一张图片,展示了我想要实现的目标:

enter image description here

我使用Google Web Toolkit创建了这个示例,我想用SWT实现它。

SWT TreeItem具有设置文本和图像的方法,但我找不到使树项成为自定义窗口小部件的方法。如果无法将自定义窗口小部件与SWT树项关联,那么在树中使用缩进和展开/折叠功能组织自定义窗口小部件的其他方法的建议也将非常有用。谢谢!

2 个答案:

答案 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();