HarmonyOS:使用Emitter进行线程间通信

Emitter主要提供线程间发送和处理事件的能力,包括对持续订阅事件或单次订阅事件的处理、取消订阅事件、发送事件到事件队列等。

一、Emitter的开发步骤如下:

  1. 订阅事件
复制代码
import { emitter } from '@kit.BasicServicesKit';
import { promptAction } from '@kit.ArkUI';
import { hilog } from '@kit.PerformanceAnalysisKit';

const TAG: string = 'ThreadModel';
const DOMAIN_NUMBER: number = 0xFF00;

// 定义一个eventId为1的事件
let event: emitter.InnerEvent = {
  eventId: 1
};

// 收到eventId为1的事件后执行该回调
let callback = (eventData: emitter.EventData): void => {
  promptAction.showToast({
    message: JSON.stringify(eventData)
  });
  hilog.info(DOMAIN_NUMBER, TAG, 'event callback:' + JSON.stringify(eventData));
};

// 订阅eventId为1的事件
emitter.on(event, callback);
promptAction.showToast({
  message: JSON.stringify('emitter subscribe success')
});
  1. 发送事件
复制代码
// 定义一个eventId为1的事件,事件优先级为Low
let event: emitter.InnerEvent = {
  eventId: 1,
  priority: emitter.EventPriority.LOW
};

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

// 发送eventId为1的事件,事件内容为eventData
emitter.emit(event, eventData);

二、示例效果图

订阅事件


发送事件


三、示例完整代码

TestEmitter.ets

bash 复制代码
import { emitter } from '@kit.BasicServicesKit';
import { promptAction } from '@kit.ArkUI';
import { hilog } from '@kit.PerformanceAnalysisKit';

const TAG: string = 'ThreadModel';
const DOMAIN_NUMBER: number = 0xFF00;

function subEvent() {
  // 定义一个eventId为1的事件
  let event: emitter.InnerEvent = {
    eventId: 1
  };

  // 收到eventId为1的事件后执行该回调
  let callback = (eventData: emitter.EventData): void => {
    promptAction.showToast({
      message: JSON.stringify(eventData)
    });
    hilog.info(DOMAIN_NUMBER, TAG, 'event callback:' + JSON.stringify(eventData));
  };

  // 订阅eventId为1的事件
  emitter.on(event, callback);
  promptAction.showToast({
    message: JSON.stringify('emitter subscribe success')
  });
}

function sendEvent() {
  // 定义一个eventId为1的事件,事件优先级为Low
  let event: emitter.InnerEvent = {
    eventId: 1,
    priority: emitter.EventPriority.LOW
  };

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

  // 发送eventId为1的事件,事件内容为eventData
  emitter.emit(event, eventData);
}


@Entry
@Component
struct TestEmitter {
  @State message: string = 'Hello World';
  private hadSubEvent: boolean = false;

  build() {
    Column() {
      Button('订阅事件')
        .fontColor(Color.Black)
        .fontWeight(FontWeight.Normal)
        .fontSize(16)
        .margin({ top: 20 })
        .onClick((event: ClickEvent) => {
          this.hadSubEvent = true;
          subEvent()
        })
      Button('发送事件')
        .fontColor(Color.Black)
        .fontWeight(FontWeight.Normal)
        .fontSize(16)
        .margin({ top: 20 })
        .onClick((event: ClickEvent) => {
          if (this.hadSubEvent) {
            sendEvent()
            return
          } else {
            promptAction.showToast({ message: "请点击订阅事件,再发送事件" })
          }
        })

    }
    .height('100%')
    .width('100%')
  }
}
相关推荐
HarmonyOS_SDK6 小时前
Account Kit(华为账号服务)再进化,开发者接入效率飙升!
harmonyos
whysqwhw13 小时前
鸿蒙 任意类型转字符串
harmonyos
程序员潘Sir15 小时前
鸿蒙应用开发从入门到实战(八):ArkTS自定义组件语法
harmonyos·鸿蒙
高心星1 天前
鸿蒙5.0应用开发——V2装饰器@Provider和@Consumer的使用
harmonyos
ChinaDragon1 天前
HarmonyOS:ArkTS卡片页面刷新
harmonyos
HMSCore2 天前
通知语音播报功能,解锁全新体验
harmonyos
HarmonyOS_SDK2 天前
通知语音播报功能,解锁全新体验
harmonyos
高心星2 天前
鸿蒙5.0应用开发——V2装饰器@ObservedV2和@Trace的使用
harmonyos