当前位置: 首页 > 知识库问答 >
问题:

SWT树节点的拖动类型是什么

赵渊
2023-03-14

我有一个SWT树,它有图像和其他文本和多级子。现在我想拖动这个树节点,但我无法为此获得适当的传输类型。所以一旦我拖动,我就不会得到拖动的图像。是否有相同的默认传输类型可用。

我用了下面的转账,但没用-

Transfer[] types = new Transfer[] {FileTransfer.getInstance(),ImageTransfer.getInstance() };

共有1个答案

申屠亦
2023-03-14

我仍然不完全确定您所要求的是什么,但是这段代码甚至可以使用images。

如果您的文本不能用作标识符,您可以想出其他方法:

private static Map<String, Image>   mapping = new HashMap<String, Image>();

public static void main(String[] args)
{
    Display display = new Display();
    final Shell shell = new Shell(display);
    shell.setText("StackOverflow");
    shell.setLayout(new FillLayout());

    Tree tree = new Tree(shell, SWT.NONE);

    Image[] images = new Image[] { display.getSystemImage(SWT.ICON_WARNING),
            display.getSystemImage(SWT.ICON_ERROR), display.getSystemImage(SWT.ICON_INFORMATION),
            display.getSystemImage(SWT.ICON_QUESTION) };

    for (int i = 0; i < 10; i++)
    {
        TreeItem item = new TreeItem(tree, SWT.NONE);
        item.setText("Item " + i);
        item.setImage(images[i % images.length]);
        mapping.put("Item " + i, images[i % images.length]);
    }

    initDnD(display, tree);

    shell.pack();
    shell.open();
    while (!shell.isDisposed())
    {
        if (!display.readAndDispatch())
            display.sleep();
    }
    display.dispose();
}

private static void initDnD(final Display display, final Tree tree)
{
    Transfer[] types = new Transfer[] { TextTransfer.getInstance() };
    int operations = DND.DROP_MOVE | DND.DROP_COPY | DND.DROP_LINK;

    final DragSource source = new DragSource(tree, operations);
    source.setTransfer(types);

    final TreeItem[] dragSourceItem = new TreeItem[1];
    source.addDragListener(new DragSourceListener()
    {
        public void dragStart(DragSourceEvent event)
        {
            TreeItem[] selection = tree.getSelection();
            if (selection.length > 0 && selection[0].getItemCount() == 0)
            {
                event.doit = true;
                dragSourceItem[0] = selection[0];
            }
            else
            {
                event.doit = false;
            }
        };

        public void dragSetData(DragSourceEvent event)
        {
            event.data = dragSourceItem[0].getText();
        }

        public void dragFinished(DragSourceEvent event)
        {
            if (event.detail == DND.DROP_MOVE)
                dragSourceItem[0].dispose();
            dragSourceItem[0] = null;
        }
    });

    DropTarget target = new DropTarget(tree, operations);
    target.setTransfer(types);
    target.addDropListener(new DropTargetAdapter()
    {
        public void dragOver(DropTargetEvent event)
        {
            event.feedback = DND.FEEDBACK_SCROLL;
            if (event.item != null)
            {
                TreeItem item = (TreeItem) event.item;
                Point pt = display.map(null, tree, event.x, event.y);
                Rectangle bounds = item.getBounds();
                if (pt.y < bounds.y + bounds.height / 3)
                {
                    event.feedback |= DND.FEEDBACK_INSERT_BEFORE;
                }
                else if (pt.y > bounds.y + 2 * bounds.height / 3)
                {
                    event.feedback |= DND.FEEDBACK_INSERT_AFTER;
                }
            }
        }

        public void drop(DropTargetEvent event)
        {
            if (event.data == null)
            {
                event.detail = DND.DROP_NONE;
                return;
            }
            String text = (String) event.data;
            if (event.item != null)
            {
                TreeItem item = (TreeItem) event.item;
                Point pt = display.map(null, tree, event.x, event.y);
                Rectangle bounds = item.getBounds();

                TreeItem[] items = tree.getItems();
                int index = 0;
                for (int i = 0; i < items.length; i++)
                {
                    if (items[i] == item)
                    {
                        index = i;
                        break;
                    }
                }

                if (pt.y < bounds.y + bounds.height / 3)
                {
                    TreeItem newItem = new TreeItem(tree, SWT.NONE, index);
                    newItem.setText(text);
                    newItem.setImage(mapping.get(text));
                }
                else if (pt.y > bounds.y + 2 * bounds.height / 3)
                {
                    TreeItem newItem = new TreeItem(tree, SWT.NONE, index + 1);
                    newItem.setText(text);
                    newItem.setImage(mapping.get(text));
                }
                else
                {
                    TreeItem newItem = new TreeItem(item, SWT.NONE);
                    newItem.setText(text);
                    newItem.setImage(mapping.get(text));
                }
            }
        }
    });
}
 类似资料:
  • 使用此示例,我想创建带有节点的TreeView,我可以拖动这些节点来更改它们的位置。 我试图实现这个例子,但我在这里遇到了一个问题: 我得到了

  • 在JavaFX中,我试图通过单击并拖动节点来移动它。如果节点不旋转,它工作得很好,但是当我旋转它时,它开始表现得很奇怪。 在45°左右,当我移动它时,它开始抖动,在60°时,它剧烈地来回抖动。在90°时,只要我开始移动节点,它就会飞离屏幕。 下面是我用来旋转和移动节点的代码。它来自连接到节点的鼠标侦听器。 编辑:这是一些示例输出,以及显示不同节点的图片。 未旋转且缓慢向左移动时的输出: 旋转时缓慢

  • 如果我没弄错的话,树通常是一个列表,其中的元素按特定顺序排列。孩子们不在他们自己的子列表中,他们都在同一个列表中。 所以,我试图创建一个Tree类,其中包含TreeNodes(类)使用Tree类中的List。 我如何跟踪父母/孩子/叶子?如果父母“父母1”,有两个孩子“孩子A”和“孩子B”,我如何将他们联系在一起?

  • 问题内容: 我试图在这个问题中创建一个类似于“奖杯轮”的可旋转节点。到目前为止,我具有甩尾功能,可以使用效果很好的UIPanGestureRecognizer在物理物体上添加角度脉冲。我也可以通过触摸停止旋转。 现在,我试图通过拖动或滑动手势来微调方向盘,这样,如果玩家对最终的效果不满意,就可以手动旋转/拖动/旋转它所喜欢的旋转方式。 目前,我将触摸的位置保存在touchesBegan中,并尝试在

  • 本文向大家介绍ElasticSearch中的集群、节点、索引、文档、类型是什么?相关面试题,主要包含被问及ElasticSearch中的集群、节点、索引、文档、类型是什么?时的应答技巧和注意事项,需要的朋友参考一下 群集是一个或多个节点(服务器)的集合,它们共同保存您的整个数据,并提供跨所有节点的联合索引和搜索功能。群集由唯一名称标识,默认情况下为“elasticsearch”。此名称很重要,因为