iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Flutter事件监听与EventBus事件应用的方法是什么
  • 463
分享到

Flutter事件监听与EventBus事件应用的方法是什么

2023-07-06 02:07:16 463人浏览 薄情痞子
摘要

这篇文章主要介绍“Flutter事件监听与EventBus事件应用的方法是什么”,在日常操作中,相信很多人在Flutter事件监听与EventBus事件应用的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家

这篇文章主要介绍“Flutter事件监听与EventBus事件应用的方法是什么”,在日常操作中,相信很多人在Flutter事件监听与EventBus事件应用的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Flutter事件监听与EventBus事件应用的方法是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

一 指针事件 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";// 定义一个全局的eventBusfinal 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!;      });    });  }

到此,关于“Flutter事件监听与EventBus事件应用的方法是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: Flutter事件监听与EventBus事件应用的方法是什么

本文链接: https://www.lsjlt.com/news/357422.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Flutter事件监听与EventBus事件应用的方法是什么
    这篇文章主要介绍“Flutter事件监听与EventBus事件应用的方法是什么”,在日常操作中,相信很多人在Flutter事件监听与EventBus事件应用的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家...
    99+
    2023-07-06
  • Flutter事件监听与EventBus事件的应用详解
    目录一 指针事件 Pointer二 手势识别三 跨组件事件的传递在Flutter中,手势有两个不同的层次: 第一层:原始指针事件(Pointer Events) 第二层:手势识别(G...
    99+
    2023-05-15
    Flutter事件监听 Flutter EventBus
  • JS添加事件监听的方法是什么
    这篇文章主要介绍“JS添加事件监听的方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JS添加事件监听的方法是什么”文章能帮助大家解决问题。1.我们一般在的事件添加时是这样做的:elm.onc...
    99+
    2023-06-26
  • Spring的事件发布与监听方式是什么
    本篇内容介绍了“Spring的事件发布与监听方式是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!事件主要代码在org.springfra...
    99+
    2023-07-05
  • JavaScript中的事件监听是什么
    这篇文章主要介绍“JavaScript中的事件监听是什么”,在日常操作中,相信很多人在JavaScript中的事件监听是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Ja...
    99+
    2022-10-19
  • jQuery3种常见事件监听方式是什么
    这篇文章主要为大家展示了“jQuery3种常见事件监听方式是什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“jQuery3种常见事件监听方式是什么”这篇文章吧。1.HTML标签内联事件实例1:...
    99+
    2023-06-29
  • Java中的事件监听机制是什么
    这篇文章给大家介绍Java中的事件监听机制是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。鼠标事件监听机制的三个方面:1.事件源对象:事件源对象就是能够产生动作的对象。在Java语言中所有的容器组件和元素组件都是事...
    99+
    2023-05-31
    java 事件监听机制 ava
  • Spring事件发布与监听机制的用法示例
    小编给大家分享一下Spring事件发布与监听机制的用法示例,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、ApplicationContext 事件机制Appl...
    99+
    2023-06-20
  • springboot应用服务启动事件的监听怎么实现
    本篇内容主要讲解“springboot应用服务启动事件的监听怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“springboot应用服务启动事件的监听怎么实现”吧!一、简介Spring B...
    99+
    2023-06-29
  • android中对截图事件进行监听的原理是什么
    这篇文章给大家介绍android中对截图事件进行监听的原理是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。监听截屏图片所在目录变化(FileObserver)监听媒体库的变化(ContentObserver)&nb...
    99+
    2023-05-30
    android 中对 roi
  • android事件分发与处理的方法是什么
    Android事件分发与处理的方法主要有以下几种:1. 触摸事件分发处理:Android中的触摸事件主要包括按下、移动、抬起等动作。...
    99+
    2023-09-13
    android
  • Java事件与错误处理方法是什么
    这篇文章主要讲解了“Java事件与错误处理方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java事件与错误处理方法是什么”吧!  12.1事件处理  传授新知  消息驱动、事件处理...
    99+
    2023-06-03
  • javascript绑定事件的方法是什么
    本篇内容介绍了“javascript绑定事件的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!绑定...
    99+
    2022-10-19
  • WebBrowser控件的常用方法、属性和事件是什么
    这篇文章主要介绍“WebBrowser控件的常用方法、属性和事件是什么”,在日常操作中,相信很多人在WebBrowser控件的常用方法、属性和事件是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”WebBr...
    99+
    2023-06-17
  • jquery ready事件的四种方法是什么
    本教程操作环境:windows7系统、jquery3.6.1版本、Dell G3电脑。jquery ready事件当 DOM(document object model 文档对象模型)加载完毕且页面完全加载(包括图像)时发生 ready 事...
    99+
    2023-05-14
    ready事件 jquery javascript
  • js的createEvent()事件方法有什么用
    `createEvent()` 方法是 JavaScript 中用于创建事件对象的方法。它通常与 `dispatchEvent()`...
    99+
    2023-10-11
    js
  • Node中的异步实现与事件驱动方法是什么
    这篇“Node中的异步实现与事件驱动方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Node中的异步实现与事件驱动方...
    99+
    2023-07-04
  • javascript失去焦点的事件方法是什么
    本篇内容主要讲解“javascript失去焦点的事件方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript失去焦点的事件方法是什么”吧!在...
    99+
    2022-10-19
  • JavaScript阻止事件冒泡的方法是什么
    本篇文章为大家展示了JavaScript阻止事件冒泡的方法是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。我们需要注意的是:事件冒泡本身的特性,会带来的坏处,也会带来的好处,在后续的博客我会详细...
    99+
    2023-06-21
  • Js冒泡事件阻止的方法是什么
    这篇文章主要介绍“Js冒泡事件阻止的方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Js冒泡事件阻止的方法是什么”文章能帮助大家解决问题。一. 事件目标现在,事件处理程序中的变量e...
    99+
    2023-06-27
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作