鸿蒙:使用Emitter进行线程间通信

前言:

官方文档上说,Emitter是一种作用在进程内的事件处理机制,为应用程序提供订阅事件、发布事件、取消事件订阅的能力。

我们学习这个工具之前,还是老样子,照着官方文档和示例学习与实践,文档链接如下:

文档中心https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/itc-with-emitter如果您看完了,但还有点迷糊,不妨看看我是怎么封装这个工具的。

下面是我运行的实际效果图和封装后的代码:

Index.ets

复制代码
import { emitterUtil } from "./EmitterUtil"

// emitter使用示例
@Entry
@Component
export struct Index {
  build() {
    Column({ space: 20 }) {
      Button("emitter.fire")
        .onClick(() => {
          emitterUtil.fire()

        })

      Button("emitter.on")
        .onClick(() => {
          emitterUtil.on()

        })

      Button("emitter.off")
        .onClick(() => {
          emitterUtil.off()

        })
    }
    .width("100%")
    .height("100%")
    .justifyContent(FlexAlign.Center)
    .alignItems(HorizontalAlign.Center)

  }
}
复制代码
EmitterUtil.ets
复制代码
import { emitter } from '@kit.BasicServicesKit';
import { promptAction } from '@kit.ArkUI';

class EmitterUtil {
  id: number = 1;

  // 订阅事件
  on() {
    // 定义一个eventId为1的事件。
    let event: emitter.InnerEvent = {
      eventId: 1
    };
    // 定义一个事件的回调处理函数,当收到对应的事件后执行回调函数
    let callback: Callback<emitter.EventData> = (eventData: emitter.EventData) => {
      console.info(`eventData:接收成功 ${JSON.stringify(eventData)}`);
    }

    // 收到eventId为1的事件后执行回调函数
    emitter.on(event, callback);

    // 订阅成功
    promptAction.showToast({ message: "订阅成功!" })
  }

  // 发送事件
  fire() {
    this.id = this.id + 1;
    // 定义一个eventId为1的事件,事件优先级为Low。
    let event: emitter.InnerEvent = {
      eventId: 1,
      priority: emitter.EventPriority.LOW
    };

    let eventData: emitter.EventData = {
      data: {
        content: 'emitter',
        id: this.id,
        isEmpty: false
      }
    };

    // 发送eventId为1的事件,事件内容为eventData。
    emitter.emit(event, eventData);
    promptAction.showToast({ message: "发送成功!id是" + this.id })

  }

  // 取消事件
  off() {
    // 取消eventId为1的事件。
    emitter.off(1);
    promptAction.showToast({ message: "取消成功!" })
  }
}

export const emitterUtil = new EmitterUtil();

以上是个人经验分享

相关推荐
大雷神4 分钟前
第25篇|Surface 预览控制:ArkUI 页面如何接住相机画面
harmonyos
大雷神27 分钟前
第24篇|相机权限和设备枚举:先判断能力再打开预览
harmonyos
川石课堂软件测试35 分钟前
使用mock进行接口测试教程
数据库·python·功能测试·测试工具·华为·单元测试·appium
Goway_Hui40 分钟前
【鸿蒙原生应用开发--ArkUI--003】TodoApp - 待办事项应用教程
华为·harmonyos
想你依然心痛44 分钟前
HarmonyOS 6(API 23)智能体驱动的沉浸式AR航天器装配工坊
华为·ar·harmonyos·智能体
不羁的木木1 小时前
HarmonyOS文件基础服务(Core File Kit)实战演练05-实战:文件管理工具开发
华为·harmonyos
Goway_Hui1 小时前
【鸿蒙原生应用开发--ArkUI--007】TimerApp - 计时器应用教程
华为·harmonyos
nashane1 小时前
HarmonyOS 6学习:保存图片预览空白?沙箱路径转URI的“视觉修复”术
学习·华为·harmonyos
芒鸽1 小时前
HarmonyOS ArkTS 状态管理深度解析:@State、@Prop、@Link、@Provide/@Consume 实战指南
华为·harmonyos·arkts·状态管理
大雷神2 小时前
HarmonyOS APP<玩转React>开源教程三十一:示例项目下载功能
react.js·开源·harmonyos