harmony next 服务卡片实时刷新

此前今日事鸿蒙版卡片数据刷新还是有点问题。

问题:

安装应用后把卡片放到桌面,在app内新增一条数据,服务卡片不刷新,需要把app进程删除重新打开,才能正常刷新数据。

原因:

卡片渲染在系统进程,创建和调用都是系统触发,即EntryFormAbility里的代码其实运行在系统进程里面,跟app进程有内存隔离。没法做到数据实时共享。

懒得上图了,卡片交互流程直接上官网看吧。

这里主要解决问题。

需要通过harmony提供的跨进程通信模块

复制代码
import commonEventManager from '@ohos.commonEventManager'

来把卡片id发给app内进行保存,才能保证在app内能实时拿到卡片id,才能保证数据能刷新到卡片上。

核心代码:

复制代码
import commonEventManager from '@ohos.commonEventManager'

class SubscriberClass {
  event_form_id = "form_id"
  publishCount: number = 1
  subscriber?: commonEventManager.CommonEventSubscriber
  // 发布者
  publish(eventType: string ,data:string){
    // next中data支持导入类型
    commonEventManager.publish(eventType,{data},(err)=>{
      if(err){
        // 失败只发3次
        if(this.publishCount<=3){
          this.publishCount++
          this.publish(eventType,data)
        }else{
          this.publishCount = 1
        }
      }else{
        this.publishCount = 1
      }
    })
  }
  // 订阅者
  subscribe(eventType: string, callback:(event?: string)=>void){
    commonEventManager.createSubscriber({ events: [eventType] }, (err, sub) => {
      if (err) {
        return console.log('logData:', `创建订阅者error ${JSON.stringify(err)}`)
      }
      this.subscriber = sub
      if (this.subscriber !== null) {
        //订阅事件
        commonEventManager.subscribe(this.subscriber, (err, data) => {
          if (err) {
            return console.error(`logData`, '订阅事件失败')
          }
          callback(data.data)
        })
      } else {
        console.error('logData:',`需要创建subscriber`);
      }
    })
  }
}

export default new SubscriberClass()

这里简单构造了一个跨进程通信的发布与订阅的对象,在卡片EntryFormAbility调用publish,把formId发布出来。在App的EntryAbility中subscribe数据。

在EntryFormAbility的onAddForm中:

复制代码
SubscriberClass.publish(SubscriberClass.event_form_id, formId)

在EntryAbility的onWindowStateCreate中:

复制代码
SubscriberClass.subscribe(SubscriberClass.event_form_id, (data?: string) => {
      if (data) {
        CardManager.get().saveCardId(this.context, data)
      }
    })

这样,才能确保在APP中任意位置能更新到卡片:

复制代码
CardManager.get().updateCard()

多说无益,直接看源码吧

相关推荐
zhanshuo11 小时前
构建可扩展的状态系统:基于 ArkTS 的模块化状态管理设计与实现
harmonyos
zhanshuo12 小时前
ArkTS 模块通信全解析:用事件总线实现页面消息联动
harmonyos
codefish79816 小时前
鸿蒙开发学习之路:从入门到实践的全面指南
harmonyos
yrjw1 天前
一款基于react-native harmonyOS 封装的【文档】文件预览查看开源库(基于Harmony 原生文件预览服务进行封装)
harmonyos
搜狐技术产品小编20232 天前
搜狐新闻直播间适配HarmonyOs实现点赞动画
华为·harmonyos
zhanshuo2 天前
ArkUI 玩转水平滑动视图:超全实战教程与项目应用解析
harmonyos·arkui
zhanshuo2 天前
ArkUI Canvas 实战:快速绘制柱状图图表组件
harmonyos·arkui
zhanshuo2 天前
手把手教你用 ArkUI 写出高性能分页列表:List + onScroll 实战解析
harmonyos
zhanshuo2 天前
深入解析 ArkUI 触摸事件机制:从点击到滑动的开发全流程
harmonyos
i仙银3 天前
鸿蒙沙箱浏览器 - SandboxFinder
app·harmonyos