Flutter 事件监听以及EventBus

news/2024/7/20 20:54:18 标签: flutter, android, ios

在Flutter中,手势有两个不同的层次:

第一层:原始指针事件(Pointer Events)

第二层:手势识别(Gesture Detector)

一  指针事件 Pointer

其原理是什么?

1 在指针落下的时候,框架做了一个hit test 的操作,确定与屏幕发生接触的位置有哪些的Widget 以及分发给最内部的组件去响应

2 事件会沿着最内部的组件向组件树的根冒泡分发

3 并且不存在用于取消或者停止指针事件进一步分发的机制

class _EventPointerDemoPageState extends State<EventPointerDemoPage> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("事件监听"),
      ),
      body: Center(
          child: Listener(
        onPointerDown: (event) {
          // 相对于这个container 的 位置
          print(event.localPosition);
          // 相对于屏幕的位置
          print(event.position);
          // print("手指按下了$event");
        },
        onPointerMove: (event) {
          // print("手指移动了$event");
        },
        onPointerUp: (event) {
          // print("手指抬起了$event");
        },
        child: Container(
          width: 200,
          height: 200,
          color: Colors.redAccent,
        ),
      )),
    );
  }
}

二 手势识别

手势识别Gesture 是对一系列Pointer的封装,官方建议尽可能使用Gesture

1 点击

onTapDown用户发生手指按下的操作
onTapUp用户发生手指抬起的操作
onTap用户点击事件完成
onTapCancel事件按下过程中被取消

2 双击

onDoubleTap快速点击了两次

3 长按

        

onLongPress在屏幕上保持了一段时间

 4 纵向拖拽

onVerticalDragStart指针和屏幕产生接触并可能开始纵向移动;
onVerticalDragUpdate指针和屏幕产生接触,在纵向上发生移动并保持移动;
onVerticalDragEnd指针和屏幕产生接触结束

      

5 横向拖拽

onHorizontalDragStart指针和屏幕产生接触并可能开始横向移动;
onHorizontalDragUpdate指针和屏幕产生接触,在横向上发生移动并保持移动
onHorizontalDragEnd指针和屏幕产生接触结束;

 6 移动

onPanStart指针和屏幕产生接触并可能开始横向移动或者纵向移动。如果设置了 onHorizontalDragStart 或者 onVerticalDragStart,该回调方法会引发崩溃
onPanUpdate指针和屏幕产生接触,在横向或者纵向上发生移动并保持移动。如果设置了 onHorizontalDragUpdate 或者 onVerticalDragUpdate,该回调方法会引发崩溃。
onPanEnd指针先前和屏幕产生了接触,并且以特定速度移动,此后不再在屏幕接触上发生移动。如果设置了 onHorizontalDragEnd 或者 onVerticalDragEnd,该回调方法会引发崩溃。

基本使用

_gestureDemo() {
    return GestureDetector(
      onTap: () {
        print("点击事件完成了");
      },
      onPanEnd: (details) {
        print(details);
      },
      onTapDown: (details) {
        // 相对于container
        print(details.localPosition);
        // 相对于屏幕的
        print(details.globalPosition);
      },
      onTapUp: (details) {
        // 抬起之后 才会调用 onTap ,证明点击事件完成了
        print("1111");
      },
      child: Container(
        width: 200,
        height: 200,
        color: Colors.blueAccent,
      ),
    );
  }

三  跨组件事件的传递

多重组件的事件传递使用的是EventBus,很方便。

官方建议我们定义不同的Event ,从而区别不同的event

使用的是插件event_bus ,简单 的三步走操作

1 创建全局的event_bus,

import "package:event_bus/event_bus.dart";

// 定义一个全局的eventBus
final eventBus = EventBus();

class MyEventMessage {
  String? name;
  String? action;
  MyEventMessage(this.name, this.action);
}

2 fire

 return ElevatedButton(
        onPressed: () {
          print("点击事件");
          // 第二步fire
          eventBus.fire(MyEventMessage("leonardo", "hahaha"));
        },
        child: Text("改变文字"));
  }

3 listen

 void initState() {
    // TODO: implement initState
    super.initState();
    // 第三步监听操作
    eventBus.on<MyEventMessage>().listen((event) {
      print(event.name);
      setState(() {
        _name = event.name!;
      });
    });
  }


http://www.niftyadmin.cn/n/212712.html

相关文章

接入丰桥,下单到打印面单到配送开发流程

顺丰开放平台地址&#xff1a;顺丰开放平台 一、了解官网 1.1、开发文档 开发接口之前可以先查看熟悉文档&#xff0c;尤其是API文档仔细阅读。进入之后是如下图&#xff0c;根据自己需要开发的接口&#xff0c;先查看文档&#xff0c;然后根据文档要求来请求并处理响应。 1.2…

【ROS2指南-6】理解ROS2参数

目标&#xff1a;了解如何在 ROS 2 中获取、设置、保存和重新加载参数。 教程级别&#xff1a;初学者 时间&#xff1a; 5分钟 内容 背景 先决条件 任务 1 设置 2 ros2参数列表 3 ros2参数获取 4 ros2 参数集 5 ros2 参数转储 6 加载参数文件 概括 下一步 背景 参数…

银行数字化转型导师坚鹏:ChatGPT解密与银行应用案例

ChatGPT解密与银行应用案例 ——开启人类AI新纪元 打造数字化转型新利器 课程背景&#xff1a; 很多企业和员工存在以下问题&#xff1a; 不清楚ChatGPT对我们有什么影响&#xff1f; 不知道ChatGPT的发展现状及作用&#xff1f; 不知道ChatGPT的银行业应用案例&#xff1f;…

jenkins学习--shot on mac

使用parallel desktop centos 三台机/两台也行 一台作为gitlab 服务器一台作为jenkins服务器一台作为测试jenkins构建的应用能够否运行的测试服务器&#xff08;需要jre) jenkins配置项目任务 构建前的脚本任务&#xff08;确保应用端口没有被占用&#xff09;构建&#xff0…

ChatGpt的问与答

2023/4/12 09:37:43 网络安全测试 2023/4/12 09:38:19 网络安全测试是指通过模拟攻击&#xff0c;对计算机系统、网络、应用程序等进行安全评估&#xff0c;发现其中存在的漏洞和安全风险&#xff0c;并提供修复建议的过程。网络安全测试可以帮助企业和组织发现和解决网络安…

Halcon视觉软件库介绍

Halcon是一种计算机视觉软件库&#xff0c;可用于图像处理和机器视觉应用程序的开发。它由奥地利的MVTec Software GmbH开发&#xff0c;支持多个平台&#xff0c;包括Windows&#xff0c;Linux和Mac OS X。 Halcon提供了各种各样的功能&#xff0c;包括图像处理&#xff0c;特…

java day4

数组、逻辑和循环4.1 数组4.1.1 声明数组变量4.1.2 创建数组对象4.1.3 访问数组元素4.1.4 修改数组元素4.1.5 多维数组4.2 块语句4.3 if条件语句4.4 switch条件语句4.5 三目运算符4.6 for循环4.7 while和do循环4.7.1 while循环4.7.2 do...while循环4.8 跳出循环标号4.1 数组 4…

Microsoft AIP部署方案

目录 前言 一、前期准备工作 1. 了解Microsoft AIP的功能和优点 2. 准备必要的硬件和软件设施