女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

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

3天內不再提示

【HarmonyOS 5】桌面快捷方式功能實現詳解

HarmonyOS解決方案 ? 來源:HarmonyOS解決方案 ? 作者:HarmonyOS解決方案 ? 2025-06-21 16:42 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

HarmonyOS 5】桌面快捷方式功能實現詳解

##鴻蒙開發能力 ##HarmonyOS SDK應用服務##鴻蒙金融類應用 (金融理財#

一、前言

在移動應用開發中,如何讓用戶快速觸達核心功能,是目前很常見的功能之一。

鴻蒙系統提供的**桌面快捷方式(Shortcuts)**功能,允許開發者為應用內常用功能創建直達入口,用戶通過長按應用圖標即可快速啟動特定功能,大幅減少操作層級。

本文將結合地圖導航場景,詳細解析鴻蒙快捷方式的實現原理與開發流程。結合華為官方開源示例 DesktopShortcut 展開,該示例基于HarmonyOS 5.0實現,完整演示了地圖導航場景的快捷方式開發流程。

二、需求分析與示例工程介紹

以地圖應用為例,用戶日常高頻使用“回家”“去公司”等導航功能。傳統流程需先打開應用、搜索目的地、再啟動導航。通過快捷方式,可實現:

  1. 長按應用圖標 ,在快捷方式列表中直接點擊“回家”或“去公司”;
  2. 拖動快捷方式到桌面 ,通過獨立圖標一鍵啟動導航。
    image.png

工程目錄介紹

├── entry/src/main/ets                  
│  ├── entryability                         
│  │  └── EntryAbility.ets                  // 核心邏輯:處理快捷方式參數并跳轉頁面
│  └── pages                                
│     ├── GoCompany.ets                     // 公司導航頁面(@Entry裝飾)
│     ├── GoHouse.ets                       // 回家導航頁面(@Entry裝飾)
│     └── Index.ets                         // 應用首頁
├── entry/src/main/resources                
│  └── base/profile                         
│     └── shortcuts_config.json             // 快捷方式元數據配置
└── module.json5                             // 模塊配置文件,關聯快捷方式

三、快捷方式功能實現步驟

1、 核心配置文件

(1)shortcuts_config.json :定義快捷方式的元數據,包括ID、名稱、圖標及目標跳轉信息。

{
  "shortcuts": [
    {
      "shortcutId": "id_go_company",
      "label": "$string:go_company",        // 對應resources/base/element/string.json中的字符串資源
      "icon": "$media:icon_company",        // 對應resources/base/media目錄下的圖標文件
      "wants": [
        {
          "bundleName": "com.example.desktopshortcut", // 應用包名(需與module.json5一致)
          "moduleName": "entry",                        // 模塊名(固定為entry)
          "abilityName": "EntryAbility",               // 目標Ability(入口Ability)
          "parameters": { "page": "GoCompany" }         // 自定義參數:標識目標頁面
        }
      ]
    },
    {
      "shortcutId": "id_go_house",
      "label": "$string:go_home",
      "icon": "$media:icon_home",
      "wants": [
        {
          "bundleName": "com.example.desktopshortcut",
          "moduleName": "entry",
          "abilityName": "EntryAbility",
          "parameters": { "page": "GoHouse" } //  `parameters`鍵名可自定義(示例中使用`page`而非前文的`shortCutKey`),需與代碼邏輯保持一致。
        }
      ]
    }
  ]
}

(2)module.json5 :聲明快捷方式配置文件的引用,關聯至應用模塊。

{
  "module": {
    "abilities": [
      {
        "name": "EntryAbility",
        "srcEntry": "./ets/entryability/EntryAbility.ets",
        "skills": [
          {
            "entities": ["entity.system.home"],
            "actions": ["ohos.want.action.home"]
          }
        ],
        "metadata": [
          {
            "name": "ohos.ability.shortcuts",
            "resource": "$profile:shortcuts_config" // 引用profile目錄下的配置文件
          }
        ]
      }
    ]
  }
}

(3)關鍵字段說明

字段說明
shortcutId唯一標識(長度≤63字節),如id_company。
label顯示名稱(支持資源索引),如$string:Go_to_the_Company。
icon圖標資源索引,如$media:company。
wants目標跳轉信息,包含包名、模塊名、Ability名稱及自定義參數(parameters)。

2、快捷入口跳轉邏輯

import router from '@ohos.router';

export default class EntryAbility extends Ability {
  private context: UIAbilityContext | undefined;

  onCreate(want: Want, launchParam: AbilityConstant.LaunchParam) {
    super.onCreate(want, launchParam);
    this.context = this.getContext();
    // 首次啟動時加載首頁
    router.pushUrl({
      url: 'pages/Index',
      context: this.context
    });
  }

  onNewWant(want: Want, launchParam: AbilityConstant.LaunchParam) {
    const page = want.parameters?.page; // 提取快捷方式傳遞的參數
    if (page && this.context) {
      router.pushUrl({
        url: `pages/${page}`, // 動態拼接頁面路徑
        context: this.context
      });
    }
  }
}

注意

  1. 快捷方式數量 :僅支持跳轉至UIAbility入口頁面,最多配置4個。
  2. 參數校驗
    在onNewWant中增加參數非空校驗,避免因快捷方式參數缺失導致應用崩潰:
if (!page || !this.context) {
  hilog.error(0x0000, 'Shortcut', 'Invalid parameters or context');
  return;
}
  1. 卡片 :可展示動態內容,支持跳轉至非入口頁面。

審核編輯 黃宇

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

    關注

    60

    文章

    2620

    瀏覽量

    44059
  • HarmonyOS
    +關注

    關注

    80

    文章

    2126

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    HarmonyOS 5】鴻蒙應用隱私保護詳解

    HarmonyOS 5】鴻蒙應用隱私保護詳解 ##鴻蒙開發能力 ##HarmonyOS SDK應用服務##鴻蒙金融類應用 (金融理財# 一、前言 在今天這個手機不離手的時代,我們每天
    的頭像 發表于 07-11 18:30 ?301次閱讀

    HarmonyOS 5】鴻蒙中進度條的使用詳解

    HarmonyOS 5】鴻蒙中進度條的使用詳解 ##鴻蒙開發能力 ##HarmonyOS SDK應用服務##鴻蒙金融類應用 (金融理財# 一、Ha
    的頭像 發表于 07-11 18:26 ?227次閱讀
    【<b class='flag-5'>HarmonyOS</b> <b class='flag-5'>5</b>】鴻蒙中進度條的使用<b class='flag-5'>詳解</b>

    HarmonyOS 5】鴻蒙星閃NearLink詳解

    HarmonyOS 5】鴻蒙星閃NearLink詳解 ##鴻蒙開發能力 ##HarmonyOS SDK應用服務##鴻蒙金融類應用 (金融理財# 一、前言 鴻蒙星閃NearLink K
    的頭像 發表于 07-11 18:24 ?316次閱讀
    【<b class='flag-5'>HarmonyOS</b> <b class='flag-5'>5</b>】鴻蒙星閃NearLink<b class='flag-5'>詳解</b>

    HarmonyOS 5】鴻蒙mPaaS詳解

    HarmonyOS 5】鴻蒙mPaaS詳解 ##鴻蒙開發能力 ##HarmonyOS SDK應用服務##鴻蒙金融類應用 (金融理財# 一、mPaaS是什么? mPaaS 是 Mobi
    的頭像 發表于 07-11 18:23 ?285次閱讀
    【<b class='flag-5'>HarmonyOS</b> <b class='flag-5'>5</b>】鴻蒙mPaaS<b class='flag-5'>詳解</b>

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

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

    HarmonyOS 5】鴻蒙應用實現發票掃描、文檔掃描輸出PDF圖片或者表格的功能

    HarmonyOS 5】鴻蒙應用實現發票掃描、文檔掃描輸出PDF圖片或者表格的功能 ##鴻蒙開發能力 ##HarmonyOS SDK應用服
    的頭像 發表于 07-11 18:16 ?287次閱讀
    【<b class='flag-5'>HarmonyOS</b> <b class='flag-5'>5</b>】鴻蒙應用<b class='flag-5'>實現</b>發票掃描、文檔掃描輸出PDF圖片或者表格的<b class='flag-5'>功能</b>

    如何實現桌面快捷方式【2】--ArkTS開發

    主要目的。大家其實一直都忽略了一種入口方式,即快捷入口。今天我用了一個下午為我的“真律法律咨詢平臺”app新增了這個功能,中間踩了不少的坑……為了方便大家的開發,我來分享一下具體的開發流程 示例 當長按App
    發表于 06-30 19:14

    如何實現桌面快捷方式【1】--ArkTS開發

    的圖標時,除了基本的“添加應用鎖”和“卸載”外,還可以彈出其他的快捷入口,更厲害的是,這幾個快捷入口,是可以拖出來的,會形成一個單獨的類似“app”的樣式,也可以點擊。 實現方式 相關
    發表于 06-30 19:03

    HarmonyOS 5】應用更新功能詳解

    與迭代需求的優選方案。這類彈窗主要用于向用戶推送新版本更新通知,而在引導用戶完成更新操作的實現層面,HarmonyOS 提供了完善的應用市場能力支撐,例如本文所介紹的 updateManager(更新功能
    發表于 06-22 18:44

    HarmonyOS 5】VisionKit人臉活體檢測詳解

    HarmonyOS 5】VisionKit人臉活體檢測詳解 ##鴻蒙開發能力 ##HarmonyOS SDK應用服務##鴻蒙金融類應用 (金融理財# 一、VisionKit人臉活體
    的頭像 發表于 06-21 11:52 ?299次閱讀
    【<b class='flag-5'>HarmonyOS</b> <b class='flag-5'>5</b>】VisionKit人臉活體檢測<b class='flag-5'>詳解</b>

    HarmonyOS 5 makeObserved接口詳解

    HarmonyOS 5】makeObserved接口詳解 ##鴻蒙開發能力 ##HarmonyOS SDK應用服務##鴻蒙金融類應用 (金融理財# 一、makeObserved接口
    的頭像 發表于 06-16 17:58 ?287次閱讀

    HarmonyOS 5】鴻蒙中的UIAbility詳解(三)

    HarmonyOS 5】鴻蒙中的UIAbility詳解(三) ##鴻蒙開發能力 ##HarmonyOS SDK應用服務##鴻蒙金融類應用 (金融理財# 一、前言 本文是鴻蒙中的UIA
    的頭像 發表于 06-14 22:32 ?49次閱讀

    HarmonyOS 5】鴻蒙CodeGenie AI輔助編程工具詳解

    HarmonyOS 5】鴻蒙CodeGenie AI輔助編程工具詳解 一、前言 1、CodeGenie是什么?CodeGenie (代碼精靈)作為鴻蒙DevEco IDE自帶的AI輔助編碼工具
    發表于 06-11 16:34

    HarmonyOS5云服務技術分享--認證文檔問題

    文「集成SDK」章節)。 初始化SDK并添加網絡權限。 ??5. 實現賬號登錄認證?? ??支持方式??: ??標準登錄??:手機、郵箱、華為賬號、自有賬號、匿名賬號。 ??高級功能
    發表于 05-22 13:20

    AD軟件快捷鍵設置和導入方法

    鼠標放在上圖中的“交互式布線”上,然后按下Ctrl鍵,同時點擊鼠標左鍵,就出現下圖所示的對話框,在這里就可以修改走線命令的快捷鍵了。 接著,選擇快捷方式下面的“主要的”右側,按下小鍵盤的5,就看
    發表于 03-26 10:03