HarmonyOS4.0系统性深入开发18公共事件简介

这篇具有很好参考价值的文章主要介绍了HarmonyOS4.0系统性深入开发18公共事件简介。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

公共事件简介

HarmonyOS通过CES(Common Event Service,公共事件服务)为应用程序提供订阅、发布、退订公共事件的能力。

公共事件从系统角度可分为:系统公共事件和自定义公共事件。

  • 系统公共事件:CES内部定义的公共事件,只有系统应用和系统服务才能发布,例如HAP安装,更新,卸载等公共事件。目前支持的系统公共事件详见系统公共事件列表。
  • 自定义公共事件:应用自定义一些公共事件用来实现跨进程的事件通信能力。

公共事件按发送方式可分为:无序公共事件、有序公共事件和粘性公共事件。

  • 无序公共事件:CES转发公共事件时,不考虑订阅者是否接收到,且订阅者接收到的顺序与其订阅顺序无关。
  • 有序公共事件:CES转发公共事件时,根据订阅者设置的优先级等级,优先将公共事件发送给优先级较高的订阅者,等待其成功接收该公共事件之后再将事件发送给优先级较低的订阅者。如果有多个订阅者具有相同的优先级,则他们将随机接收到公共事件。
  • 粘性公共事件:能够让订阅者收到在订阅前已经发送的公共事件就是粘性公共事件。普通的公共事件只能在订阅后发送才能收到,而粘性公共事件的特殊性就是可以先发送后订阅。发送粘性事件必须是系统应用或系统服务,且需要申请ohos.permission.COMMONEVENT_STICKY权限,配置方式请参阅访问控制授权申请指导。

每个应用都可以按需订阅公共事件,订阅成功,当公共事件发布时,系统会将其发送给对应的应用。这些公共事件可能来自系统、其他应用和应用自身。

图1 公共事件示意图

HarmonyOS4.0系统性深入开发18公共事件简介,HarmonyOS4.0系统性深入开发,harmonyos,开发语言,鸿蒙系统,intellij idea,鸿蒙

公共事件订阅概述

公共事件服务提供了动态订阅和静态订阅两种订阅方式。动态订阅与静态订阅最大的区别在于,动态订阅是应用运行时行为,而静态订阅是后台服务无需处于运行状态。

  • 动态订阅:指订阅方在运行时调用公共事件订阅的API实现对公共事件的订阅,详见动态订阅公共事件。
  • 静态订阅:订阅方通过配置文件声明和实现继承自StaticSubscriberExtensionAbility的类实现对公共事件的订阅,详见静态订阅公共事件。

动态订阅公共事件

场景介绍

动态订阅是指当应用在运行状态时对某个公共事件进行订阅,在运行期间如果有订阅的事件发布那么订阅了这个事件的应用将会收到该事件及其传递的参数。例如,某应用希望在其运行期间收到电量过低的事件,并根据该事件降低其运行功耗,那么该应用便可动态订阅电量过低事件,收到该事件后关闭一些非必要的任务来降低功耗。订阅部分系统公共事件需要先申请权限,订阅这些事件所需要的权限请见公共事件权限列表。

接口说明

详细接口见接口文档。

接口名 接口描述
createSubscriber(subscribeInfo: CommonEventSubscribeInfo, callback: AsyncCallback<CommonEventData>): void 创建订阅者对象(callback)
createSubscriber(subscribeInfo: CommonEventSubscribeInfo): Promise 创建订阅者对象(promise)
subscribe(subscriber: CommonEventSubscriber, callback: AsyncCallback): void 订阅公共事件

开发步骤

  1. 导入CommonEvent模块。

    import commonEvent from '@ohos.commonEventManager';
    
  2. 创建订阅者信息,详细的订阅者信息数据类型及包含的参数请见CommonEventSubscribeInfo文档介绍。

    // 用于保存创建成功的订阅者对象,后续使用其完成订阅及退订的动作
    let subscriber = null;
    // 订阅者信息
    let subscribeInfo = {
        events: ["usual.event.SCREEN_OFF"], // 订阅灭屏公共事件
    }
    
  3. 创建订阅者,保存返回的订阅者对象subscriber,用于执行后续的订阅、退订等操作。

    // 创建订阅者回调
    commonEvent.createSubscriber(subscribeInfo, (err, data) => {
        if (err) {
            console.error(`[CommonEvent] CreateSubscriberCallBack err=${JSON.stringify(err)}`);
        } else {
            console.info(`[CommonEvent] CreateSubscriber success`);
            subscriber = data;
            // 订阅公共事件回调
        }
    })
    
  4. 创建订阅回调函数,订阅回调函数会在接收到事件时触发。订阅回调函数返回的data内包含了公共事件的名称、发布者携带的数据等信息,公共事件数据的详细参数和数据类型请见CommonEventData文档介绍。

    // 订阅公共事件回调
    if (subscriber !== null) {
        commonEvent.subscribe(subscriber, (err, data) => {
            if (err) {
                console.error(`[CommonEvent] SubscribeCallBack err=${JSON.stringify(err)}`);
            } else {
                console.info(`[CommonEvent] SubscribeCallBack data=${JSON.stringify(data)}`);
            }
        })
    } else {
        console.error(`[CommonEvent] Need create subscriber`);
    }
    

静态订阅公共事件(仅对系统应用开放)

场景介绍

静态订阅者在未接收订阅的目标事件时,处于未拉起状态,当系统或应用发布了指定的公共事件后,静态订阅者将被拉起,并执行onReceiveEvent回调,开发者可通过在onReceiveEvent回调中执行业务逻辑,实现当应用接收到特定公共事件时执行业务逻辑的目的。例如,某应用希望在设备开机的时候执行一些初始化任务,那么该应用可以静态订阅开机事件,在收到开机事件后会拉起该应用,然后执行初始化任务。静态订阅是通过配置文件声明和实现继承自StaticSubscriberExtensionAbility的类实现对公共事件的订阅。需要注意的是,静态订阅公共事件对系统功耗有一定影响,建议谨慎使用

开发步骤

  1. 静态订阅者声明

    声明一个静态订阅者,首先需要在工程中新建一个ExtensionAbility, 该ExtensionAbility从StaticSubscriberExtensionAbility派生,其代码实现如下:

    import StaticSubscriberExtensionAbility from '@ohos.application.StaticSubscriberExtensionAbility'
    
    export default class StaticSubscriber extends StaticSubscriberExtensionAbility {
        onReceiveEvent(event) {
            console.log('onReceiveEvent, event:' + event.event);
        }
    }
    

    开发者可以在onReceiveEvent中实现业务逻辑。

  2. 静态订阅者工程配置

    在完成静态订阅者的代码实现后,需要将该订阅者配置到系统的module.json5中,配置形式如下:

    {
      "module": {
        ......
        "extensionAbilities": [
          {
            "name": "StaticSubscriber",
            "srcEntrance": "./ets/StaticSubscriber/StaticSubscriber.ts",
            "description": "$string:StaticSubscriber_desc",
            "icon": "$media:icon",
            "label": "$string:StaticSubscriber_label",
            "type": "staticSubscriber",
            "visible": true,
            "metadata": [
              {
                "name": "ohos.extension.staticSubscriber",
                "resource": "$profile:subscribe"
              }
            ]
          }
        ]
        ......
      }
    }
    

    上述json文件主要关注以下字段:

    • srcEntrance : 表示ExtensionAbility的入口文件路径,即步骤2中声明的静态订阅者所在的文件路径
    • type: 表示ExtensionAbility的类型,对于静态订阅者需要声明为“staticSubscriber”
    • metadata: 表示ExtensionAbility的二级配置文件信息。由于不同的ExtensionAbility类型其配置信息不尽相同,因此需要使用不同的config文件表示其具体配置信息。
      • name:表示ExtensionAbility的类型名称,对于静态订阅类型,name必须声明为“ohos.extension.staticSubscriber”,否则无法识别为静态订阅者;
      • resource: 字段表示ExtensionAbility的配置信息路径,由开发者自行定义,在本例中表示路径为“resources/base/profile/subscribe.json"。

    metadata指向的二级配置文件的通常形式如下:

    {
      "commonEvents": [
        {
          "name": "xxx",
          "permission": "xxx",
          "events":[
            "xxx"
          ]
        }
      ]
    }
    

    需要注意二级配置文件必须按照此形式进行声明,否则会无法正确识别。下面对字段进行介绍:

    • name: 静态订阅ExtensionAbility的名称,需要和module.json5中声明的ExtensionAbility的name一致
    • permission:订阅者要求的发布者需要具备的权限,对于发布了目标事件但不具备permission中声明的权限的发布者将被视为非法事件不予发布
    • events: 订阅的目标事件列表
  3. 修改设备系统配置文件

    修改设备系统配置文件 /etc/static_subscriber_config.json,将静态订阅应用者的包名添加至该json文件中即可。

    {
        "xxx",
        "ohos.extension.staticSubscriber",
        "xxx"
    }
    

取消动态订阅公共事件

场景介绍

动态订阅者完成业务需要时,需要主动取消订阅,订阅者通过调用unsubscribe()方法取消订阅事件。

接口说明

接口名 接口描述
unsubscribe(subscriber: CommonEventSubscriber, callback?: AsyncCallback) 取消订阅公共事件

开发步骤

  1. 导入CommonEvent模块。

    import commonEvent from '@ohos.commonEventManager';
    
  2. 根据动态订阅公共事件章节的步骤来订阅某个事件。

  3. 调用CommonEvent中的unsubscribe方法取消订阅某事件。

    // subscriber为订阅事件时创建的订阅者对象
    if (subscriber !== null) {
        commonEvent.unsubscribe(subscriber, (err) => {
            if (err) {
                console.error(`[CommonEvent] UnsubscribeCallBack err=${JSON.stringify(err)}`)
            } else {
                console.info(`[CommonEvent] Unsubscribe`)
                subscriber = null
            }
        })
    }
    

公共事件发布

场景介绍

当需要发布某个自定义公共事件时,可以通过publish()方法发布事件。发布的公共事件可以携带数据,供订阅者解析并进行下一步处理。

注意

已发出的粘性公共事件后来订阅者也可以接收到,其他公共事件都需要先订阅再接收,订阅参考公共事件订阅章节。

接口说明

详细接口见接口文档。

接口名 接口描述
publish(event: string, callback: AsyncCallback) 发布公共事件。
publish(event: string, options: CommonEventPublishData, callback: AsyncCallback) 指定发布信息并发布公共事件。

发布不携带信息的公共事件

不携带信息的公共事件,只能发布无序公共事件。

  1. 导入CommonEvent模块。

    import commonEvent from '@ohos.commonEventManager';
    
  2. 传入需要发布的事件名称和回调函数,发布事件。

    // 发布公共事件
    commonEvent.publish("usual.event.SCREEN_OFF", (err) => {
        if (err) {
            console.error(`[CommonEvent] PublishCallBack err=${JSON.stringify(err)}`);
        } else {
            console.info(`[CommonEvent] Publish success`);
        }
    })
    

发布携带信息的公共事件

携带信息的公共事件,可以发布为无序公共事件、有序公共事件和粘性事件,可以通过参数CommonEventPublishData的isOrdered、isSticky的字段进行设置。

  1. 导入CommonEvent模块。

    import commonEvent from '@ohos.commonEventManager';
    
  2. 传入需要发布的事件名称和回调函数,发布事件。

    // 公共事件相关信息
    let options = {
        code: 1, // 公共事件的初始代码
        data: "initial data", // 公共事件的初始数据
    }
    
  3. 传入需要发布的事件名称、需要发布的指定信息和回调函数,发布事件。文章来源地址https://www.toymoban.com/news/detail-787332.html

    // 发布公共事件
    commonEvent.publish("usual.event.SCREEN_OFF", options, (err) => {
        if (err) {
            console.error('[CommonEvent] PublishCallBack err=' + JSON.stringify(err));
        } else {
            console.info('[CommonEvent] Publish success')
        }
    })
    

到了这里,关于HarmonyOS4.0系统性深入开发18公共事件简介的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • HarmonyOS4.0系统性深入开发34栅格布局(GridRow/GridCol)

    栅格布局是一种通用的辅助定位工具,对移动设备的界面设计有较好的借鉴作用。主要优势包括: 提供可循的规律:栅格布局可以为布局提供规律性的结构,解决多尺寸多设备的动态布局问题。通过将页面划分为等宽的列数和行数,可以方便地对页面元素进行定位和排版。

    2024年02月21日
    浏览(51)
  • 系统性认知网络安全

    前言: 本文旨在介绍网络安全相关基础知识体系和框架 目录 一.信息安全概述 信息安全研究内容及关系  信息安全的基本要求 保密性Confidentiality: 完整性Integrity: 可用性Availability: 二.信息安全的发展 20世纪60年代: 20世纪60-70年代: 20世纪90年代以后: 三.网络安全的攻防

    2024年02月08日
    浏览(44)
  • 【系统性】 循序渐进学C++

    一、环境配置 1.1.第一个程序(基本格式) ​ ​ 模板 1.2注释 1.3变量 ​ 意义:方便管理内存空间 ​ 方法:数据类型 变量名 = 数字; 1.4常量 1.5 1.6变量命名规则 二、数据类型 ​ 目的:给数据存分配合适的空间大小;避免资源浪费 2.1整形 ​ 2.2 sizeof 2.3浮点型 ​ fl

    2024年03月18日
    浏览(66)
  • 【基础类】—面向对象类系统性学习

    构造函数模拟一个类 ES6 Class声明 通过 new 实例化一个类 借助构造函数实现继承 缺点: Parent1的原型上的属性和方法,并没有被child所继承。 总结:只实现了部分继承,如果父类的属性都在构造函数里面,完全可以实现继承,如果父类的原型对象上还有方法或属性,那么子类

    2024年02月14日
    浏览(46)
  • 如何系统性的学习Python语言

    零基础同学的福音来了,如果你对Python语言的学习感兴趣,接下来可以由浅入深的了解下Python语言,哪怕你是零基础的小白也完全可以学会的,最后也会给大家放出学习和实例相结合的教程及方法,给到各位同学系统性的教学,最重要的是免费,可真谓是学生党们的福音呀。

    2024年02月10日
    浏览(45)
  • linux与windows系统性能测试

    # 一、Linux系统下的性能测试 ##### 可通过以下命令进行安装。 ##### 如果您使用CentOS、Redhat、Aliyun Linux等操作系统,运行以下命令     sudo yum install fio ##### 如果您使用Ubuntu或Debian操作系统,运行以下命令     sudo apt-get  update     sudo apt-get install fio ##### 下面提供一些通用的性能

    2024年04月17日
    浏览(46)
  • 【基础类】—前后端通信类系统性学习

    同源策略限制从一个源加载的文档或脚本如何与来自另一个源的资源进行交互。这是一个用于隔离潜在恶意文件的关键的安全机制。 源:协议、域名和端口, 默认端口是80 三者有一个不同,即源不同,就是跨域 限制:不是一个源的文档,你没有权利去操作另一个源的文档,

    2024年02月13日
    浏览(38)
  • 金融——规避容易造成金融系统性风险的项目

    金融的关联性太强,容易造成很多社会问题, 改变,必须建立在有效规避风险之上 答: 答: 答:我暂时认为,他们都是未来。信用系统是一个美好的愿望,就像五六十年代理想的共产主义一样,要走的路还是很远,我个人是希望遥远的将来能够实现,那是多么美丽的未来,

    2024年01月20日
    浏览(57)
  • 系统性学习vue-组件及脚手架

    书接上文 Vue脚手架是Vue官方提供的标准化开发工具(开发平台) CLI: command line interface (命令行接口工具) 俗称脚手架 备注: 如果下载缓慢可以配置npm淘宝镜像: npm config set registry https://registry.npm.taobao.org Vue脚手架隐藏了所有webpack相关配置,弱项查看具体的webpack配置,请执行 vue ins

    2024年02月02日
    浏览(47)
  • 初识C语言——详细入门(系统性学习day4)

    目录 前言 一、C语言简单介绍、特点、基本构成 简单介绍: 特点: 基本构成: 二、认识C语言程序 标准格式: 简单C程序: 三、基本构成分类详细介绍    (1) (2)数据类型 计算机中常用存储单位 数据类型的取值范围 打印输入类型 (3)常量和变量 常量的分类:

    2024年02月08日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包