哈哈哈哈哈操欧洲电影,久草网在线,亚洲久久熟女熟妇视频,麻豆精品色,久久福利在线视频,日韩中文字幕的,淫乱毛视频一区,亚洲成人一二三,中文人妻日韩精品电影

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

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

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

HarmonyOS實戰(zhàn):高德地圖自定義定位圖標展示

尤楓 ? 來源:jf_54996641 ? 作者:jf_54996641 ? 2025-06-09 14:59 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前言

地圖定位功能基本上已經(jīng)成了日常應用程序的必備功能之一,在日常開發(fā)地圖定位的功能的時候難免會遇到很多意想不到的問題,本篇文章記錄日常開發(fā)過程中的細節(jié)與完整的流程,幫助更多的開發(fā)者避免遇到類似的問題,建議點贊收藏!

實現(xiàn)效果

需求分析

  • 首先需要實現(xiàn)一個自定義的圖標替代系統(tǒng)默認的箭頭。
  • 獲取定位權(quán)限與位置信息。
  • 獲取定位結(jié)果并展示當前位置。

技術(shù)實現(xiàn)

  1. 鴻蒙的實際開發(fā)過程中,地圖定位權(quán)限首先需要申請兩個權(quán)限,分別是:
const permissions: Array< Permissions > = [
  'ohos.permission.APPROXIMATELY_LOCATION',
  'ohos.permission.LOCATION'
]

static applyPermission(context: common.UIAbilityContext, permissions: Array< Permissions >, grantedBlock: () = > void,
                       deniedBlock?: () = > void) {
  let atManager = abilityAccessCtrl.createAtManager()
  let permissionGrantedNumber: number = 0 //記錄已經(jīng)授權(quán)的總個數(shù)
  atManager.requestPermissionsFromUser(context, permissions).then((data) = > {
    for (let index = 0; index < data.authResults.length; index++) {
      if (data.authResults[index] == 0) { //已授權(quán)
        permissionGrantedNumber++;
      }
    }
    if (permissionGrantedNumber == permissions.length) {
      grantedBlock()
    } else {
      if (deniedBlock) {
        deniedBlock()
      } else {
        //打開系統(tǒng)設置
        PermissionUtil.openPermissionsInSystemSettings(context)
      }
    }
  })
}

2. 兩個權(quán)限必須同時申請,缺一不可,同時如果權(quán)限是被拒絕過的,那就要手動打開系統(tǒng)設置,跳轉(zhuǎn)到對應應用程序的位置提示用戶手動打開權(quán)限。

let bundleInfo: bundleManager.BundleInfo =
      await bundleManager.getBundleInfoForSelf(bundleManager.BundleFlag.GET_BUNDLE_INFO_WITH_APPLICATION);

    let wantInfo: Want = {
      bundleName: 'com.huawei.hmos.settings',
      abilityName: 'com.huawei.hmos.settings.MainAbility',
      uri: 'application_info_entry',
      parameters: {
        settingsParamBundleName: bundleInfo.name
      }
    }
    context.startAbility(wantInfo).then(() = > {
    })
  1. 得到系統(tǒng)授權(quán)后,開始使用高德定位。
let listener: IAMapLocationListener = {
      onLocationChanged: (location) = > {
        console.info('地圖定位成功:  ')
      }, onLocationError: (e) = > {
        console.info('地圖定位失敗:  ' + JSON.stringify(e))
        if (!this.hasUserLocation) {
          // 嘗試獲取緩存位置
          this.getLastLocation(success, error)
        }
      }
    };
    LocationManager.getInstance().addListener(listener)
  1. 定位成功后,添加用戶自定義的圖標。
this.aMap?.moveCamera(CameraUpdateFactory.newLatLngZoom(new LatLng(userLat,userLon), 15));
          let options: MarkerOptions = new MarkerOptions();
          options.setPosition(new LatLng(userLat, userLon));
          options.setIcon(await BitmapDescriptorFactory.fromView(() = > {
            this.customMarkerBuilder()
          }))
          this.aMap?.addMarker(options);

//自定義圖標
 @Builder
  customMarkerBuilder(){
    Image($r("app.media.user_location_icon"))
      .width($r('app.float.vp_40'))
      .height($r('app.float.vp_40'))
  }
  1. 這里需要特別注意經(jīng)緯度 userLat,userLon 必須是 float 類型,不然定位不準。這點一定要注意。因為鴻蒙沒有提供 float 類型的屬性,這里需要使用 Number.parseFloat 對數(shù)據(jù)進行轉(zhuǎn)換。(真實慘痛經(jīng)歷,定位跑到歐洲去了)。
  2. 當完成這些操作,大多數(shù)人都認為基本上可以正常顯示了,但是萬萬沒想到地圖依然沒有定位到當前位置。這是因為很多人忽略了系統(tǒng)的 GPS 定位按鈕是否打開,也就是系統(tǒng)下拉菜單中的位置圖標。

  1. 必須在檢查權(quán)限的時候,檢查系統(tǒng)位置開關(guān)是否打開。
let location =  geoLocationManager.isLocationEnabled()
      console.log("定位權(quán)限是否開啟:"+location)
  1. 如果沒有打開,則需要跳轉(zhuǎn)到系統(tǒng)對應的位置提示用戶打開。
context.startAbility(
          {
            bundleName: "com.huawei.hmos.settings",

            abilityName: "com.huawei.hmos.settings.MainAbility",

            uri: "location_manager_settings"

          },
  1. 完成以上操作,地圖就能正常顯示自定義位置圖標了。

總結(jié)

鴻蒙對于位置權(quán)限要求十分嚴格,必須同時滿足兩個權(quán)限申請,同時也要注意 GPS 的位置開關(guān)是否正常打開。另外特別注意的是經(jīng)緯度是否是 float 類型,否則會導致位置跑偏。學會的小伙伴趕緊動手試試吧!

審核編輯 黃宇

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

    關(guān)注

    60

    文章

    3012

    瀏覽量

    46151
  • HarmonyOS
    +關(guān)注

    關(guān)注

    80

    文章

    2156

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    使用Python/MyHDL創(chuàng)建自定義FPGA IP

    使用 Python/MyHDL 創(chuàng)建自定義 FPGA IP,與 Vivado 集成,并通過 PYNQ 進行控制——實現(xiàn)軟件上的簡單硬件設計。
    的頭像 發(fā)表于 04-09 09:53 ?178次閱讀
    使用Python/MyHDL創(chuàng)建<b class='flag-5'>自定義</b>FPGA IP

    MCUXpresso SDK創(chuàng)建自定義清單

    概述 MCUXpresso SDK 24.12 介紹塞恩漢CED支持自定義清單,使開發(fā)人員能夠精確定義其工作區(qū)中包含哪些組件、驅(qū)動程序、中間件和板支持包。此功能在極簡主義、可重復性和 CI/CD
    發(fā)表于 04-07 07:11

    極海APM32F427如何實現(xiàn)自定義USB HID設備與PC進行通信

    最近需要使用到 APM32F427 枚舉成Custom HID設備進行用戶自定義通信,但是官方的例程只有提供的HID枚舉為鼠標或者鍵盤類型的設備。這里記錄一下,怎么使用Geehy官方的USB中間件,實現(xiàn)自定義的USB HID設備進行用戶通信。
    的頭像 發(fā)表于 03-30 09:30 ?2728次閱讀
    極海APM32F427如何實現(xiàn)<b class='flag-5'>自定義</b>USB HID設備與PC進行通信

    如何為 Vision Five 2 編譯自定義 Linux 內(nèi)核?

    Vision Five 2 的 Debian 用戶指南只提供了半頁關(guān)于如何編譯自己的內(nèi)核的相當稀疏的內(nèi)容。僅從該文檔中,我無法制作我的自定義內(nèi)核。那里的信息似乎相當不完整。如果有人能提供一些
    發(fā)表于 02-24 07:44

    無圖形界面模式下自定義檢查工具的應用

    此前文章已介紹 ANSA 中的自定義檢查工具。本文將探討該功能在無圖形界面(No-GUI)模式下的應用,旨在滿足標準化工作流程的需求,適用于需要高度自動化的前處理場景。通過集成自定義檢查,用戶可實現(xiàn)工作流程的高效自動化運行。
    的頭像 發(fā)表于 11-30 14:13 ?743次閱讀
    無圖形界面模式下<b class='flag-5'>自定義</b>檢查工具的應用

    采用匯編指示符來使用自定義指令

    * 使用riscv-nuclei-elf-objdump -d a.out &gt; main.dump命令查看反匯編代碼,結(jié)果如下所示 如圖所示,在指定位置插入了自定義的指令數(shù)據(jù)。 2
    發(fā)表于 10-28 06:02

    地圖與通義實驗室達成深度合作

    在AI原生浪潮推動下,阿里巴巴集團旗下地圖與通義實驗室宣布達成深度合作,并在近日發(fā)布的地圖
    的頭像 發(fā)表于 08-15 17:23 ?1771次閱讀

    LOTO示波器自定義解碼功能—CANFD解碼

    LOTO示波器軟件更新了自定義解碼功能,并在bilibili上傳了演示視頻,視頻鏈接: https://www.bilibili.com/video/BV1wq3ezjEjQ
    的頭像 發(fā)表于 07-11 10:34 ?1167次閱讀
    LOTO示波器<b class='flag-5'>自定義</b>解碼功能—CANFD解碼

    大彩講堂:VisualTFT軟件如何自定義圓形進度條

    VisualTFT軟件如何自定義圓形進度條
    的頭像 發(fā)表于 07-07 17:10 ?1871次閱讀
    大彩講堂:VisualTFT軟件如何<b class='flag-5'>自定義</b>圓形進度條

    HarmonyOS實戰(zhàn):3秒實現(xiàn)一個自定義輪播圖

    那么簡單,需要考慮的細節(jié)很多。不過在 HarmonyOS 中實現(xiàn)一個輪播圖卻是十分的簡單,本篇文章教你在最短的時間內(nèi)快速實現(xiàn)一個自定義的 輪播圖,建議點贊收藏!
    的頭像 發(fā)表于 06-24 17:06 ?1581次閱讀

    KiCad 中的自定義規(guī)則(KiCon 演講)

    “ ?Seth Hillbrand 在 KiCon US 2025 上為大家介紹了 KiCad 的規(guī)則系統(tǒng),并詳細講解了自定義規(guī)則的設計與實例。? ” ? 演講主要圍繞 加強 KiCad 中的自定義
    的頭像 發(fā)表于 06-16 11:17 ?2517次閱讀
    KiCad 中的<b class='flag-5'>自定義</b>規(guī)則(KiCon 演講)

    HarmonyOS實戰(zhàn)自定義時間選擇器

    前言 最近在日常鴻蒙開發(fā)過程中,經(jīng)常會使用一些時間選擇器,鴻蒙官方提供的時間選擇器滿足不了需求,所以自己動手自定義一些經(jīng)常會使用到的時間選擇器,希望能幫到你,建議點贊收藏! 實現(xiàn)效果 需求分析 默認
    的頭像 發(fā)表于 06-09 15:51 ?744次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>實戰(zhàn)</b>:<b class='flag-5'>自定義</b>時間選擇器

    HarmonyOS實戰(zhàn)地圖定位功能完整流程詳解

    前言 地圖定位功能相信很多人都用過,在鴻蒙的應用程序開發(fā)中,使用地圖定位功能變得十分常見,
    的頭像 發(fā)表于 06-09 15:23 ?1312次閱讀

    HarmonyOS應用自定義鍵盤解決方案

    自定義鍵盤是一種替換系統(tǒng)默認鍵盤的解決方案,可實現(xiàn)鍵盤個性化交互。允許用戶結(jié)合業(yè)務需求與操作習慣,對按鍵布局進行可視化重構(gòu)、設置多功能組合鍵位,使輸入更加便捷和舒適。在安全防護層面,自定義鍵盤可以
    的頭像 發(fā)表于 06-05 14:19 ?2581次閱讀

    地圖與Rokid達成合作

    近日,地圖與Rokid宣布達成合作,將共同推出基于全場景智能眼鏡Rokid Glasses的全球首個導航智能體(NaviAgent)應用,標志著
    的頭像 發(fā)表于 05-20 16:00 ?912次閱讀
    德化县| 勃利县| 五大连池市| 惠东县| 汶上县| 天长市| 辛集市| 桐梓县| 丹江口市| 平乐县| 无锡市| 东光县| 罗平县| 平阴县| 宁夏| 苍溪县| 婺源县| 库尔勒市| 上林县| 曲周县| 益阳市| 怀来县| 冷水江市| 霸州市| 竹山县| 彭阳县| 将乐县| 汶川县| 阿拉善盟| 田林县| 黎城县| 唐河县| 昌都县| 沁水县| 沙洋县| 元谋县| 北安市| 平邑县| 沐川县| 台北县| 朝阳县|