什么是HarmonyOS“跨設(shè)備遷移”?
HarmonyOS“跨設(shè)備遷移”是指將承載業(yè)務(wù)的Page在同一用戶的不同設(shè)備間遷移,以便支持用戶業(yè)務(wù)無(wú)縫切換的訴求。“跨設(shè)備遷移”實(shí)現(xiàn)了業(yè)務(wù)跨設(shè)備流轉(zhuǎn)功能,打破業(yè)務(wù)受限單設(shè)備的壁壘。
典型應(yīng)用場(chǎng)景舉例:
導(dǎo)航場(chǎng)景
如果用戶駕車出行,上車前,在手機(jī)上規(guī)劃好導(dǎo)航路線;上車后,導(dǎo)航自動(dòng)遷移到車機(jī)和車載音箱;下車后,導(dǎo)航自動(dòng)遷移回手機(jī)。如果用戶騎車出行,在手機(jī)上規(guī)劃好導(dǎo)航路線,騎行時(shí)手表可以接續(xù)導(dǎo)航。
辦公場(chǎng)景
大屏上呈現(xiàn)的文檔,PAD或者手機(jī)可以跨設(shè)備編輯。
娛樂(lè)場(chǎng)景
電影視頻從客廳電視到房間PAD跨設(shè)備接續(xù)播放。
HarmonyOS“跨設(shè)備遷移”的技術(shù)原理
HarmonyOS“跨設(shè)備遷移”需要用到一項(xiàng)關(guān)鍵技術(shù)——“分布式任務(wù)調(diào)度”。
分布式任務(wù)調(diào)度
“跨設(shè)備遷移”依賴HarmonyOS系統(tǒng)中分布式任務(wù)調(diào)度的“業(yè)務(wù)遷移能力”。
“分布式任務(wù)調(diào)度”基于分布式軟總線、分布式數(shù)據(jù)管理、分布式Profile和分布式安全認(rèn)證這四項(xiàng)技術(shù)特性,構(gòu)建統(tǒng)一的分布式服務(wù)管理(發(fā)現(xiàn)、同步、注冊(cè)、調(diào)用)機(jī)制,支持對(duì)跨設(shè)備的應(yīng)用進(jìn)行遠(yuǎn)程啟動(dòng)、遠(yuǎn)程調(diào)用、遠(yuǎn)程連接以及遷移等操作。
● 分布式軟總線實(shí)現(xiàn)了近場(chǎng)設(shè)備間統(tǒng)一的分布式通信能力管理,提供不區(qū)分鏈路的設(shè)備發(fā)現(xiàn)、連接、組網(wǎng)和傳輸能力。開(kāi)發(fā)者可無(wú)需關(guān)注設(shè)備間組網(wǎng)方式與底層協(xié)議,集中精力實(shí)現(xiàn)業(yè)務(wù)邏輯功能。
● 分布式數(shù)據(jù)管理中的數(shù)據(jù)同步能力可實(shí)現(xiàn)組網(wǎng)內(nèi)的設(shè)備信息共享實(shí)時(shí)同步,如設(shè)備上下線、設(shè)備信息列表等,方便多設(shè)備信息實(shí)時(shí)同步。
● 分布式Profile實(shí)現(xiàn)多設(shè)備Profile的統(tǒng)一查詢、訂閱能力,拉通多設(shè)備之間的管理。
● 分布式安全認(rèn)證提供應(yīng)用完整性保護(hù)、應(yīng)用權(quán)限管理、設(shè)備認(rèn)證、密鑰管理等服務(wù),為業(yè)務(wù)提供安全保障基礎(chǔ)。
分布式任務(wù)調(diào)度基于以上技術(shù)特性基座,構(gòu)建統(tǒng)一的分布式服務(wù)管理機(jī)制,完成了分布式組網(wǎng)內(nèi)設(shè)備中的系統(tǒng)服務(wù)信息同步及管理,包括服務(wù)注冊(cè)、服務(wù)發(fā)現(xiàn)、服務(wù)同步和服務(wù)調(diào)度。
在業(yè)務(wù)發(fā)起“跨設(shè)備遷移”請(qǐng)求時(shí),分布式調(diào)度系統(tǒng)根據(jù)調(diào)度決策機(jī)制選擇目標(biāo)設(shè)備,并獲取對(duì)應(yīng)設(shè)備的系統(tǒng)服務(wù)信息,在系統(tǒng)服務(wù)成功調(diào)度后,向目標(biāo)設(shè)備發(fā)起遠(yuǎn)程啟動(dòng)、遠(yuǎn)程調(diào)用、遠(yuǎn)程連接和遠(yuǎn)程遷移,由對(duì)應(yīng)設(shè)備的分布式任務(wù)調(diào)度系統(tǒng)完成本地化的任務(wù)執(zhí)行。
HarmonyOS“跨設(shè)備遷移”的具體實(shí)現(xiàn)流程
HarmonyOS“跨設(shè)備遷移”依賴“Ability”實(shí)現(xiàn),這里我們簡(jiǎn)單介紹一下“Ability”。Ability
Ability是應(yīng)用所具備能力的抽象,HarmonyOS支持應(yīng)用以Ability為單位進(jìn)行部署。業(yè)務(wù)“跨設(shè)備遷移”的基礎(chǔ)粒度也是Ability,具體實(shí)現(xiàn)是在不同設(shè)備間同一應(yīng)用的同名Ability之間進(jìn)行遷移。
● Ability概述
https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ability-ability-overview-0000000000029852
HarmonyOS的應(yīng)用由一個(gè)或多個(gè)FA(Feature Ability)或PA(Particle Ability)組成。
● FA有UI界面,提供與用戶交互的能力
FA僅支持Page Ability,一個(gè)Page實(shí)例可以包含一組相關(guān)頁(yè)面,每個(gè)頁(yè)面用一個(gè)AbilitySlice實(shí)例表示。
● Page Ability基本概念
https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ability-page-concept-0000000000033573● PA無(wú)UI界面,提供后臺(tái)運(yùn)行任務(wù)的能力以及統(tǒng)一的數(shù)據(jù)訪問(wèn)抽象
PA支持Service Ability和Data Ability:
Service Ability:用于提供后臺(tái)運(yùn)行任務(wù)的能力。
Data Ability:用于對(duì)外部提供統(tǒng)一的數(shù)據(jù)訪問(wèn)抽象。
Ability的生命周期主要用于Page實(shí)例的狀態(tài)機(jī)管理,系統(tǒng)管理或用戶操作等行為均會(huì)引起Page實(shí)例在其生命周期的不同狀態(tài)之間進(jìn)行轉(zhuǎn)換。Ability Class提供的回調(diào)機(jī)制能夠讓Page及時(shí)感知外界變化,從而正確地應(yīng)對(duì)狀態(tài)變化。
● Page Ability生命周期
https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ability-page-lifecycle-0000000000029840
“跨設(shè)備遷移”的處理依賴Ability的生命周期管理來(lái)完成Page的狀態(tài)切換,同時(shí)Page在生命周期回調(diào)中處理數(shù)據(jù)的保存與恢復(fù)。
● onStart()
當(dāng)系統(tǒng)首次創(chuàng)建Page實(shí)例時(shí)觸發(fā)。應(yīng)用須重寫(xiě)該方法,并在此初始化配置為展示AbilitySlice。Page在此后進(jìn)入INACTIVE狀態(tài),用戶不可交互。
● onActive()
當(dāng)Page從INACTIVE狀態(tài)切換到前臺(tái)時(shí)觸發(fā)。Page在此之后進(jìn)入ACTIVE狀態(tài),該狀態(tài)下,應(yīng)用與用戶處于可交互的狀態(tài)。
● onInactive()
當(dāng)Page即將進(jìn)入不可交互狀態(tài)時(shí)會(huì)被觸發(fā),Page在此之后進(jìn)入INACTIVE狀態(tài),應(yīng)用與用戶不可交互。
● onBackground()
當(dāng)Page不再對(duì)用戶可見(jiàn)時(shí)觸發(fā)。Page在此之后進(jìn)入BACKGROUND狀態(tài)。
● onForeground()
當(dāng)Page從BACKGROUND狀態(tài)重新回到前臺(tái)時(shí)觸發(fā)。Page在此之后回到INACTIVE狀態(tài)。
● onStop()當(dāng)系統(tǒng)將要銷毀Page時(shí)觸發(fā)。遷移流程圍繞Ability的生命周期,我們來(lái)看看業(yè)務(wù)“跨設(shè)備遷移”的具體流程。
業(yè)務(wù)“跨設(shè)備遷移”的本質(zhì)即通過(guò)分布式組網(wǎng)把一個(gè)設(shè)備的“Ability運(yùn)行狀態(tài)”遷移到另外一臺(tái)設(shè)備上。
程序中“跨設(shè)備遷移”通過(guò)調(diào)用Page Ability的遷移接口ContinueAbility,將設(shè)備A的業(yè)務(wù)無(wú)縫遷移到指定設(shè)備B中。其中,支持遷移的Page以及此Page所包含的所有AbilitySlice必須實(shí)現(xiàn)IAbilityContinuation接口。具體接口代碼如下:
public interface IAbilityContinuation { //是否可遷移 boolean onStartContinuation();
//保存數(shù)據(jù) boolean onSaveData(IntentParams var1);
//恢復(fù)數(shù)據(jù) boolean onRestoreData(IntentParams var1);
//遷移完成 void onCompleteContinuation(int var1);
default void onRemoteTerminated() { throw new RuntimeException(“Stub!”); }}
“跨設(shè)備遷移”關(guān)鍵步驟:
1設(shè)備A上的Page調(diào)用continueAbility請(qǐng)求遷移。2HarmonyOS處理遷移任務(wù),并回調(diào)設(shè)備A上Page的保存數(shù)據(jù)方法onSaveData,用于保存遷移必須的Page數(shù)據(jù)。3HarmonyOS將Page數(shù)據(jù)從設(shè)備A遷移到設(shè)備B。4HarmonyOS在設(shè)備B上啟動(dòng)同一個(gè)Page,并回調(diào)onRestoreData恢復(fù)Page數(shù)據(jù)。
“跨設(shè)備遷移”數(shù)據(jù)流轉(zhuǎn)過(guò)程:1設(shè)備A上的Page請(qǐng)求遷移到設(shè)備B(調(diào)用continueAbility)后,HarmonyOS回調(diào)設(shè)備A上該P(yáng)age及其AbilitySlice棧中所有AbilitySlice實(shí)例的onStartContinuation()方法,以確認(rèn)當(dāng)前是否可以遷移。True代表可執(zhí)行遷移。
2若可執(zhí)行遷移,則HarmonyOS回調(diào)設(shè)備A上Page及其AbilitySlice棧中所有AbilitySlice實(shí)例的onSaveData()方法,由該P(yáng)age保存必須傳遞到接收端設(shè)備B的Page狀態(tài)數(shù)據(jù)。3若數(shù)據(jù)保存成功,則分布式調(diào)度系統(tǒng)通過(guò)RPC通信,在設(shè)備B上啟動(dòng)同一個(gè)Page,并恢復(fù)對(duì)應(yīng)的AbilitySlice棧,然后回調(diào)設(shè)備B上該P(yáng)age的onRestoreData()方法,傳遞此前保存的數(shù)據(jù);
此后設(shè)備B上此Page從onStart()開(kāi)始其生命周期回調(diào)。4HarmonyOS回調(diào)設(shè)備A上Page及其AbilitySlice棧中所有AbilitySlice實(shí)例的onCompleteContinuation()方法,通知設(shè)備A遷移結(jié)果即數(shù)據(jù)恢復(fù)成功與否。
了解完具體流程,下面我們給大家推薦一個(gè)HarmonyOS“跨設(shè)備遷移”動(dòng)手實(shí)踐的Demo。
HarmonyOS“跨設(shè)備遷移”動(dòng)手實(shí)例
我們?yōu)榇蠹規(guī)?lái)一個(gè)辦公場(chǎng)景下“基于分布式的協(xié)同郵件編輯”Demo,作為“跨設(shè)備遷移”應(yīng)用的開(kāi)發(fā)實(shí)例。該實(shí)例通過(guò)模擬不同設(shè)備間協(xié)同的郵件內(nèi)容編輯來(lái)做一個(gè)“內(nèi)容”跨設(shè)備遷移的演示。目前該Demo已在HarmonyOS官網(wǎng)Codelabs中上線,感興趣的同學(xué)可以參考其具體流程,動(dòng)手開(kāi)發(fā)一個(gè)“跨設(shè)備遷移”郵箱Demo。
● 官網(wǎng)鏈接:
https://developer.huawei.com/consumer/cn/codelabsPortal/carddetails/Distributed-Mail
通過(guò)這一系列的解析,開(kāi)發(fā)者們是不是對(duì)HarmonyOS“跨設(shè)備遷移”技術(shù)有了更深的了解,未來(lái)我們還將為大家?guī)?lái)更多HarmonyOS相關(guān)技術(shù)解讀,也歡迎大家后臺(tái)留言,告訴我們更多你想聽(tīng)的技術(shù)內(nèi)容,我們將逐一為大家奉上~
編輯:jq
-
PA
+關(guān)注
關(guān)注
3文章
245瀏覽量
46978 -
HarmonyOS
+關(guān)注
關(guān)注
79文章
1982瀏覽量
30579
原文標(biāo)題:HarmonyOS “跨設(shè)備遷移”原理解析
文章出處:【微信號(hào):HarmonyOS_Dev,微信公眾號(hào):HarmonyOS開(kāi)發(fā)者】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
AKI跨語(yǔ)言調(diào)用庫(kù)神助攻C/C++代碼遷移至HarmonyOS NEXT
HarmonyOS Next 應(yīng)用元服務(wù)開(kāi)發(fā)-應(yīng)用接續(xù)動(dòng)態(tài)配置遷移快速啟動(dòng)目標(biāo)應(yīng)用
HarmonyOS Next 應(yīng)用元服務(wù)開(kāi)發(fā)-應(yīng)用接續(xù)動(dòng)態(tài)配置遷移保持遷移連續(xù)性
HarmonyOS Next 應(yīng)用元服務(wù)開(kāi)發(fā)-應(yīng)用接續(xù)動(dòng)態(tài)配置遷移按需退出
HarmonyOS Next 應(yīng)用元服務(wù)開(kāi)發(fā)-應(yīng)用接續(xù)動(dòng)態(tài)配置遷移按需遷移頁(yè)面
HarmonyOS Next 應(yīng)用元服務(wù)開(kāi)發(fā)-應(yīng)用接續(xù)動(dòng)態(tài)配置跨段遷移
HarmonyOS Next 應(yīng)用元服務(wù)開(kāi)發(fā)-分布式數(shù)據(jù)對(duì)象遷移數(shù)據(jù)文件資產(chǎn)遷移
HarmonyOS Next 應(yīng)用元服務(wù)開(kāi)發(fā)-分布式數(shù)據(jù)對(duì)象遷移數(shù)據(jù)權(quán)限與基礎(chǔ)數(shù)據(jù)
華為HarmonyOS NEXT 10月8日開(kāi)啟公測(cè)
![華為<b class='flag-5'>HarmonyOS</b> NEXT 10月8日開(kāi)啟公測(cè)](https://file1.elecfans.com/web2/M00/07/B9/wKgZombybUmAVCAGAAV6rv1rPfk684.png)
HarmonyOS NEXT Developer Beta1最新術(shù)語(yǔ)表
國(guó)產(chǎn)系統(tǒng)重要突破!深開(kāi)鴻KaihongOS率先連接HarmonyOS Next,實(shí)現(xiàn)跨生態(tài)互聯(lián)
![國(guó)產(chǎn)系統(tǒng)重要突破!深開(kāi)鴻KaihongOS率先連接<b class='flag-5'>HarmonyOS</b> Next,實(shí)現(xiàn)<b class='flag-5'>跨</b>生態(tài)互聯(lián)](https://file1.elecfans.com/web2/M00/F3/A9/wKgaomZ6OGuABDiYAADvHqP4zlo992.png)
鴻蒙開(kāi)發(fā):應(yīng)用組件跨設(shè)備交互(流轉(zhuǎn))【跨端遷移】
![鴻蒙開(kāi)發(fā):應(yīng)用組件<b class='flag-5'>跨</b><b class='flag-5'>設(shè)備</b>交互(流轉(zhuǎn))【<b class='flag-5'>跨</b>端<b class='flag-5'>遷移</b>】](https://file1.elecfans.com/web2/M00/ED/97/wKgaomZoDo-ARaW5AABo08GI6Tw501.jpg)
評(píng)論