国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

HarmonyOS中如何進行跨端遷移

OpenHarmony技術社區 ? 來源:鴻蒙技術社區 ? 作者:曾瑞紳 ? 2021-11-15 09:38 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

流轉在 HarmonyOS 中泛指多設備分布式操作,也是 HarmonyOS 的亮點之一。

流轉按體驗可以分為跨端遷移和多端協同,這里主要跟大家講一下如何進行跨端遷移,以及我在項目開發過程中,所遇到的問題與解決方法。

具體概念這里就不做過多的贅述了,大家可以查閱官方文檔:
https://developer.harmonyos.com/cn/docs/documentation/doc-guides/hop-overview-0000001092995092

開發步驟

在開發過程中,我們可以根據業務需求分為以下兩種場景:

  • 同個 FA 之間的遷移(Ability1—Ability1)

  • 不同 FA 之間的遷移(Ability1—Ability2)

下面給大家介紹一下以上兩種場景的具體的開發步驟。 ①同個 FA 之間的遷移

同個 FA 之間的遷移是指不同設備端安裝了同個 FA,官方文檔已經有比較詳細的開發步驟,下面只給大家講一下需要注意的事項及我所遇到的問題避免大家踩坑。

我們在創建完一個 FA 之后,因為我們大部門的業務邏輯都是在 AbilitySlice,所以我們在 Ability 及 AbilitySlice 都要去實現 IAbilityContinuation 接口

并且將 Ability 中實現的 onStartContinuation()、onSaveData(IntentParams intentParams)、onRestoreData(IntentParams intentParams)的返回值,都設為 true。

publicclassMainAbilityextendsAbilityimplementsIAbilityContinuation{

@Override
publicbooleanonStartContinuation(){
returntrue;
}

@Override
publicbooleanonSaveData(IntentParamsintentParams){
returntrue;
}

@Override
publicbooleanonRestoreData(IntentParamsintentParams){
returntrue;
}
//省略部分代碼
...
}

在對應的 FA 模塊的 config.json 中,配置對應的權限,且在代碼中也需要動態申請。
"reqPermissions":[
{
"name":"ohos.permission.DISTRIBUTED_DATASYNC"},
{
"name":"ohos.permission.DISTRIBUTED_DEVICE_STATE_CHANGE"},
{
"name":"ohos.permission.GET_DISTRIBUTED_DEVICE_INFO"},
{
"name":"ohos.permission.GET_BUNDLE_INFO"}
]

if(canRequestPermission(SystemPermission.DISTRIBUTED_DATASYNC)){
//是否可以申請彈框授權(首次申請或者用戶未選擇禁止且不再提示)
requestPermissionsFromUser(
newString[]{SystemPermission.DISTRIBUTED_DATASYNC},PERMISSIONS_REQUEST_DISTRIBUTED);
}

定義相關參數、設置流轉任務管理服務回調函數、注冊流轉任務管理服務、管理流轉的目標設備,同時需要在流轉結束時解注冊流轉任務管理服務。

//流轉應用包名
privateStringBUNDLE_NAME="XXX.XXX.XXX";
//注冊流轉任務管理服務后返回的Abilitytoken
privateintabilityToken;
//用戶在設備列表中選擇設備后返回的設備ID
privateStringselectDeviceId;
//獲取流轉任務管理服務管理類
privateIContinuationRegisterManagercontinuationRegisterManager;
//設置流轉任務管理服務設備狀態變更的回調
privateIContinuationDeviceCallbackcontinuationDeviceCallback=newIContinuationDeviceCallback(){
@Override
publicvoidonDeviceConnectDone(StringdeviceId,StringdeviceType){
selectDeviceId=deviceId;
continuationRegisterManager.updateConnectStatus(abilityToken,selectDeviceId,DeviceConnectState.CONNECTING.getState(),null);
...
}

@Override
publicvoidonDeviceDisconnectDone(Strings){
getUITaskDispatcher().asyncDispatch(()->{
continuationRegisterManager.updateConnectStatus(abilityToken,selectDeviceId,DeviceConnectState.DIS_CONNECTING.getState(),null);
});
unRegisterContinuation();
}
};
//設置注冊流轉任務管理服務回調
privateRequestCallbackrequestCallback=newRequestCallback(){
@Override
publicvoidonResult(intresult){
abilityToken=result;
}
};
...

@Override
publicvoidonStart(Intentintent){
...
continuationRegisterManager=getContinuationRegisterManager();
}

@Override
publicvoidonStop(){
super.onStop();
//解注冊流轉任務管理服務
continuationRegisterManager.unregister(abilityToken,null);
//斷開流轉任務管理服務連接
continuationRegisterManager.disconnect();
}

在 Api5 的時候 IContinuationDeviceCallback 的回調接口跟官方文檔有些出入,當你選擇設備后會在 onDeviceConnectDone 返回你所選擇的設備 ID 及設備類型。

注冊流轉服務之后我們便可以調起系統流轉選擇設備彈窗,可以通過 ExtraParams 對設備進行過濾,如不需要過濾,可不傳。

ExtraParamsparams=newExtraParams();
String[]devTypes=newString[]{ExtraParams.DEVICETYPE_SMART_PHONE,ExtraParams.DEVICETYPE_SMART_WATCH,ExtraParams.DEVICETYPE_SMART_PAD};
params.setDevType(devTypes);
registerContinuation();
//顯示選擇設備列表
continuationRegisterManager.showDeviceList(abilityToken,params,newRequestCallback(){
@Override
publicvoidonResult(intresult){
}
});

選擇完設備之后會通過上述的 IContinuationDeviceCallback 的 onDeviceConnectDone 方法進行回調。

之后通過 continueAbility 方法傳入目標設備的 DeviceID,將運行的 FA 遷移到目標設備,實現業務在設備間無縫遷移。

//設置流轉任務管理服務設備狀態變更的回調
privateIContinuationDeviceCallbackcontinuationDeviceCallback=newIContinuationDeviceCallback(){
@Override
publicvoidonDeviceConnectDone(StringdeviceId,StringdeviceType){
selectDeviceId=deviceId;
getUITaskDispatcher().asyncDispatch(()->{
continuationRegisterManager.updateConnectStatus(abilityToken,selectDeviceId,DeviceConnectState.CONNECTING.getState(),null);
});
if(selectDeviceId!=null){
continueAbility(selectDeviceId);
}
...
}

@Override
publicvoidonDeviceDisconnectDone(Strings){
...
unRegisterContinuation();
}

};

在 FA 遷移中我覺得最主要的部分就是狀態和數據的傳遞,要讓用戶體驗到”無縫“的用戶體驗,需要通過實現 IAbilityContinuation 接口來實現數據的傳遞。

主要代碼如下:

@Override
publicbooleanonSaveData(IntentParamssaveData){
//根據業務需求,在這里去設置需要傳遞的數據
saveData.setParam("continueParam",continueParam);
returntrue;
}
@Override
publicbooleanonRestoreData(IntentParamsrestoreData){
//遠端FA遷移傳來的狀態數據,開發者可以按照自身業務對這些數據進行處理
Objectdata=restoreData.getParam("continueParam");
getUITaskDispatcher().asyncDispatch(()->{

});
returntrue;
}

需要注意的是,在 onRestoreData 處理數據更新 UI 的時候,需要在 UI 線程中去更新,否則會報錯。 ②不同 FA 之間的遷移 在實際開發中可能會因為設備端的部分需求、UI 的不同,例如車機、手機、手表,從而開發了不同的 FA。

不同 FA 之間的遷移幾乎與同個 FA 之間遷移配置一致,只是我們的 AbilitySlice 不需要再實現 IAbilityContinuation 接口來實現數據的同步,而是通過 Intent,具體實現如下。

首先我們先在選擇設備成功后的回調 IContinuationDeviceCallback 初始化分布式環境。

//設置流轉任務管理服務設備狀態變更的回調
privateIContinuationDeviceCallbackcontinuationDeviceCallback=newIContinuationDeviceCallback(){
@Override
publicvoidonDeviceConnectDone(StringdeviceId,StringdeviceType){
selectDeviceId=deviceId;
//省略部分代碼
...
try{
//初始化分布式環境
DeviceManager.initDistributedEnvironment(selectDeviceId,newIInitCallback(){
@Override
publicvoidonInitSuccess(Stringsuccess){

}

@Override
publicvoidonInitFailure(Stringfailure,intresult){
}
});
}catch(RemoteExceptione){
e.printStackTrace();
}
...
}
....
};

之前我們是通過 continueAbility() 方法進行跳轉,而現在我們需要通過 Intent 方法進行跳轉。

Intentintent=newIntent();
Operationoperation=newIntent.OperationBuilder()
.withDeviceId(deviceId)
.withBundleName(bundleName)
.withAbilityName(abilityName)
.withFlags(Intent.FLAG_ABILITYSLICE_MULTI_DEVICE)
.build();
intent.setOperation(operation);
IntentParamsintentParams=newIntentParams();
//通過IntentParams傳遞參數
...
startAbility(intent);

在接收方,我們可以通過 onStart(Intent intent) 方法接受傳遞過來的參數,再根據自己的業務邏輯實現數據同步。 ③自定義設備選擇彈窗 在實際項目開發中我們也可以自定義流轉彈窗樣式,但并不推薦這種方式,經測試發現只有在兩個設備通過藍牙連接的時候才能獲取到設備列表,只有在特定的場景。

例如手機與車機、手機與手表在實際使用過程中我們基本上是會保持藍牙連接的,通過這種方式實現流轉會更穩定。但如果不能保持藍牙實時連接的場景則不推薦。

官方 API提供了 DeviceManager.getDeviceList() 來獲取遠端設備,具體代碼如下。

publicstaticListgetDeviceList(){
//調用DeviceManager的getDeviceList接口,通過FLAG_GET_ONLINE_DEVICE標記獲得在線設備列表
ListonlineDevices=DeviceManager.getDeviceList(DeviceInfo.FLAG_GET_ONLINE_DEVICE);
//判斷組網設備是否為空
if(onlineDevices==null){
LogUtil.e(TAG,"onlinedevicesisnull");
returnnewArrayList<>();
}
returnonlineDevices;
}

獲取到設備列表后,我們就可以自行實現頁面了,在上述的 showDeviceList() 彈出設備列表的位置替換成自己的彈窗即可。

結語

目前在 DevEco Studio 2.1 Release 以上版本已經支持跨端遷移的模擬器了。

如果沒有顯示出來可以在 Settings-DevEco Labs 勾選 Enable Super Device。

以上過程是在實際開發過程中慢慢摸索得出,如有不對的地方,歡迎在評論區指出,共同探討(附下載)。
https://harmonyos.51cto.com/posts/9013

責任編輯:haq
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 鴻蒙系統
    +關注

    關注

    183

    文章

    2642

    瀏覽量

    69844
  • HarmonyOS
    +關注

    關注

    80

    文章

    2153

    瀏覽量

    36045

原文標題:HarmonyOS流轉,替你踩坑了!!!

文章出處:【微信號:gh_834c4b3d87fe,微信公眾號:OpenHarmony技術社區】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    HarmonyOS首登微信公開課,分享平臺適配與體驗提升實踐經驗

    近日,2026微信公開課PRO在廣州舉行。值得關注的是,HarmonyOS開發專家首次以官方分享嘉賓身份亮相開發者專場,并圍繞“平臺適配與體驗提升”這一主題,深入剖析了微信小程序在平臺開發
    的頭像 發表于 02-02 09:22 ?302次閱讀
    <b class='flag-5'>HarmonyOS</b>首登微信公開課,分享<b class='flag-5'>跨</b>平臺適配與體驗提升實踐經驗

    對于設備上的舊固件如何進行備份和恢復?

    對于設備上的舊固件,如何進行備份和恢復?
    發表于 12-12 08:23

    Taro on HarmonyOS 技術架構深度解析

    on HarmonyOS 的技術實現方案、核心優化策略,以及開源版本的主要特性。 本文將詳細介紹 Taro on HarmonyOS 的技術架構、性能優化實踐和開源進展,分享我們在
    的頭像 發表于 08-04 16:10 ?787次閱讀
    Taro on <b class='flag-5'>HarmonyOS</b> 技術架構深度解析

    軟國際上云遷移服務充分釋放云計算價值

    華為云生態的核心合作伙伴,軟國際憑借深厚的行業積累、成熟的遷移方法論及專業化工具鏈,為企業提供到端上云服務,助力客戶實現業務無縫遷移,充分釋放云計算價值。
    的頭像 發表于 07-25 14:32 ?948次閱讀
    <b class='flag-5'>中</b>軟國際上云<b class='flag-5'>遷移</b>服務充分釋放云計算價值

    HarmonyOS 5】鴻蒙的UIAbility詳解(二)

    HarmonyOS 5】鴻蒙的UIAbility詳解(二) ##鴻蒙開發能力 ##HarmonyOS SDK應用服務##鴻蒙金融類應用 (金融理財# 一、前言 今天我們繼續深入講解
    的頭像 發表于 07-11 18:17 ?919次閱讀
    【<b class='flag-5'>HarmonyOS</b> 5】鴻蒙<b class='flag-5'>中</b>的UIAbility詳解(二)

    HarmonyOS Next】ArkUI-X休閑益智接水果【進階】

    本文通過ArkUI-X實現平臺接水果游戲,深入探究網絡圖片在HarmonyOS與iOS設備上的渲染差異,并提供專業級優化方案。基于WebView的混合架構,我們實現了單代碼庫雙適配的高效開發
    發表于 06-28 22:14

    HarmonyOS next】ArkUI-X休閑益智記憶翻牌【進階】

    本文通過記憶翻牌游戲實現,揭秘網絡圖片在HarmonyOS與iOS設備上的渲染差異,并提供專業級優化方案。基于ArkUI-X的Web組件技術,我們實現了一套代碼雙運行的混合架構。 一、平臺
    發表于 06-28 22:12

    HarmonyOS next】ArkUI-X休閑益智連連看【進階】

    一套代碼雙運行的平臺實踐 在移動應用開發平臺技術始終是開發者追求的圣杯。借助ArkUI-X框架,我們僅用一套ArkTS代碼即可實現應用在H
    發表于 06-28 21:51

    HarmonyOS next】ArkUI-X新聞熱搜聚合App【進階】

    平臺開發的強大能力。開發者可以復用超過80%的HarmonyOS代碼快速實現iOS應用開發,顯著降低多平臺維護成本。項目已開源至Gitee倉庫,歡迎開發者共同參與完善。 未來展望: 探索
    發表于 06-28 21:43

    HarmonyOS next】ArkUI-X休閑益智猜字謎【基礎】

    下圖是在iOS的運行效果 下圖是在HarmonyOS的運行效果 今天咱們來聊聊如何用ArkUI-X這個新興框架實現開發,通過一個猜字
    發表于 06-26 20:01

    ArkUI-X平臺應用改造指南

    工作量大幅增加,開發成本也隨之上升,而且很難保持一致的交互體驗。 ArkUI-X 平臺框架是基于 HarmonyOS 打造的平臺框架
    發表于 06-16 23:05

    京東開源Taro on HarmonyOS C-API版本

    近日,京東正式開源了Taro on HarmonyOS C-API 版本,為鴻蒙應用開發提供高性能框架。這次版本的發布,帶來了更豐富的樣式適配、更高效的渲染性能、更全面的組件支持,讓開發者以Web范式的方式來開發出媲美鴻蒙性
    的頭像 發表于 06-09 09:19 ?1131次閱讀
    京東開源Taro on <b class='flag-5'>HarmonyOS</b> C-API版本

    高壓單探頭設計的器材應如何選型

    在高壓單探頭設計的過程,器材的選型是尤為重要的,這決定探頭的性能,可靠性和安全性等重要環節。從電氣性能到機械結構,每一個器件的選型都要經過深思熟慮,本文主要從電氣性能方面探討,應該如何進行器材的選型。
    的頭像 發表于 06-05 18:07 ?546次閱讀

    HarmonyOS5云服務技術分享--ArkTS開發Node環境

    ? 你好呀,開發者小伙伴們!今天我們來聊聊如何在HarmonyOS(ArkTS API 9及以上)玩轉云函數,特別是結合Node.js和HTTP觸發器的開發技巧。文章會手把手帶你從零開始,用最接地
    發表于 05-22 17:21

    請問STM32WBA65如何進行matter的學習?

    STM32WBA65如何進行matter的學習?相關的支持都有哪些?有一個X-CUBE-MATTER,可是這個沒有集成在STM32CubeMX
    發表于 04-24 07:22