跳到主要内容

手势检测器 GestureDetector

一个用于检测手势的控件。

尝试识别与其非空回调相对应的手势。

如果该控件有一个content,它将以该子控件为参考来确定自己的尺寸行为。如果没有content,则它会根据父控件的尺寸自动调整大小。

示例

在线示例

纸牌游戏教程

可拖动容器

以下示例演示了如何在 Stack 内自由拖动一个控件。

该示例还展示了 GestureDetector 可以拥有一个子控件(蓝色容器),也可以嵌套在另一个控件内(黄色容器),得到相同的结果。

import flet as ft

def main(page: ft.Page):
def on_pan_update1(e: ft.DragUpdateEvent):
c.top = max(0, c.top + e.delta_y)
c.left = max(0, c.left + e.delta_x)
c.update()

def on_pan_update2(e: ft.DragUpdateEvent):
e.control.top = max(0, e.control.top + e.delta_y)
e.control.left = max(0, e.control.left + e.delta_x)
e.control.update()

gd = ft.GestureDetector(
mouse_cursor=ft.MouseCursor.MOVE,
drag_interval=50,
on_pan_update=on_pan_update1,
)

c = ft.Container(gd, bgcolor=ft.Colors.AMBER, width=50, height=50, left=0, top=0)

gd1 = ft.GestureDetector(
mouse_cursor=ft.MouseCursor.MOVE,
drag_interval=10,
on_vertical_drag_update=on_pan_update2,
left=100,
top=100,
content=ft.Container(bgcolor=ft.Colors.BLUE, width=50, height=50),
)

page.add( ft.Stack([c, gd1], width=1000, height=500))

ft.app(target=main)

属性

content

手势检测器包含的子控件。

mouse_cursor

鼠标指针悬停在控件上时的样式。类型值为MouseCursor

drag_interval

水平拖动、垂直拖动和平移更新事件的节流时间间隔(以毫秒为单位)。当用户移动指针时,会生成大量的事件以进行精确跟踪。drag_interval 允许每隔 X 毫秒将拖动更新事件发送给 Flet 程序,从而保持带宽(适用于 Web 和移动应用程序)。默认值为 0,即不进行节流,所有事件都发送给 Flet 程序,实现非常平滑的跟踪。

hover_interval

on_hover 事件的节流时间间隔(以毫秒为单位)。

事件

multi_tap_touches

触发 on_multi_tap 事件所需的最小指针数。

on_double_tap

用户在同一位置快速连续两次点击屏幕的主要按钮。

on_double_tap_down

可能引发双击的指针已在特定位置接触屏幕。

在第二次点击的按下事件之后立即触发。

事件处理程序参数是 MapTapEvent 类的实例。

on_enter

当鼠标指针进入此控件时触发。

事件处理程序参数是 HoverEvent 类的实例。

on_exit

当鼠标指针离开此控件时触发。

事件处理程序参数是 HoverEvent 类的实例。

on_horizontal_drag_end

之前与屏幕接触且水平移动的主要按钮的指针不再与屏幕接触,并且在停止接触屏幕时以特定速度移动。

事件处理程序参数是 DragEndEvent 类的实例。

on_horizontal_drag_start

使用主要按钮触摸屏幕并开始水平移动的指针。

事件处理程序参数是 DragStartEvent 类的实例。

on_horizontal_drag_update

与主要按钮接触并水平移动的指针已经在水平方向上移动。

事件处理程序参数是 DragUpdateEvent 类的实例。

on_hover

当鼠标指针进入此控件时触发。

事件处理程序参数是 HoverEvent 类的实例。

on_long_press_end

当使用主要按钮触发的长按手势停止接触屏幕时调用。

事件处理程序参数是一个LongPressEndEvent 类的实例。

on_long_press_start

当使用主要按钮触发的长按手势被识别时调用。

当指针在同一位置长时间保持接触屏幕时触发。

事件处理程序参数是一个LongPressStartEvent 类的实例。

on_pan_end

之前与主要按钮接触屏幕并移动的指针不再接触屏幕,并且在停止接触屏幕时以特定速度移动。

事件处理程序参数是一个DragEndEvent类的实例。

on_pan_start

使用主要按钮触摸屏幕并开始移动时调用。

事件处理程序参数是一个DragStartEvent类的实例。

on_pan_update

与主要按钮接触屏幕并移动的指针再次移动时调用。

事件处理程序参数是一个DragUpdateEvent类的实例。

on_scale_end

事件处理程序参数是一个ScaleEndEvent类的实例。

on_scale_start

与屏幕接触的指针已经建立了焦点和初始缩放比例为1.0。

事件处理程序参数是一个ScaleStartEvent类的实例。

on_scale_update

事件处理程序参数是一个ScaleUpdateEvent类的实例。

on_secondary_long_press_end

当使用次要按钮触发的长按手势停止接触屏幕时调用。

事件处理程序参数是一个 LongPressEndEvent类的实例。

on_secondary_long_press_start

当使用次要按钮触发的长按手势被识别时调用。

当指针在同一位置长时间保持接触屏幕时触发。

事件处理程序参数是一个LongPressStartEvent 类的实例。

on_secondary_tap

发生了一个次要按钮的轻触。

on_secondary_tap_down

可能会触发次要按钮轻触的指针在特定位置接触屏幕时调用。

事件处理程序参数是一个 MapTapEvent类的实例。

on_secondary_tap_up

将触发次要按钮轻触的指针在特定位置停止接触屏幕时调用。

事件处理程序参数是一个 MapTapEvent类的实例。

on_tap

发生了一个主要按钮的轻触。

on_tap_down

可能会触发主要按钮轻触的指针在特定位置接触屏幕时调用。

事件处理程序参数是一个 MapTapEvent类的实例。

on_tap_up

将触发主要按钮轻触的指针在特定位置停止接触屏幕时调用。

事件处理程序参数是一个 MapTapEvent类的实例。

on_vertical_drag_end

之前与主要按钮接触屏幕并垂直移动的指针不再接触屏幕,并且在停止接触屏幕时以特定速度移动。

事件处理程序参数是一个DragEndEvent类的实例。

on_vertical_drag_start

使用主要按钮触摸屏幕并开始垂直移动时调用。

事件处理程序参数是一个DragStartEvent类的实例。

on_vertical_drag_update

与主要按钮接触屏幕并垂直移动的指针在垂直方向上再次移动时调用。

事件处理程序参数是一个DragUpdateEvent类的实例。

on_multi_long_press

当识别到具有多个指针的长按手势时调用。

on_multi_tap

多个指针接触屏幕时触发。

事件处理程序参数是一个MultiTapEvent类的实例。

on_scroll

on_scroll是一个事件处理程序参数,它是ScrollEvent类的一个实例。