0
点赞
收藏
分享

微信扫一扫

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

boom莎卡拉卡 2024-12-02 阅读 2

一、Emitter的开发步骤如下:

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')
});
// 定义一个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

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%')
  }
}
举报

相关推荐

0 条评论