Python
- 4. 其他流程控制工具
- 4.1. if语句
- 4.2. for语句
- 4.3. range()函数
- 4.4. 循环中的break、continue语句及else子句
- 4.5. pass语句
- 4.6. 定义函数
- 4.7. 函数定义详解
- 4.7.1. 默认值参数
- 4.7.2. 关键字参数
- 4.7.3. 特殊参数
- 4.7.3.1. 位置或关键字参数
- 4.7.3.2. 仅位置参数
- 4.7.3.3. 仅限关键字参数
- 4.7.3.4. 函数示例
- 4.7.3.5. 小结
- 4.7.4. 任意实参列表
- 4.7.5. 解包实参列表
- 4.7.6. Lambda 表达式
- 4.7.7. 文档字符串
- 4.7.8. 函数注解
- 4.8. 小插曲:编码风格
library/tkinter.dnd
tkinter.dnd
--- 拖放操作支持¶
源代码: Lib/tkinter/dnd.py
注解
此模块是实验性的且在为 Tk DND 所替代后将被弃用。
tkinter.dnd
模块为单个应用内部的对象提供了在同一窗口中或多个窗口间的拖放操作支持。 要将对象设为可拖放,你必须为其创建启动拖放进程的事件绑定。 通常,你要将 ButtonPress 事件绑定到你所编写的回调函数 (参见 Bindings and Events)。 该函数应当调用 dnd_start()
,其中 'source' 为要拖动的对象,而 'event' 为发起调用的事件(你的回调函数的参数)。
目标对象的选择方式如下:
从顶至底地在鼠标之下的区域中搜索目标控件
目标控件应当具有一个指向可调用对象的 dnd_accept 属性
如果 dnd_accept 不存在或是返回 None,则将转至父控件中搜索
如果目标控件未找到,则目标对象为 None
调用 <old_target>.dnd_leave(source, event)
调用 <new_target>.dnd_enter(source, event)
调用 <target>.dnd_commit(source, event) 来通知释放
调用 <source>.dnd_end(target, event) 来表明拖放的结束
-
class
tkinter.dnd.
DndHandler
(source, event)¶ DndHandler 类处理拖放事件,在事件控件的根对象上跟踪 Motion 和 ButtonRelease 事件。
-
cancel
(event=None)¶ 取消拖放进程。
-
finish
(event, commit=0)¶ 执行结束播放函数。
-
on_motion
(event)¶ 在执行拖动期间为目标对象检查鼠标之下的区域。
-
on_release
(event)¶ 当释放模式被触发时表明拖动的结束。
-
-
tkinter.dnd.
dnd_start
(source, event)¶ 用于拖放进程的工厂函数。
此页内容是否对您有帮助
感谢反馈!