欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Flutter事件監(jiān)聽與EventBus事件的應用詳解

 更新時間:2023年04月13日 09:20:46   作者:iOS_Apple  
EventBus的核心是基于Streams。它允許偵聽器訂閱事件并允許發(fā)布者觸發(fā)事件,使得不同組件的數(shù)據(jù)不需要一層層傳遞,可以直接通過EventBus實現(xiàn)跨組件通訊

在Flutter中,手勢有兩個不同的層次:

第一層:原始指針事件(Pointer Events)

第二層:手勢識別(Gesture Detector)

一 指針事件 Pointer

其原理是什么?

1 在指針落下的時候,框架做了一個hit test 的操作,確定與屏幕發(fā)生接觸的位置有哪些的Widget 以及分發(fā)給最內部的組件去響應

2 事件會沿著最內部的組件向組件樹的根冒泡分發(fā)

3 并且不存在用于取消或者停止指針事件進一步分發(fā)的機制

class _EventPointerDemoPageState extends State<EventPointerDemoPage> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("事件監(jiān)聽"),
      ),
      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用戶發(fā)生手指按下的操作
onTapUp用戶發(fā)生手指抬起的操作
onTap用戶點擊事件完成
onTapCancel事件按下過程中被取消

2 雙擊

onDoubleTap快速點擊了兩次

3 長按

onLongPress在屏幕上保持了一段時間

4 縱向拖拽

onVerticalDragStart指針和屏幕產(chǎn)生接觸并可能開始縱向移動;
onVerticalDragUpdate指針和屏幕產(chǎn)生接觸,在縱向上發(fā)生移動并保持移動;
onVerticalDragEnd指針和屏幕產(chǎn)生接觸結束

5 橫向拖拽

onHorizontalDragStart指針和屏幕產(chǎn)生接觸并可能開始橫向移動;
onHorizontalDragUpdate指針和屏幕產(chǎn)生接觸,在橫向上發(fā)生移動并保持移動
onHorizontalDragEnd指針和屏幕產(chǎn)生接觸結束;

6 移動

onPanStart指針和屏幕產(chǎn)生接觸并可能開始橫向移動或者縱向移動。如果設置了 onHorizontalDragStart 或者 onVerticalDragStart,該回調方法會引發(fā)崩潰
onPanUpdate指針和屏幕產(chǎn)生接觸,在橫向或者縱向上發(fā)生移動并保持移動。如果設置了 onHorizontalDragUpdate 或者 onVerticalDragUpdate,該回調方法會引發(fā)崩潰。
onPanEnd指針先前和屏幕產(chǎn)生了接觸,并且以特定速度移動,此后不再在屏幕接觸上發(fā)生移動。如果設置了 onHorizontalDragEnd 或者 onVerticalDragEnd,該回調方法會引發(fā)崩潰。

基本使用

_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 ,從而區(qū)別不同的event

使用的是插件event_bus ,簡單 的三步走操作

1 創(chuàng)建全局的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();
    // 第三步監(jiān)聽操作
    eventBus.on<MyEventMessage>().listen((event) {
      print(event.name);
      setState(() {
        _name = event.name!;
      });
    });
  }

到此這篇關于Flutter事件監(jiān)聽與EventBus事件的應用詳解的文章就介紹到這了,更多相關Flutter事件監(jiān)聽內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Android GridView仿微信朋友圈顯示圖片

    Android GridView仿微信朋友圈顯示圖片

    這篇文章主要介紹了Android GridView仿微信朋友圈顯示圖片,上傳多圖并且多圖顯示,GridView可以動態(tài)加載圖片的數(shù)量,感興趣的小伙伴們可以參考一下
    2016-01-01
  • 詳解Android中App的啟動界面Splash的編寫方法

    詳解Android中App的啟動界面Splash的編寫方法

    這篇文章主要介紹了Android中App的啟動界面Splash的編寫方法,需要的朋友可以參考下
    2016-02-02
  • Android調用前后攝像頭同時工作實例代碼

    Android調用前后攝像頭同時工作實例代碼

    本篇文章主要介紹了Android調用前后攝像頭同時工作實例代碼,這里整理了詳細的代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-07-07
  • Android創(chuàng)建外部lib庫及自定義View的圖文教程

    Android創(chuàng)建外部lib庫及自定義View的圖文教程

    這篇文章主要給大家介紹了關于Android創(chuàng)建外部lib庫及自定義View的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-11-11
  • Android垂直切換的圓角Banner與垂直指示器相關介紹與應用詳解

    Android垂直切換的圓角Banner與垂直指示器相關介紹與應用詳解

    這篇文章主要介紹了Android垂直切換的圓角Banner與垂直指示器相關介紹與應用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-10-10
  • 深入學習Kotlin?枚舉的簡潔又高效進階用法

    深入學習Kotlin?枚舉的簡潔又高效進階用法

    這篇文章主要為大家介紹了深入學習Kotlin?枚舉簡潔又高效的進階用法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • Android應用實踐之數(shù)獨游戲開發(fā)

    Android應用實踐之數(shù)獨游戲開發(fā)

    這篇文章主要為大家詳細介紹了Android應用實踐之數(shù)獨游戲開發(fā),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • android編程之XML文件解析方法詳解(附源碼)

    android編程之XML文件解析方法詳解(附源碼)

    這篇文章主要介紹了android編程之XML文件解析方法,結合實例形式較為詳細的分析了Android解析XML文件的sax、pull及Dom三種方法,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-11-11
  • Andriod 獲取電池的信息實例代碼

    Andriod 獲取電池的信息實例代碼

    通過本段實例代碼給大家介紹Andriod 獲取電池的信息的相關知識,對android獲取電池信息相關知識感興趣的朋友一起學習吧
    2016-03-03
  • Android仿微信和QQ多圖合并框架(類似群頭像)的實現(xiàn)方法

    Android仿微信和QQ多圖合并框架(類似群頭像)的實現(xiàn)方法

    這篇文章主要給大家介紹了關于Android仿微信和QQ多圖合并框架的相關資料,其實就是我們平時所見的群聊頭像,文中通過示例代碼介紹的非常詳細,對各位Android開發(fā)者們具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-12-12

最新評論