HarmonyOS开发实例:【事件的订阅和发布】

embedded/2024/10/19 15:44:10/

介绍

本示例主要展示了公共事件相关的功能,实现了一个检测用户部分行为的应用。具体而言实现了如下几点功能:

1.通过订阅系统公共事件,实现对用户操作行为(亮灭屏、锁屏和解锁屏幕、断联网)的监测;

2.通过在用户主动停止监测行为时发布自定义有序公共事件,实现对用户主动触发监听行为的持久化记录;

3.通过在用户设置对某一事件的监听状态时发布粘性事件,记录下本次应用运行期间允许监听的事件列表,同时在应用退出时将临时允许的修改为不允许;

4.打开自定义订阅事件页面需先安装[CardEvent]应用,通过订阅指定应用事件,实现用户对指定卡片发送事件的监听。

效果预览

订阅系统公共事件,主动停止监听行为及对某一事件的监听状态时发布粘性事件

image.png

使用说明:鸿蒙开发文档参考了gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md点击或者复制转到即可。

1.安装编译生成的hap包,依赖包hap,桌面上显示应用图标如下,点击图标即可进入应用。

image.png

2.进入应用显示菜单页,可选择“进入”,“历史”,“设置”及“关于”几个选项。

3.点击“进入”后跳转至主页面,点击主页面“开始监控”按钮,将开始监听系统公共事件,并进行计时,此时按钮内容变更为“停止监听”;点击停止监听按钮,页面上将显示本次监听时长及监听期间收到的干扰信息汇总,并在页面右下角显示“查看详情”按钮,点击按钮将跳转至详情页,显示监听期间收到的干扰信息,应用当前仅监听了亮灭屏、锁屏和解锁屏幕、断联网等用户可操作的系统公共事件,后续可根据需求快速扩展。

4.返回至应用菜单页面,点击“历史”可查看用户操作监听的历史记录,当前支持每次运行期间最多存储10条历史记录,超过10条后将删除历史数据。

5.返回至应用菜单页面,点击“设置”可进行具体系统事件的监听配置,应用提供了“一直”、“仅本次”及“从不”三个选项,其中“仅本次”选项是指本次应用运行期间将监听特定系统公共事件,应用退出后该选项将自动调整为“从不”。

6.在设置页面,点击“自定义事件定向订阅”进入订阅页面,

  • 点击”订阅“按钮进行订阅事件,同时订阅指定本应用事件和订阅非指定应用事件。
  • 点击应用内卡片发送事件或点击应用外卡片发送事件。
  • 点击应用内卡片发送事件后,指定应用事件和非指定应用事件均会接收到卡片所发送的事件 ;点击应用外卡片发送事件后,非指定应用事件会被接收,指定应用事件不会被接收。
  • 点击”取消订阅“ 页面中会提示当前事件取消订阅。

7.返回至应用菜单页面,点击“关于”可查看应用版本信息及本示例的说明。

搜狗高速浏览器截图20240326151547.png

代码解读

CustomCommonEvent

HarmonyOS与OpenHarmony开发文档+mau123789是v直接拿取
entry/src/main/ets/
|---Application
|   |---MyAbilityStage.ts                    
|---component
|   |---Header.ets                           // 头部组件
|---entryformability
|   |---EntryFormAbility.ts                  // 卡片提供方  
|---feature
|   |---HistoryFeature.ts                    
|   |---LaunchFeature.ts                    
|   |---MainFeature.ts                    
|   |---SettingFeature.ts                    
|---LauncherAbility 
|   |---LauncherAbility.ts
|---MainAbility
|   |---MainAbility.ts
|---model
|   |---Consts.ts                            // 数据定义
|   |---Logger.ts                            // 日志打印  
|   |---SurveillanceEventsManager.ts         // 公共事件模块
|   |---Utils.ts                        
|---pages
|   |---About.ets                            // 关于页面
|   |---Detail.ets                           // 详情页面
|   |---History.ets                          // 历史页面
|   |---jumpToCommonEvent.ets                // 自定义订阅事件页面
|   |---Launch.ets                           // 发起页面
|   |---Main.ets                             // 进入页面
|   |---Setting.ets                          // 设置页面
|---publishcard
|   |---pages
|   |	|---PublishCard.ets              	 // 卡片页面

CustomCommonEventRely

entry/src/main/ets/
|---entryformability
|   |---EntryFormAbility.ts					// 发布事件
|---pages
|   |---Index.ets
|---widget
|   |---pages
|   |	|---PublishCard.ets 				// 发布事件的卡片

具体实现

  • 该示例entry部分分为五个模块:

    • 进入模块

      • 使用到应用文上下文,createSubscriber方法创建订阅者,getCurrentTime获取获取自Unix纪元以来经过的时间进行对用户操作行为的监测功能页面开发。
  • 源码链接:[Consts.ts]

/** Copyright (c) 2022-2023 Huawei Device Co., Ltd.* Licensed under the Apache License, Version 2.0 (the "License");* you may not use this file except in compliance with the License.* You may obtain a copy of the License at**     http://www.apache.org/licenses/LICENSE-2.0** Unless required by applicable law or agreed to in writing, software* distributed under the License is distributed on an "AS IS" BASIS,* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.* See the License for the specific language governing permissions and* limitations under the License.*/import commonEvent from '@ohos.commonEventManager';export default class consts {// definition for databasestatic readonly DATA_BASE_NAME: string = "nothing_pre";static readonly DATA_BASE_KEY_TOTAL_TIMES: string = "totalTimes";static readonly DATA_BASE_KEY_START_TIME: string = "startTime";static readonly DATA_BASE_KEY_WIFI_POWER_STATE: string = commonEvent.Support.COMMON_EVENT_WIFI_POWER_STATE;static readonly DATA_BASE_KEY_SCREEN_OFF: string = commonEvent.Support.COMMON_EVENT_SCREEN_OFF;static readonly DATA_BASE_KEY_SCREEN_ON: string = commonEvent.Support.COMMON_EVENT_SCREEN_ON;static readonly DATA_BASE_KEY_SCREEN_LOCKED: string = commonEvent.Support.COMMON_EVENT_SCREEN_LOCKED;static readonly DATA_BASE_KEY_SCREEN_UNLOCKED: string = commonEvent.Support.COMMON_EVENT_SCREEN_UNLOCKED;static readonly DATA_BASE_KEY_ONCE_EVENTS: string = "onceCall";static readonly DATA_BASE_KEY_NEVER_EVENTS: string = "neverCall";// definition for event enable statestatic readonly ENABLE_STATE_ALWAYS : number = 0static readonly ENABLE_STATE_ONCE : number = 1static readonly ENABLE_STATE_NEVER : number = 2// definition for record volumestatic readonly MAX_RECORD_NUM: number = 10;// definition for self defined common eventsstatic readonly COMMON_EVENT_FINISH_MEDITATION: string = "finish_meditation"static readonly COMMON_EVENT_SETTING_UPDATE: string = "setting_update"}

[LaunchFeature.ts]

/** Copyright (c) 2024 Huawei Device Co., Ltd.* Licensed under the Apache License, Version 2.0 (the "License");* you may not use this file except in compliance with the License.* You may obtain a copy of the License at**     http://www.apache.org/licenses/LICENSE-2.0** Unless required by applicable law or agreed to in writing, software* distributed under the License is distributed on an "AS IS" BASIS,* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.* See the License for the specific language governing permissions and* limitations under the License.*/import common from '@ohos.app.ability.common';import commonEvent from '@ohos.commonEventManager';import dataPreferences from '@ohos.data.preferences';import Want from '@ohos.app.ability.Want';import router from '@ohos.router';import consts from '../module/Consts';import Logger from '../module/Logger';export default class LaunchFeature {private innerContext: common.UIAbilityContext = null;private pref: dataPreferences.Preferences = null;private subscriber = null;private subscriberLow = null;private currentRecordTimes: number = 0;constructor(abilityContext: common.UIAbilityContext) {this.innerContext = abilityContext;}async init(): Promise<void> {await dataPreferences.getPreferences(this.innerContext, consts.DATA_BASE_NAME).then((pref) => {this.pref = pref;});await this.pref.get(consts.DATA_BASE_KEY_WIFI_POWER_STATE, 0).then((value: number) => {globalThis.settings.set(commonEvent.Support.COMMON_EVENT_WIFI_POWER_STATE, value);});await this.pref.get(consts.DATA_BASE_KEY_SCREEN_OFF, 0).then((value1: number) => {globalThis.settings.set(commonEvent.Support.COMMON_EVENT_SCREEN_OFF, value1);});await this.pref.get(consts.DATA_BASE_KEY_SCREEN_ON, 0).then((value2: number) => {globalThis.settings.set(commonEvent.Support.COMMON_EVENT_SCREEN_ON, value2);});await this.pref.get(consts.DATA_BASE_KEY_SCREEN_LOCKED, 0).then((value3: number) => {globalThis.settings.set(commonEvent.Support.COMMON_EVENT_SCREEN_LOCKED, value3);});await this.pref.get(consts.DATA_BASE_KEY_SCREEN_UNLOCKED, 0).then((value4: number) => {globalThis.settings.set(commonEvent.Support.COMMON_EVENT_SCREEN_UNLOCKED, value4);});}private insertRecord = (event, value) => {value.push(event.parameters[consts.DATA_BASE_KEY_START_TIME]);// refresh databasethis.pref.put(consts.DATA_BASE_KEY_TOTAL_TIMES, value).then(() => {let detail: Array<string> = [];detail.push(event.parameters["startTime"]);detail.push(event.parameters["endTime"]);detail.push(event.parameters["totalTime"]);detail.push(event.parameters["totalEvents"]);this.pref.put(event.parameters[consts.DATA_BASE_KEY_START_TIME], detail).then(() => {this.pref.flush()})});}private callbackFunc = (error, event) => {this.pref.has(consts.DATA_BASE_KEY_TOTAL_TIMES, (err, ret) => {if (ret) {this.pref.get(consts.DATA_BASE_KEY_TOTAL_TIMES, []).then((value) => {this.insertRecord(event, value);});} else {let value: Array<string> = [];this.insertRecord(event, value);}if (this.currentRecordTimes >= consts.MAX_RECORD_NUM) {this.subscriber.finishCommonEvent();return;}this.subscriber.abortCommonEvent();this.subscriber.finishCommonEvent();this.currentRecordTimes++;})}private callbackLowFunc = (error, event) => {this.currentRecordTimes = 1;this.pref.get(consts.DATA_BASE_KEY_TOTAL_TIMES, []).then((value: Array<string>) => {for (let i = 0; i < consts.MAX_RECORD_NUM; i++) {this.pref.delete(value[i]).then(() => {this.pref.flush();this.subscriberLow.finishCommonEvent();})}let records = value.slice(consts.MAX_RECORD_NUM, consts.MAX_RECORD_NUM + 1);this.pref.put(consts.DATA_BASE_KEY_TOTAL_TIMES, records);this.pref.flush();})}jumpToStart = () => {// subscribeif (this.subscriber == null) {let highSubscriberInfo = {events: [consts.COMMON_EVENT_FINISH_MEDITATION // unordered self defined event],priority: 2 // 2 indicates high priority subscriber};commonEvent.createSubscriber(highSubscriberInfo, (err, subscriber) => {this.subscriber = subscriberif (subscriber != null) {commonEvent.subscribe(subscriber, this.callbackFunc)}});}// subscribeif (this.subscriberLow == null) {let lowSubscriberInfo = {events: [consts.COMMON_EVENT_FINISH_MEDITATION // unordered self defined event],priority: 1 // 1 indicates low priority subscriber};commonEvent.createSubscriber(lowSubscriberInfo, (updaerr, subscriber) => {this.subscriberLow = subscriberif (subscriber != null) {commonEvent.subscribe(subscriber, this.callbackLowFunc)}});}let want = {bundleName: 'com.samples.customcommonevent',abilityName: 'MainAbility',};this.innerContext.startAbility(want);}jumpToHistory = () => {Logger.info("ready to jump to history page");router.pushUrl({url: 'pages/History',params: {}});}jumpToSetting = () => {Logger.info("ready to jump to setting page");router.pushUrl({url: 'pages/Setting',params: {}});}jumpToAbout = () => {Logger.info("ready to jump to about page");router.pushUrl({url: 'pages/About',params: {}});}jumpToCommonEvent = (): void => {Logger.info('ready to jump to commonEvent page');let context: common.UIAbilityContext | undefined = AppStorage.get('context');let want: Want = {bundleName: "com.samples.cardevent",abilityName: "EntryAbility",};context && context.startAbility(want,  (err) => {if (err.code) {Logger.error('StartAbility', `Failed to startAbility. Code: ${err.code}, message: ${err.message}`);}});};}

[LauncherAbility.ts]

/** Copyright (c) 2022-2023 Huawei Device Co., Ltd.* Licensed under the Apache License, Version 2.0 (the "License");* you may not use this file except in compliance with the License.* You may obtain a copy of the License at**     http://www.apache.org/licenses/LICENSE-2.0** Unless required by applicable law or agreed to in writing, software* distributed under the License is distributed on an "AS IS" BASIS,* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.* See the License for the specific language governing permissions and* limitations under the License.*/import UIAbility from '@ohos.app.ability.UIAbility';import commonEvent from '@ohos.commonEventManager';import consts from '../module/Consts';import dataPreferences from '@ohos.data.preferences';import surveillanceEventsManager from '../module/SurveillanceEventsManager';import Logger from '../module/Logger';export default class LauncherAbility extends UIAbility {onCreate(want) {globalThis.abilityWant = want;let settings: Map<string, number> = new Map();surveillanceEventsManager.surveillanceEvents.forEach((element: string) => {settings.set(element, consts.ENABLE_STATE_ALWAYS);});globalThis.settings = settings;AppStorage.setOrCreate('context', this.context);Logger.info(`LauncherAbility onCreate, settings.size = ${globalThis.settings.size}`)}async onDestroy() {Logger.info("LauncherAbility onDestroy")globalThis.settings.forEach((value: number, key: string) => {if (value == consts.ENABLE_STATE_ONCE) {globalThis.settings.set(key, consts.ENABLE_STATE_NEVER);}});let thisPref = null;await dataPreferences.getPreferences(this.context, consts.DATA_BASE_NAME).then((pref) => {thisPref = pref;});for (let element of surveillanceEventsManager.surveillanceEvents) {await thisPref.put(element, globalThis.settings.get(element));};await thisPref.flush();let options = {isSticky: true,parameters: surveillanceEventsManager.getSurveillanceEventStates()};commonEvent.publish(consts.COMMON_EVENT_SETTING_UPDATE, options, () => {Logger.info("success to publish once enable event");});}onWindowStageCreate(windowStage) {// Main window is created, set main page for this abilitywindowStage.loadContent("pages/Launch", (err, data) => {if (err.code) {Logger.error('Failed to load the content. Cause:' + JSON.stringify(err));return;}Logger.info('Succeeded in loading the content. Data: ' + JSON.stringify(data));});}onWindowStageDestroy() {// Main window is destroyed, release UI related resourcesLogger.info("LauncherAbility onWindowStageDestroy");}onForeground() {// Ability has brought to foregroundLogger.info("LauncherAbility onForeground");}onBackground() {// Ability has back to backgroundLogger.info("LauncherAbility onBackground");}}

[SurveillanceEventsManager.ts]

/** Copyright (c) 2022-2023 Huawei Device Co., Ltd.* Licensed under the Apache License, Version 2.0 (the "License");* you may not use this file except in compliance with the License.* You may obtain a copy of the License at**     http://www.apache.org/licenses/LICENSE-2.0** Unless required by applicable law or agreed to in writing, software* distributed under the License is distributed on an "AS IS" BASIS,* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.* See the License for the specific language governing permissions and* limitations under the License.*/import commonEvent from '@ohos.commonEventManager';export class EventData {"usual.event.wifi.POWER_STATE": number;"usual.event.SCREEN_OFF": number;"usual.event.SCREEN_ON": number;"usual.event.SCREEN_LOCKED": number;"usual.event.SCREEN_UNLOCKED": number;}export default class SurveillanceEventsManager {constructor() {}static getSurveillanceEventStates(): EventData {return {"usual.event.wifi.POWER_STATE": globalThis.settings.get(commonEvent.Support.COMMON_EVENT_WIFI_POWER_STATE),"usual.event.SCREEN_OFF": globalThis.settings.get(commonEvent.Support.COMMON_EVENT_SCREEN_OFF),"usual.event.SCREEN_ON": globalThis.settings.get(commonEvent.Support.COMMON_EVENT_SCREEN_ON),"usual.event.SCREEN_LOCKED": globalThis.settings.get(commonEvent.Support.COMMON_EVENT_SCREEN_LOCKED),"usual.event.SCREEN_UNLOCKED": globalThis.settings.get(commonEvent.Support.COMMON_EVENT_SCREEN_UNLOCKED)}}static surveillanceEvents: Array<string> = [commonEvent.Support.COMMON_EVENT_WIFI_POWER_STATE,commonEvent.Support.COMMON_EVENT_SCREEN_OFF,commonEvent.Support.COMMON_EVENT_SCREEN_ON,commonEvent.Support.COMMON_EVENT_SCREEN_LOCKED,commonEvent.Support.COMMON_EVENT_SCREEN_UNLOCKED,]}
  • 参考接口:[@ohos.app.ability.common],[@ohos.commonEventManager],[@ohos.data.preferences],[@ohos.commonEvent],[@ohos.router],[@ohos.systemTime]

    • 历史模块

      • 使用到应用文上下文,getPreferences方法获取Preferences实例,组件Header进行历史页面开发。
  • 源码链接:[Header.ets]

/** Copyright (c) 2022 Huawei Device Co., Ltd.* Licensed under the Apache License, Version 2.0 (the "License");* you may not use this file except in compliance with the License.* You may obtain a copy of the License at**     http://www.apache.org/licenses/LICENSE-2.0** Unless required by applicable law or agreed to in writing, software* distributed under the License is distributed on an "AS IS" BASIS,* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.* See the License for the specific language governing permissions and* limitations under the License.*/import router from '@ohos.router'@Componentexport struct Header {@State src: string = ''build() {Column() {}.backgroundImage($rawfile(this.src)).backgroundImageSize(ImageSize.Cover).position({ x: '2%', y: '2%' }).size({ width: 100, height: 50 }).onClick(() => {router.back()})}}

[Consts.ts]

/** Copyright (c) 2022-2023 Huawei Device Co., Ltd.* Licensed under the Apache License, Version 2.0 (the "License");* you may not use this file except in compliance with the License.* You may obtain a copy of the License at**     http://www.apache.org/licenses/LICENSE-2.0** Unless required by applicable law or agreed to in writing, software* distributed under the License is distributed on an "AS IS" BASIS,* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.* See the License for the specific language governing permissions and* limitations under the License.*/import commonEvent from '@ohos.commonEventManager';export default class consts {// definition for databasestatic readonly DATA_BASE_NAME: string = "nothing_pre";static readonly DATA_BASE_KEY_TOTAL_TIMES: string = "totalTimes";static readonly DATA_BASE_KEY_START_TIME: string = "startTime";static readonly DATA_BASE_KEY_WIFI_POWER_STATE: string = commonEvent.Support.COMMON_EVENT_WIFI_POWER_STATE;static readonly DATA_BASE_KEY_SCREEN_OFF: string = commonEvent.Support.COMMON_EVENT_SCREEN_OFF;static readonly DATA_BASE_KEY_SCREEN_ON: string = commonEvent.Support.COMMON_EVENT_SCREEN_ON;static readonly DATA_BASE_KEY_SCREEN_LOCKED: string = commonEvent.Support.COMMON_EVENT_SCREEN_LOCKED;static readonly DATA_BASE_KEY_SCREEN_UNLOCKED: string = commonEvent.Support.COMMON_EVENT_SCREEN_UNLOCKED;static readonly DATA_BASE_KEY_ONCE_EVENTS: string = "onceCall";static readonly DATA_BASE_KEY_NEVER_EVENTS: string = "neverCall";// definition for event enable statestatic readonly ENABLE_STATE_ALWAYS : number = 0static readonly ENABLE_STATE_ONCE : number = 1static readonly ENABLE_STATE_NEVER : number = 2// definition for record volumestatic readonly MAX_RECORD_NUM: number = 10;// definition for self defined common eventsstatic readonly COMMON_EVENT_FINISH_MEDITATION: string = "finish_meditation"static readonly COMMON_EVENT_SETTING_UPDATE: string = "setting_update"}

[HistoryFeature.ts]

/** Copyright (c) 2022-2023 Huawei Device Co., Ltd.* Licensed under the Apache License, Version 2.0 (the "License");* you may not use this file except in compliance with the License.* You may obtain a copy of the License at**     http://www.apache.org/licenses/LICENSE-2.0** Unless required by applicable law or agreed to in writing, software* distributed under the License is distributed on an "AS IS" BASIS,* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.* See the License for the specific language governing permissions and* limitations under the License.*/import common from '@ohos.app.ability.common'import consts from '../module/Consts'import dataPreferences from '@ohos.data.preferences'import Logger from '../module/Logger'const TAG: string = '[Sample_CustomCommonEvent_HistoryFeature]'export default class HistoryFeature {constructor(abilityContext: common.UIAbilityContext) {this.innerContext = abilityContext}async getData() {await this.init()return new Promise((resolve) => {resolve(this.dataSource)})}private async init() {let prefer = nullawait dataPreferences.getPreferences(this.innerContext, consts.DATA_BASE_NAME).then((pref) => {prefer = pref})let records: Array<string>await prefer.get(consts.DATA_BASE_KEY_TOTAL_TIMES, []).then((value: Array<string>) => {records = value})for (let item of records) {await prefer.get(item, []).then((detail: Array<string>) => {if(JSON.stringify(detail) !== '[]'){this.dataSource.push(detail)}}).catch((error)=>{Logger.info(TAG, `Failed to get value code is ${error.code}`)})}}private dataSource: Array<Array<string>> = []private innerContext: common.UIAbilityContext = null}
  • 参考接口:[@ohos.app.ability.common],[@ohos.data.preferences]

    • 设置模块

      • 本模块分为三个事件,分别为记录联网事件,记录灭屏事件,记录亮屏事件,进行锁屏事件、进行解锁屏幕事件,每一个事件都可进行一直,仅本次和从不的单项选择,使用到应用文上下文吗,CommonEvent.publish发布公共事件,getPreferences方法获取Preferences实例进行功能页面开发。
      • 源码链接:[Header.ets],[Consts.ts]

[SettingFeature.ts]

/** Copyright (c) 2022 Huawei Device Co., Ltd.* Licensed under the Apache License, Version 2.0 (the "License");* you may not use this file except in compliance with the License.* You may obtain a copy of the License at**     http://www.apache.org/licenses/LICENSE-2.0** Unless required by applicable law or agreed to in writing, software* distributed under the License is distributed on an "AS IS" BASIS,* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.* See the License for the specific language governing permissions and* limitations under the License.*/import commonEvent from '@ohos.commonEventManager';import common from '@ohos.app.ability.common';import consts from '../module/Consts';import dataPreferences from '@ohos.data.preferences';import Logger from '../module/Logger';import surveillanceEventsManager from '../module/SurveillanceEventsManager';export default class SettingFeature {private innerContext: common.UIAbilityContext = nullprivate pref: dataPreferences.Preferences = nullconstructor(abilityContext: common.UIAbilityContext) {this.innerContext = abilityContext}async init() {await dataPreferences.getPreferences(this.innerContext, consts.DATA_BASE_NAME).then((pref=>{this.pref = pref})).catch(err=>{Logger.info(`getPreferences err ${JSON.stringify(err)}`)})}changeState(group: string, state: number) {globalThis.settings.set(group, state);let options = {isSticky: true,parameters: surveillanceEventsManager.getSurveillanceEventStates()}commonEvent.publish(consts.COMMON_EVENT_SETTING_UPDATE, options, () => {Logger.info('success to publish setting update event')})this.pref.put(group, state).then(() => {this.pref.flush()})}checkStateForAlways(group: string): boolean {return globalThis.settings.get(group) == consts.ENABLE_STATE_ALWAYS}checkStateForOnce(group: string): boolean {return globalThis.settings.get(group) == consts.ENABLE_STATE_ONCE}checkStateForNever(group: string): boolean {return globalThis.settings.get(group) == consts.ENABLE_STATE_NEVER}changeStateToAlways(group: string) {this.changeState(group, consts.ENABLE_STATE_ALWAYS)}changeStateToOnce(group: string) {this.changeState(group, consts.ENABLE_STATE_ONCE)}changeStateToNever(group: string) {this.changeState(group, consts.ENABLE_STATE_NEVER)}}

[SurveillanceEventsManager.ts]

/** Copyright (c) 2022-2023 Huawei Device Co., Ltd.* Licensed under the Apache License, Version 2.0 (the "License");* you may not use this file except in compliance with the License.* You may obtain a copy of the License at**     http://www.apache.org/licenses/LICENSE-2.0** Unless required by applicable law or agreed to in writing, software* distributed under the License is distributed on an "AS IS" BASIS,* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.* See the License for the specific language governing permissions and* limitations under the License.*/import commonEvent from '@ohos.commonEventManager';export class EventData {"usual.event.wifi.POWER_STATE": number;"usual.event.SCREEN_OFF": number;"usual.event.SCREEN_ON": number;"usual.event.SCREEN_LOCKED": number;"usual.event.SCREEN_UNLOCKED": number;}export default class SurveillanceEventsManager {constructor() {}static getSurveillanceEventStates(): EventData {return {"usual.event.wifi.POWER_STATE": globalThis.settings.get(commonEvent.Support.COMMON_EVENT_WIFI_POWER_STATE),"usual.event.SCREEN_OFF": globalThis.settings.get(commonEvent.Support.COMMON_EVENT_SCREEN_OFF),"usual.event.SCREEN_ON": globalThis.settings.get(commonEvent.Support.COMMON_EVENT_SCREEN_ON),"usual.event.SCREEN_LOCKED": globalThis.settings.get(commonEvent.Support.COMMON_EVENT_SCREEN_LOCKED),"usual.event.SCREEN_UNLOCKED": globalThis.settings.get(commonEvent.Support.COMMON_EVENT_SCREEN_UNLOCKED)}}static surveillanceEvents: Array<string> = [commonEvent.Support.COMMON_EVENT_WIFI_POWER_STATE,commonEvent.Support.COMMON_EVENT_SCREEN_OFF,commonEvent.Support.COMMON_EVENT_SCREEN_ON,commonEvent.Support.COMMON_EVENT_SCREEN_LOCKED,commonEvent.Support.COMMON_EVENT_SCREEN_UNLOCKED,]}
  • 参考接口:[@ohos.app.ability.common],[@ohos.data.preferences],[@ohos.commonEvent],[@ohos.router],[@ohos.commonEvent]

    • 关于模块

      • 该模块开发主要介绍了本示例的功能作用以及说明了什么情况下不能使用。
      • 源码链接:[Header.ets],[Consts.ts]
    • 设置中订阅事件模块

      • 本模块主要支持指定应用订阅自定义事件。subScribeInfo新增可选属性publisherBundleName,创建订阅对象时可指定PublisherBundlerName,事件发布时,获取订阅者信息,增加校验bundleName是否等于publisherBundlerName,相等则加入事件回调方,达成只接收指定发布方发布的事件的效果。
      • 源码链接:[EntryFormAbility.ts],[PublishCard.ets]
      • 参考接口:[@ohos.commonEventManager],[@ohos.hilog],[@ohos.app.form.formInfo],[@ohos.app.form.formBindingData],[@ohos.app.form.FormExtensionAbility]

http://www.ppmy.cn/embedded/6081.html

相关文章

CentOS常见的命令

CentOS&#xff08;Community ENTerprise Operating System&#xff09;是一个基于Red Hat Enterprise Linux源代码构建的开源企业级Linux发行版。在日常的系统管理和维护中&#xff0c;掌握一些常见的CentOS命令是非常必要的。本文将介绍一些CentOS系统中常用的命令&#xff0…

【Linux 杂货铺】进程间通信

1.进程为什么要通信呢&#xff1f; ①&#x1f34e; 为了进程之间更好的协同工作&#xff0c;举个例子&#xff0c;在学校&#xff0c;学院的管理人员给教师安排课程的时候&#xff0c;必须事先知道该教师平常的上课情况&#xff0c;不然会将教师的课程安排到一起造成麻烦&…

Keepalived+LVS+nginx搭建nginx高可用集群

一、简介 nginx是一款非常优秀的反向代理工具&#xff0c;支持请求分发&#xff0c;负载均衡&#xff0c;以及缓存等等非常实用的功能。在请求处理上&#xff0c;nginx采用的是epoll模型&#xff0c;这是一种基于事件监听的模型&#xff0c;因而其具备非常高效的请求处理效率…

【Java框架】Spring框架(三)——Spring整合Mybatis及Spring声明式事务

目录 回顾Mybatis和新对象思路整理 Spring和MyBatis的整合步骤1. 创建Web工程&#xff0c;导入Spring和MyBatis的相关依赖2. 建立开发目录结构&#xff0c;创建实体类3. 创建数据访问接口和SQL映射语句文件4. 使用Spring配置文件配置数据源4.1 database.properties4.2spring配置…

linux的内存管理

Linux的内存管理是操作系统中至关重要的组成部分之一。它负责管理系统中的物理内存&#xff0c;以便进程可以访问和使用它。以下是Linux内存管理的一些关键方面&#xff1a; 虚拟内存管理&#xff1a; Linux使用虚拟内存系统&#xff0c;将物理内存和进程地址空间分开管理。每个…

【最新可用】Claude国内镜像,可上传图片,可用Claude3全系模型,包括Pro版本的Opus),亲测比GPT好用

Claude对话、上传图片的超详细教程来啦&#xff01; 近期&#xff0c;Claude 3 Opus的发布引发了网络上的广泛关注与热议&#xff0c;有观点认为其性能已经凌驾于GPT-4之上。虽然网络上已经出现了大量基于这两款先进AI技术的实际应用案例&#xff0c;但仍有许多人对在国内如何…

分享一个纯HTML的后台数据统计管理UI框架模板源码

纯HTML的后台数据统计管理UI框架模板源码 有很多好看的样式 以及各种图表 表格 大量的图标 源码 <!DOCTYPE html> <html lang"en"><head><!-- Required meta tags --><meta charset"utf-8"><meta name"viewport&qu…

serverLess

第一步 安装依赖 npm install serverless-devs/s g 第二步 配置秘钥&#xff1a; 第三步 执行终端 执行命令 s config add 选择 alibaba cloud &#xff08;alibaba&#xff09; 把对应的ID secret填写&#xff0c;第三个别名可以随便写&#xff1a; serverLess 查看是…