java 点击拖拽脚本_JavaFX实现拖拽结点效果

本文介绍了如何使用JavaFX创建可拖拽的树结构结点。通过监听鼠标事件,实现结点在GUI中的拖动功能。详细讲解了结点的拖拽实现过程,包括鼠标进入、退出、按下和释放事件的处理,以及结点位置的动态更新。
摘要由CSDN通过智能技术生成

在学校里复习完数据结构的树结构后,想使用 JavaFX 把树给画出来,其中树的结点我希望做成可拖拽,这里简单记录下 JavaFX 的鼠标拖拽。

拖拽是 GUI 中常见的用户交互,经常通过将鼠标指针变为手势来提醒用户某个结点可点击:

9e9875a04479504d126bc4a6233670ac.png

而当用户点击鼠标(准确来说是指按压鼠标不放)时,鼠标指针将变为十字来提醒用户该结点可拖拽:

6707b2cd5d5cbad2ca2b0da263653e3c.png

上诉两种鼠标指针变化都很简单,只要在相应的事件处理器中进行设置即可:

public class DraggableDemo extends Application {

private void draggable(Node node) {

// 提示用户该结点可点击

node.addEventHandler(MouseEvent.MOUSE_ENTERED, event -> node.setCursor(Cursor.HAND));

node.addEventHandler(MouseEvent.MOUSE_EXITED, event -> node.setCursor(Cursor.DEFAULT));

// 提示用户该结点可拖拽

node.addEventHandler(MouseEvent.MOUSE_PRESSED, event -> node.setCursor(Cursor.MOVE));

node.addEventHandler(MouseEvent.MOUSE_RELEASED, event -> node.setCursor(Cursor.DEFAULT));

// ... 剩余代码 ...

}

}

下面实现结点的拖拽,这里以 X 轴为参考进行说明:

7a415a00b1454358161f445547663efc.png

在图中,我们要计算的未知数是 x(y 轴方向上的变量暂时不考虑),其中 x = layoutX + distanceX 。另外在用户按压鼠标时,我们需要缓存一下按压事件所发生的位置坐标。下面来实现结点的拖拽功能,变量 y 的计算方式与 x 类似。

我们首先写一个内部类Position专门用来表示坐标:

public class DraggableDemo extends Application {

privat

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值