写点什么

HarmonyOS 卡片刷新服务,信息实时更新一目了然

作者:HMS Core
  • 2024-03-20
    广东
  • 本文字数:2944 字

    阅读完需:约 10 分钟

如今衣食住行娱乐影音等 App 占据了大多数人的手机,一部手机可以满足日常大多需求,但对需要经常查看或进行简单操作的场景来说,总需要用户点开 App 操作未免过于繁琐。


针对该问题, HarmonyOS SDK 为用户提供了Form Kit(卡片开发服务),您可以将应用的重要信息或操作前置到卡片,以达到服务直达、减少体验层级的目的,用户无需打开 App,根据引导将卡片添加到桌面,即可随时随地查看服务的重要信息和动态变化。



面对需要实时更新信息的 App 卡片,Push Kit (推送服务)向开发者提供了卡片刷新服务。应用通过集成 Push Kit 后获取 Push Token,基于 Push Kit 的系统级通道,便可以在合适场景向用户即时推送卡片内容,从而提升用户的感知度和活跃度。


能力优势

可靠、稳定


应用无论是否在后台运行,通过 Push Kit 都能即时刷新服务内容。通过华为终端设备的长连接,充分保障刷新内容送达;系统级通道最高可提供每秒千万级的推送速度。


实时、灵活


由开发者在合适场景即时推送卡片封面内容,实时更新;支持图片、文本等多种格式刷新;并及时返回送达回执。


开发步骤

为方便 App 开发者接入,仅需五步即可完成卡片刷新功能的开发及卡片内容刷新。



1.参见创建一个ArkTS卡片,完成本地服务卡片的创建。


2.在项目模块级别下的 src/main/resources/base/profile/form_config.json 中配置dataProxyEnabled字段为 true,开启卡片代理刷新功能。


{  "forms": [    {      "name": "WidgetCard",      "src": "./ets/widget/pages/WidgetCard.ets",      "uiSyntax": "arkts",      "window": {        "designWidth": 720,        "autoDesignWidth": true      },      "colorMode": "auto",      "isDefault": true,      "updateEnabled": true,      "updateDuration": 1,      "scheduledUpdateTime": "10:30",      "defaultDimension": "2*2",      "supportDimensions": ["2*2"],      "dataProxyEnabled": true    }  ]}
复制代码


3.在卡片生命周期管理文件(下以 EntryFormAbility 为例)的onAddForm()回调中获取 formId,定义需要在卡片页面文件(下以 WidgetCard 为例)中和通过 Push Kit 要刷新的字段,如下以 text_key 和 image_key 为例。


import { formBindingData, formInfo, FormExtensionAbility } from '@kit.FormKit';import { Want } from '@kit.AbilityKit';
export default class EntryFormAbility extends FormExtensionAbility { onAddForm(want: Want): formBindingData.FormBindingData { // 获取formId const formId = want.parameters![formInfo.FormParam.IDENTITY_KEY] as string;
// 定义需要在WidgetCard中刷新的字段 class CreateFormData { formId: string = ''; text_key: string = ''; image_key: string = ''; }
const obj: CreateFormData = { formId: formId, text_key: '默认文本', image_key: '', } const bindingData: formBindingData.FormBindingData = formBindingData.createFormBindingData(obj);
// 定义需要通过Push Kit代理刷新的字段,每个key均需要在上面bindingData中定义 const text_key: formBindingData.ProxyData = { key: 'text_key', subscriberId: formId, }; const image_key: formBindingData.ProxyData = { key: 'image_key', subscriberId: formId, }; bindingData.proxies = [text_key, image_key]; return bindingData; }}
复制代码


4.卡片页面文件( src/main/ets/widget/pages/WidgetCard.ets 为例)中,创建LocalStorage变量并与@Entry装饰器绑定,使用@LocalStorageProp装饰器创建 key-value 的变量。


本文创建了 formId、text 和 image 三个变量,对应的 key 为 formId、text_key 和 image_key,需要注意的是卡片页面布局中 image 对应的组件是 Image 图片组件,图片组件传递的变量必须以 memory:// 开头。


// 定义页面级的UI状态存储LocalStorageconst storage = new LocalStorage();
// 绑定@Entry(storage)@Componentstruct WidgetCard { @LocalStorageProp('formId') formId: string = ''; @LocalStorageProp('text_key') text: string = ''; @LocalStorageProp('image_key') image: string = '';
build() { Flex({ direction: FlexDirection.Column }) { Row() { Text() { // Span是Text组件的子组件,用于显示行内文本 Span('formID:') Span(this.formId) } .fontSize(10) }
Row() { Text() { Span('文本:') Span(this.text) } .fontSize(10) }
Row() { if (this.image) { Image('memory://' + this.image).height(80) } } } .padding(10) }}
复制代码


5.建议您将 formId、pushToken 等信息上报到应用服务端,用于向应用发送卡片刷新消息。请参见指导获取Push Token


// 以下为伪代码import { Want } from '@kit.AbilityKit';import { pushService } from '@kit.PushKit';import { hilog } from '@kit.PerformanceAnalysisKit';import { BusinessError } from '@kit.BasicServicesKit';import { formInfo } from '@kit.FormKit';
async function saveFormInfo(want: Want): Promise<void> { try { const formId = want.parameters![formInfo.FormParam.IDENTITY_KEY] as string; const moduleName = want.moduleName; const abilityName = want.abilityName; const formName = want.parameters![formInfo.FormParam.NAME_KEY] as string; const pushToken: string = await pushService.getToken();
// 将formId, moduleName, abilityName, formName, pushToken 上报到应用服务端 } catch (err) { let e: BusinessError = err as BusinessError; hilog.error(0x0000, 'testTag', 'Save form info failed: %{public}s', e.message); }}
复制代码


6.应用服务端调用 REST API 推送卡片刷新消息,消息详情可参见场景化消息API接口功能介绍,请求示例如下:


// Request URLPOST https://push-api.cloud.huawei.com/v3/[projectId]/messages:send
// Request HeaderContent-Type: application/jsonAuthorization: Bearer eyJr*****OiIx---****.eyJh*****iJodHR--***.QRod*****4Gp---**** push-type: 1
// Request Body{ "payload": { "moduleName": "entry", "abilityName": "EntryFormAbility", "formName": "widget", "formId": 423434262, "version": 123456, "formData": { "text_key": "刷新文本内容" }, "images": [ { "keyName": "image_key", "url": "***", "require": 1 } ] }, "target": { "token": [ "IQAAAAC*************************dRH7_bPbfMrVfsYw" ] }, "pushOptions": { "testMessage": true }}
复制代码


了解更多详情>>


获取卡片开发服务开发指导文档


获取推送卡片刷新消息开发指导文档


获取推送服务开发指导文档

用户头像

HMS Core

关注

HarmonyOS SDK 2022-06-16 加入

HarmonyOS SDK通过将HarmonyOS系统级能力对外开放,支撑开发者高效打造更纯净、更智能、更精致、更易用的鸿蒙原生应用,和开发者共同成长。

评论

发布
暂无评论
HarmonyOS卡片刷新服务,信息实时更新一目了然_HarmonyOS_HMS Core_InfoQ写作社区