0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

OpenHarmony上使用服务卡片

OpenHarmony技术社区 来源:OST开源开发者 2023-06-25 15:12 次阅读

服务卡片是一种界面展示形式,将服务的重要信息以卡片的形式展示给用户,用户可通过轻量交互行为实现服务直达、减少层级跳转的目的。

原子化服务卡片的核心理念在于提供用户容易使用且一目了然的信息内容,将智慧化能力融入到原子化服务卡片的体验中供用户选择使用,同时满足在不同终端设备上的展示。

基本概念

卡片使用方:显示卡片内容的宿主应用,控制卡片在宿主中展示的位置,如桌面、原子化服务中心等。

卡片管理服务:用于管理系统中所添加卡片的常驻代理服务,包括卡片对象的管理与使用,以及卡片周期性刷新等。

卡片提供方:提供卡片显示内容的 OpenHarmony 应用或原子化服务,控制卡片的显示内容、控件布局以及控件点击事件。

注:卡片使用方和提供方不要求常驻运行,在需要添加/删除/请求更新卡片时,卡片管理服务会拉起卡片提供方获取卡片信息。

运作机制

bc94e9aa-1326-11ee-962d-dac502259ad0.png

①卡片管理服务

包含以下模块:

周期性刷新:在卡片添加后,根据卡片的刷新策略启动定时任务周期性触发卡片的刷新。

卡片缓存管理:在卡片添加到卡片管理服务后,对卡片的视图信息进行缓存,以便下次获取卡片时可以直接返回缓存数据,降低时延。

卡片生命周期管理:对于卡片切换到后台或者被遮挡时,暂停卡片的刷新;以及卡片的升级/卸载场景下对卡片数据的更新和清理。

卡片使用方对象管理:对卡片使用方的 RPC 对象进行管理,用于使用方请求进行校验以及对卡片更新后的回调处理。

通信适配层:负责与卡片使用方和提供方进行 RPC 通信。

②卡片提供方

包含以下模块:

卡片服务:由卡片提供方开发者实现,开发者实现 onCreateForm、onUpdateForm 和 onDeleteForm 处理创建卡片、更新卡片以及删除卡片等请求,提供相应的卡片服务。

卡片提供方实例管理模块:由卡片提供方开发者实现,负责对卡片管理服务分配的卡片实例进行持久化管理。

通信适配层:由 OpenHarmony SDK 提供,负责与卡片管理服务通信,用于将卡片的更新数据主动推送到卡片管理服务。

卡片类别

①尺寸分类

每个原子化服务可以配置多个原子化服务卡片,原子化服务卡片有微(1×2)、小( 2×2 )、中( 2×4 )、大(4×4)4 种尺寸,图示展示了不同尺寸的卡片。

bcae51d8-1326-11ee-962d-dac502259ad0.png

②场景分类

服务卡片按照不同应用场景使用的应用模型分类,可分为 FA 卡片、Stage 卡片。

FA 卡片

FA 卡片开发,即基于 FA 模型的卡片提供方开发,主要涉及如下功能逻辑:

开发卡片生命周期回调函数 LifecycleForm。

创建卡片数据 FormBindingData 对象。

通过 FormProvider 更新卡片。

开发卡片页面。

Stage 卡片

Stage 卡片开发,即基于 Stage 模型的卡片提供方开发,主要涉及如下功能逻辑:

卡片生命周期回调函数 FormExtension 开发。

创建卡片数据 FormBindingData 对象。

通过 FormProvider 更新卡片。

卡片页面开发。

本文主要介绍如何拉起卡片服务,对于卡片的开发介绍可以参考社区已有文档。 FA 卡片开发:

https://docs.openharmony.cn/pages/v3.1/zh-cn/application-dev/ability/fa-formability.md/
Stage 卡片开发:
https://docs.openharmony.cn/pages/v3.1/zh-cn/application-dev/ability/stage-formextension.md/

实践探索

bcde4cee-1326-11ee-962d-dac502259ad0.png

原子化服务卡片分为独立服务卡片和应用内服务卡片。其中,独立服务卡片又分为本地卡片和云端卡片。

本地卡片可以直接安装到设备上,而云端卡片需要下载并安装到设备上。应用内服务卡片则是指嵌入到应用程序中的服务卡片,可以提供更加定制化和个性化的服务。

卡片提供方可以提供单独的服务卡片,也可以在应用内提供服务卡片,这取决于使用场景。

①拉起应用内卡片

卡片提供方在应用内提供卡片,应用安装到设备后,效果如下图所示:

bceb9aa2-1326-11ee-962d-dac502259ad0.png

卡片提供方信息:在已有应用中通过 File→New→Service Widget 新建应用内卡片。

bd0d0188-1326-11ee-962d-dac502259ad0.png

卡片生成后,相关信息可以在 config.json 文件查看:

bd188b02-1326-11ee-962d-dac502259ad0.png

卡片使用方修改:调用 FormComponent 组件。

根据卡片提供方的卡片 name、bundle、ability、module、dimension 等信息调用 FormComponent 组件。

参考代码如下:

FormComponent({
id:0,
name:"widget",
bundle:"com.example.test_card",
ability:"com.example.test_card.FormAbility",
module:"entry",
dimension:FormDimension.Dimension_2_2
})
.allowUpdate(true)
.size({width:360,height:360})
.visibility(Visibility.Visible)
.onAcquired((form)=>{
console.log(`forminfo:${JSON.stringify(form)}`);
this.formId=form.id;
})
.onError((err)=>{
console.log(`zjxappfailtoaddform,err:${JSON.stringify(err)}`);
})
关于卡片使用方组件详细描述见FormComponent:
https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/arkui-ts/ts-basic-components-formcomponent.md
增加权限:在 entrysrcmainmodule.json5 中增加 FormComponent 组件所需的权限 GET_BUNDLE_INFO、GET_BUNDLE_INFO_PRIVILEGED、REQUIRE_FORM。
"abilities":[
{
"name":"EntryAbility",
"srcEntrance":"./ets/entryability/EntryAbility.ts",
"description":"$string:EntryAbility_desc",
"icon":"$media:icon",
"label":"$string:EntryAbility_label",
"startWindowIcon":"$media:icon",
"startWindowBackground":"$color:start_window_background",
"visible":true,
"skills":[
{
"entities":[
"entity.system.home"
],
"actions":[
"action.system.home"
]
}
]
}
],
"requestPermissions":[
{
"name":"ohos.permission.GET_BUNDLE_INFO"
},
{
"name":"ohos.permission.GET_BUNDLE_INFO_PRIVILEGED"
},
{
"name":"ohos.permission.REQUIRE_FORM"
}
]

②拉起独立的卡片

单独的服务卡片安装到设备后,可以通过 hdc shell 命令查询到对应的卡片服务。

#ps-ef|grep"com.zjxtest.hmservice"

卡片提供方信息:工程模板通过选择工程类型为"Atomic service",可以新建独立的服务卡片。

bd24b562-1326-11ee-962d-dac502259ad0.png

entrysrcmainmodule.json5 中可以查看卡片相关信息:

bd323980-1326-11ee-962d-dac502259ad0.png

卡片使用方修改:调用 FormComponent 组件。

根据卡片提供方的卡片 name、bundle、ability、module、dimension 等信息调用 FormComponent 组件。

参考代码如下:

FormComponent({
id:0,
name:"widget",
bundle:"com.example.test_card",
ability:"EntryFormAbility",
module:"entry",
dimension:FormDimension.Dimension_2_2
})
.allowUpdate(true)
.size({width:360,height:360})
.visibility(Visibility.Visible)
.onAcquired((form)=>{
console.log(`forminfo:${JSON.stringify(form)}`);
this.formId=form.id;
})
.onError((err)=>{
console.log(`zjxappfailtoaddform,err:${JSON.stringify(err)}`);
})

注:ability 与应用内的服务卡片有所区别。

增加权限:参考上面增加权限部分。

总结

本文介绍了两种类型的卡片,独立服务卡片、应用内服务卡片。 独立服务卡片是指可以独立安装和运行的服务卡片,可以提供各种功能和服务,如天气、新闻、音乐等。 独立服务卡片又分为本地卡片和云端卡片。本地卡片可以直接安装到设备上,而云端卡片需要下载并安装到设备上。 应用内服务卡片是指嵌入到应用程序中的服务卡片,可以提供更加定制化和个性化的服务。 应用内服务卡片通常与应用程序紧密集成,可以提供更加便捷和高效的服务。应用内服务卡片可以根据应用程序的需求和用户的偏好进行定制和开发,可以提供更加丰富和多样化的服务。 最后对如何两种类型的拉起方式做了介绍,希望可以给初学开发者一些帮助。

作者:赵军霞

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 通信
    +关注

    关注

    18

    文章

    5938

    浏览量

    135747
  • 卡片
    +关注

    关注

    0

    文章

    8

    浏览量

    9198
  • SDK
    SDK
    +关注

    关注

    3

    文章

    1017

    浏览量

    45658
  • OpenHarmony
    +关注

    关注

    25

    文章

    3628

    浏览量

    16027

原文标题:OpenHarmony上使用服务卡片

文章出处:【微信号:gh_834c4b3d87fe,微信公众号:OpenHarmony技术社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    OpenHarmony开发案例:【电影卡片

    基于元服务卡片的能力,实现带有卡片的电影应用,介绍卡片的开发过程和生命周期实现。
    的头像 发表于 04-15 17:53 1200次阅读
    <b class='flag-5'>OpenHarmony</b>开发案例:【电影<b class='flag-5'>卡片</b>】

    一文看懂HarmonyOS服务卡片运行原理和开发方法

    或者操作前置到卡片,以达到服务直达的目的。卡片实际界面如下图所示。图1 具有服务卡片的桌面如图
    发表于 07-27 17:21

    完整服务卡片项目开发,为Bilibili添加服务卡片

    { ... ... protected ProviderFormInfo onCreateForm(Intent intent) {...}//在服务卡片右击>>服务
    发表于 09-03 20:49

    HarmonyOS卡片开发--服务卡片概述

    服务卡片(以下简称“卡片”)是FA的一种界面展示形式,将FA的重要信息或操作前置到卡片,以达到服务直达,减少体验层级的目的。
    发表于 09-22 14:10

    HarmonyOS原子化服务(三)服务卡片策划设计经验总结

    的内容特色等,选择一种类型或者多种类型的一张或者多张卡片,一个原子化服务应用,蛟龙腾飞总体建议不超过16张服务卡片。2.
    发表于 02-10 09:29

    HarmonyOS之服务卡片(Java)开发步骤

    服务卡片的组件单独添加点击事件(Java)Java卡片通过componentProvider.setIntentAgent方法设置点击事件。封装IntentAgentInfo时,第一个参数“200
    发表于 07-26 16:17

    HarmonyOS/OpenHarmony应用开发-FA卡片开发体验

    卡片概述卡片是一种界面展示形式,可以将应用的重要信息或操作前置到卡片,以达到服务直达,减少体验层级的目的。卡片常用于嵌入到其他应用(当前只支
    发表于 12-06 14:48

    HarmonyOS/OpenHarmony服务开发-配置卡片的配置文件

    ;supportDimensions\": [ \"2*2\" ] } ] } *附件:HarmonyOSOpenHarmony服务开发-配置卡片的配置文件.docx
    发表于 08-01 11:45

    OpenHarmony ArkTS工程目录结构(Stage模型)

    :模块配置文件。主要包含HAP的配置信息、应用/服务在具体设备的配置信息以及应用/服务的全局配置信息。具体的配置文件说明,详见module.json5配置文件。 build-profile.json5
    发表于 09-18 15:23

    基于DevEco Studio的OpenHarmony应用原子化服务(元服务)入门教程

    一、创建项目 二、创建卡片 三、应用服务代码 Index.ets @Entry @Component struct Index { @State TITLE: string
    发表于 11-06 11:18

    B站添加鸿蒙服务卡片教程

    ‍‍‍‍‍‍‍‍ 6 月 2 日鸿蒙发布,今年的六月已经被鸿蒙刷屏了。从安卓到鸿蒙,最直观的变化应该就是服务卡片了。我也是在学习鸿蒙的同时,实际体验一下服务卡片的开发。 接下来分享下我
    的头像 发表于 08-12 10:07 2661次阅读
    B站添加鸿蒙<b class='flag-5'>服务</b><b class='flag-5'>卡片</b>教程

    HarmonyOS服务卡片如何换肤

      关注HarmonyOS的小伙伴肯定对服务卡片已经很熟悉了。服务卡片(也简称为“卡片”)是FA(FeatureAbility,元
    的头像 发表于 02-12 10:28 2763次阅读
    HarmonyOS<b class='flag-5'>服务</b><b class='flag-5'>卡片</b>如何换肤

    用Java开发HarmonyOS服务卡片

    卡片服务:由卡片提供方开发者实现,开发者实现 onCreateForm、onUpdateForm 和 onDeleteForm 处理创建卡片、更新
    的头像 发表于 04-26 11:04 1449次阅读

    如何在OpenHarmony开发服务卡片

    本篇文章我们将分享如何在 OpenHarmony 开发服务卡片
    的头像 发表于 04-10 11:12 982次阅读

    HarmonyOS 3.1实现计步卡片

    本篇帖子是参考 Codelab 基于 Stage 模型 JS 服务卡片,使用最新 ArkTS 元服务开发的,实现带有卡片的计步应用,用于介绍卡片
    的头像 发表于 05-29 11:10 744次阅读