0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

OpenHarmony上使用服務(wù)卡片

OpenHarmony技術(shù)社區(qū) ? 來源:OST開源開發(fā)者 ? 2023-06-25 15:12 ? 次閱讀

服務(wù)卡片是一種界面展示形式,將服務(wù)的重要信息以卡片的形式展示給用戶,用戶可通過輕量交互行為實(shí)現(xiàn)服務(wù)直達(dá)、減少層級(jí)跳轉(zhuǎn)的目的。

原子化服務(wù)卡片的核心理念在于提供用戶容易使用且一目了然的信息內(nèi)容,將智慧化能力融入到原子化服務(wù)卡片的體驗(yàn)中供用戶選擇使用,同時(shí)滿足在不同終端設(shè)備上的展示。

基本概念

卡片使用方:顯示卡片內(nèi)容的宿主應(yīng)用,控制卡片在宿主中展示的位置,如桌面、原子化服務(wù)中心等。

卡片管理服務(wù):用于管理系統(tǒng)中所添加卡片的常駐代理服務(wù),包括卡片對(duì)象的管理與使用,以及卡片周期性刷新等。

卡片提供方:提供卡片顯示內(nèi)容的 OpenHarmony 應(yīng)用或原子化服務(wù),控制卡片的顯示內(nèi)容、控件布局以及控件點(diǎn)擊事件。

注:卡片使用方和提供方不要求常駐運(yùn)行,在需要添加/刪除/請(qǐng)求更新卡片時(shí),卡片管理服務(wù)會(huì)拉起卡片提供方獲取卡片信息。

運(yùn)作機(jī)制

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

①卡片管理服務(wù)

包含以下模塊:

周期性刷新:在卡片添加后,根據(jù)卡片的刷新策略啟動(dòng)定時(shí)任務(wù)周期性觸發(fā)卡片的刷新。

卡片緩存管理:在卡片添加到卡片管理服務(wù)后,對(duì)卡片的視圖信息進(jìn)行緩存,以便下次獲取卡片時(shí)可以直接返回緩存數(shù)據(jù),降低時(shí)延。

卡片生命周期管理:對(duì)于卡片切換到后臺(tái)或者被遮擋時(shí),暫停卡片的刷新;以及卡片的升級(jí)/卸載場景下對(duì)卡片數(shù)據(jù)的更新和清理。

卡片使用方對(duì)象管理:對(duì)卡片使用方的 RPC 對(duì)象進(jìn)行管理,用于使用方請(qǐng)求進(jìn)行校驗(yàn)以及對(duì)卡片更新后的回調(diào)處理。

通信適配層:負(fù)責(zé)與卡片使用方和提供方進(jìn)行 RPC 通信。

②卡片提供方

包含以下模塊:

卡片服務(wù):由卡片提供方開發(fā)者實(shí)現(xiàn),開發(fā)者實(shí)現(xiàn) onCreateForm、onUpdateForm 和 onDeleteForm 處理創(chuàng)建卡片、更新卡片以及刪除卡片等請(qǐng)求,提供相應(yīng)的卡片服務(wù)。

卡片提供方實(shí)例管理模塊:由卡片提供方開發(fā)者實(shí)現(xiàn),負(fù)責(zé)對(duì)卡片管理服務(wù)分配的卡片實(shí)例進(jìn)行持久化管理。

通信適配層:由 OpenHarmony SDK 提供,負(fù)責(zé)與卡片管理服務(wù)通信,用于將卡片的更新數(shù)據(jù)主動(dòng)推送到卡片管理服務(wù)。

卡片類別

①尺寸分類

每個(gè)原子化服務(wù)可以配置多個(gè)原子化服務(wù)卡片,原子化服務(wù)卡片有微(1×2)、小( 2×2 )、中( 2×4 )、大(4×4)4 種尺寸,圖示展示了不同尺寸的卡片。

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

②場景分類

服務(wù)卡片按照不同應(yīng)用場景使用的應(yīng)用模型分類,可分為 FA 卡片、Stage 卡片。

FA 卡片

FA 卡片開發(fā),即基于 FA 模型的卡片提供方開發(fā),主要涉及如下功能邏輯:

開發(fā)卡片生命周期回調(diào)函數(shù) LifecycleForm。

創(chuàng)建卡片數(shù)據(jù) FormBindingData 對(duì)象。

通過 FormProvider 更新卡片。

開發(fā)卡片頁面。

Stage 卡片

Stage 卡片開發(fā),即基于 Stage 模型的卡片提供方開發(fā),主要涉及如下功能邏輯:

卡片生命周期回調(diào)函數(shù) FormExtension 開發(fā)。

創(chuàng)建卡片數(shù)據(jù) FormBindingData 對(duì)象。

通過 FormProvider 更新卡片。

卡片頁面開發(fā)。

本文主要介紹如何拉起卡片服務(wù),對(duì)于卡片的開發(fā)介紹可以參考社區(qū)已有文檔。 FA 卡片開發(fā):

https://docs.openharmony.cn/pages/v3.1/zh-cn/application-dev/ability/fa-formability.md/
Stage 卡片開發(fā):
https://docs.openharmony.cn/pages/v3.1/zh-cn/application-dev/ability/stage-formextension.md/

實(shí)踐探索

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

原子化服務(wù)卡片分為獨(dú)立服務(wù)卡片和應(yīng)用內(nèi)服務(wù)卡片。其中,獨(dú)立服務(wù)卡片又分為本地卡片和云端卡片。

本地卡片可以直接安裝到設(shè)備上,而云端卡片需要下載并安裝到設(shè)備上。應(yīng)用內(nèi)服務(wù)卡片則是指嵌入到應(yīng)用程序中的服務(wù)卡片,可以提供更加定制化和個(gè)性化的服務(wù)。

卡片提供方可以提供單獨(dú)的服務(wù)卡片,也可以在應(yīng)用內(nèi)提供服務(wù)卡片,這取決于使用場景。

①拉起應(yīng)用內(nèi)卡片

卡片提供方在應(yīng)用內(nèi)提供卡片,應(yīng)用安裝到設(shè)備后,效果如下圖所示:

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

卡片提供方信息:在已有應(yīng)用中通過 File→New→Service Widget 新建應(yīng)用內(nèi)卡片。

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

卡片生成后,相關(guān)信息可以在 config.json 文件查看:

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

卡片使用方修改:調(diào)用 FormComponent 組件。

根據(jù)卡片提供方的卡片 name、bundle、ability、module、dimension 等信息調(diào)用 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)}`);
})
關(guān)于卡片使用方組件詳細(xì)描述見FormComponent:
https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/arkui-ts/ts-basic-components-formcomponent.md
增加權(quán)限:在 entrysrcmainmodule.json5 中增加 FormComponent 組件所需的權(quán)限 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"
}
]

②拉起獨(dú)立的卡片

單獨(dú)的服務(wù)卡片安裝到設(shè)備后,可以通過 hdc shell 命令查詢到對(duì)應(yīng)的卡片服務(wù)。

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

卡片提供方信息:工程模板通過選擇工程類型為"Atomic service",可以新建獨(dú)立的服務(wù)卡片。

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

entrysrcmainmodule.json5 中可以查看卡片相關(guān)信息:

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

卡片使用方修改:調(diào)用 FormComponent 組件。

根據(jù)卡片提供方的卡片 name、bundle、ability、module、dimension 等信息調(diào)用 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 與應(yīng)用內(nèi)的服務(wù)卡片有所區(qū)別。

增加權(quán)限:參考上面增加權(quán)限部分。

總結(jié)

本文介紹了兩種類型的卡片,獨(dú)立服務(wù)卡片、應(yīng)用內(nèi)服務(wù)卡片。 獨(dú)立服務(wù)卡片是指可以獨(dú)立安裝和運(yùn)行的服務(wù)卡片,可以提供各種功能和服務(wù),如天氣、新聞、音樂等。 獨(dú)立服務(wù)卡片又分為本地卡片和云端卡片。本地卡片可以直接安裝到設(shè)備上,而云端卡片需要下載并安裝到設(shè)備上。 應(yīng)用內(nèi)服務(wù)卡片是指嵌入到應(yīng)用程序中的服務(wù)卡片,可以提供更加定制化和個(gè)性化的服務(wù)。 應(yīng)用內(nèi)服務(wù)卡片通常與應(yīng)用程序緊密集成,可以提供更加便捷和高效的服務(wù)。應(yīng)用內(nèi)服務(wù)卡片可以根據(jù)應(yīng)用程序的需求和用戶的偏好進(jìn)行定制和開發(fā),可以提供更加豐富和多樣化的服務(wù)。 最后對(duì)如何兩種類型的拉起方式做了介紹,希望可以給初學(xué)開發(fā)者一些幫助。

作者:趙軍霞

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 通信
    +關(guān)注

    關(guān)注

    18

    文章

    5950

    瀏覽量

    135787
  • 卡片
    +關(guān)注

    關(guān)注

    0

    文章

    8

    瀏覽量

    9201
  • SDK
    SDK
    +關(guān)注

    關(guān)注

    3

    文章

    1020

    瀏覽量

    45697
  • OpenHarmony
    +關(guān)注

    關(guān)注

    25

    文章

    3641

    瀏覽量

    16061

原文標(biāo)題:OpenHarmony上使用服務(wù)卡片

文章出處:【微信號(hào):gh_834c4b3d87fe,微信公眾號(hào):OpenHarmony技術(shù)社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    OpenHarmony開發(fā)案例:【電影卡片

    基于元服務(wù)卡片的能力,實(shí)現(xiàn)帶有卡片的電影應(yīng)用,介紹卡片的開發(fā)過程和生命周期實(shí)現(xiàn)。
    的頭像 發(fā)表于 04-15 17:53 ?1209次閱讀
    <b class='flag-5'>OpenHarmony</b>開發(fā)案例:【電影<b class='flag-5'>卡片</b>】

    一文看懂HarmonyOS服務(wù)卡片運(yùn)行原理和開發(fā)方法

    或者操作前置到卡片,以達(dá)到服務(wù)直達(dá)的目的。卡片實(shí)際界面如下圖所示。圖1 具有服務(wù)卡片的桌面如圖
    發(fā)表于 07-27 17:21

    完整服務(wù)卡片項(xiàng)目開發(fā),為Bilibili添加服務(wù)卡片

    { ... ... protected ProviderFormInfo onCreateForm(Intent intent) {...}//在服務(wù)卡片右擊>>服務(wù)
    發(fā)表于 09-03 20:49

    HarmonyOS卡片開發(fā)--服務(wù)卡片概述

    服務(wù)卡片(以下簡稱“卡片”)是FA的一種界面展示形式,將FA的重要信息或操作前置到卡片,以達(dá)到服務(wù)直達(dá),減少體驗(yàn)層級(jí)的目的。
    發(fā)表于 09-22 14:10

    HarmonyOS原子化服務(wù)(三)服務(wù)卡片策劃設(shè)計(jì)經(jīng)驗(yàn)總結(jié)

    的內(nèi)容特色等,選擇一種類型或者多種類型的一張或者多張卡片,一個(gè)原子化服務(wù)應(yīng)用,蛟龍騰飛總體建議不超過16張服務(wù)卡片。2.
    發(fā)表于 02-10 09:29

    HarmonyOS之服務(wù)卡片(Java)開發(fā)步驟

    服務(wù)卡片的組件單獨(dú)添加點(diǎn)擊事件(Java)Java卡片通過componentProvider.setIntentAgent方法設(shè)置點(diǎn)擊事件。封裝IntentAgentInfo時(shí),第一個(gè)參數(shù)“200
    發(fā)表于 07-26 16:17

    HarmonyOS/OpenHarmony應(yīng)用開發(fā)-FA卡片開發(fā)體驗(yàn)

    卡片概述卡片是一種界面展示形式,可以將應(yīng)用的重要信息或操作前置到卡片,以達(dá)到服務(wù)直達(dá),減少體驗(yàn)層級(jí)的目的。卡片常用于嵌入到其他應(yīng)用(當(dāng)前只支
    發(fā)表于 12-06 14:48

    HarmonyOS/OpenHarmony服務(wù)開發(fā)-配置卡片的配置文件

    ;supportDimensions\": [ \"2*2\" ] } ] } *附件:HarmonyOSOpenHarmony服務(wù)開發(fā)-配置卡片的配置文件.docx
    發(fā)表于 08-01 11:45

    OpenHarmony ArkTS工程目錄結(jié)構(gòu)(Stage模型)

    :模塊配置文件。主要包含HAP的配置信息、應(yīng)用/服務(wù)在具體設(shè)備的配置信息以及應(yīng)用/服務(wù)的全局配置信息。具體的配置文件說明,詳見module.json5配置文件。 build-profile.json5
    發(fā)表于 09-18 15:23

    基于DevEco Studio的OpenHarmony應(yīng)用原子化服務(wù)(元服務(wù))入門教程

    一、創(chuàng)建項(xiàng)目 二、創(chuàng)建卡片 三、應(yīng)用服務(wù)代碼 Index.ets @Entry @Component struct Index { @State TITLE: string
    發(fā)表于 11-06 11:18

    B站添加鴻蒙服務(wù)卡片教程

    ???????? 6 月 2 日鴻蒙發(fā)布,今年的六月已經(jīng)被鴻蒙刷屏了。從安卓到鴻蒙,最直觀的變化應(yīng)該就是服務(wù)卡片了。我也是在學(xué)習(xí)鴻蒙的同時(shí),實(shí)際體驗(yàn)一下服務(wù)卡片的開發(fā)。 接下來分享下我
    的頭像 發(fā)表于 08-12 10:07 ?2671次閱讀
    B站添加鴻蒙<b class='flag-5'>服務(wù)</b><b class='flag-5'>卡片</b>教程

    HarmonyOS服務(wù)卡片如何換膚

      關(guān)注HarmonyOS的小伙伴肯定對(duì)服務(wù)卡片已經(jīng)很熟悉了。服務(wù)卡片(也簡稱為“卡片”)是FA(FeatureAbility,元
    的頭像 發(fā)表于 02-12 10:28 ?2771次閱讀
    HarmonyOS<b class='flag-5'>服務(wù)</b><b class='flag-5'>卡片</b>如何換膚

    用Java開發(fā)HarmonyOS服務(wù)卡片

    卡片服務(wù):由卡片提供方開發(fā)者實(shí)現(xiàn),開發(fā)者實(shí)現(xiàn) onCreateForm、onUpdateForm 和 onDeleteForm 處理創(chuàng)建卡片、更新
    的頭像 發(fā)表于 04-26 11:04 ?1456次閱讀

    如何在OpenHarmony開發(fā)服務(wù)卡片

    本篇文章我們將分享如何在 OpenHarmony 開發(fā)服務(wù)卡片。
    的頭像 發(fā)表于 04-10 11:12 ?994次閱讀

    HarmonyOS 3.1實(shí)現(xiàn)計(jì)步卡片

    本篇帖子是參考 Codelab 基于 Stage 模型 JS 服務(wù)卡片,使用最新 ArkTS 元服務(wù)開發(fā)的,實(shí)現(xiàn)帶有卡片的計(jì)步應(yīng)用,用于介紹卡片
    的頭像 發(fā)表于 05-29 11:10 ?757次閱讀