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

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

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

探索HarmonyOS位置服務(wù):為用戶提供直觀的坐標顯示

ITMING ? 來源:ITMING ? 作者:ITMING ? 2024-08-20 10:51 ? 次閱讀

關(guān)于作者
白曉明
寧夏圖爾科技有限公司董事長兼CEO、堅果派聯(lián)合創(chuàng)始人
華為HDE、潤和軟件HiHope社區(qū)專家、鴻蒙KOL、倉頡KOL
華為開發(fā)者學(xué)堂/51CTO學(xué)堂/CSDN學(xué)堂認證講師
開放原子開源基金會2023開源貢獻之星
OpenHarmony三方庫貢獻者
公眾號:開源開發(fā)者新視界(openwatcher)

在先前的環(huán)節(jié)中,我們所獲取到的位置信息是以經(jīng)緯度的方式來呈現(xiàn)。不可否認,這種呈現(xiàn)方式在描述位置時具有極高的準確性,能夠精確地定位到地球的每一個點。然而,不得不承認的是,對于普通用戶而言,經(jīng)緯度的表述形式顯示得過于專業(yè)和晦澀,缺乏直觀性和易理解性,確實不夠友好。

HarmonyOS的位置服務(wù)(Location Kit)則猶如一位貼心的助手,為開發(fā)者提供了地理編碼轉(zhuǎn)化和逆地理編碼轉(zhuǎn)化這兩種極為實用的能力。其中,地理編碼就像是一個信息豐富的寶藏,它包含了多個屬性來對位置進行細致入微的描述。比如,它涵蓋了國家這個宏觀層面的標識,讓我們能夠快速確定位置所在的大區(qū)域;還有行政區(qū)劃,進一步明確了具體的地區(qū)范圍;街道的描述則讓我們對周邊環(huán)境有了更清晰的認知;門牌號更是精準地指向了具體的地點;而地址描述則以一種更為通俗易懂的方式將所有這些信息整合起來,為用戶提供一個全面而直觀的位置表達。這樣豐富多樣的信息呈現(xiàn)方式,無疑更加便于用戶理解和把握自己所處的位置,無論是在日常的出行導(dǎo)航中,還是在社交應(yīng)用里與朋友分享位置,都能讓用戶輕松便捷地知曉自己的具體方位,為我們的數(shù)字生活帶來更多的便利和舒適體驗。

查看地理編碼與逆地理編碼服務(wù)是否可用

首先,開發(fā)者在進行操作時,需要優(yōu)先調(diào)用isGeoServiceAvailable方法來查詢地理編碼與逆地理編碼服務(wù)的可用性。這一步驟至關(guān)重要,因為只有當確定服務(wù)可用的情況下,才能夠進行后續(xù)的編碼轉(zhuǎn)化操作。如果經(jīng)過查詢發(fā)現(xiàn)服務(wù)不可用,那么就意味著該設(shè)備并不具備地理編碼與逆地理編碼轉(zhuǎn)化能力。這種情況下,開發(fā)者務(wù)必不要使用相關(guān)接口,以免引起不必要的錯誤或者異常情況,從而確保應(yīng)用程序的穩(wěn)定性。

let isAvailable = geoLocationManager.isGeocoderAvailable();

把坐標轉(zhuǎn)化為地理位置信息

在實際應(yīng)用中,我們可以通過調(diào)用getCurrentLocation()函數(shù)獲取當前位置,也可以使用on('locationChange')方法進行位置變化訂閱。然而,通過這兩種方式所獲取到的位置信息都是以坐標形式呈現(xiàn)出來的,對于普通用戶而言,這種坐標形式的位置信息可能會顯得比較抽象且難以理解。

為了能夠讓用戶更加直觀地理解位置信息,開發(fā)者可以調(diào)用getAddressesFromLocation方法,該方法能夠?qū)⒆鴺诵问降奈恢眯畔⑥D(zhuǎn)化為地理位置信息。比如國家信息、行政區(qū)、城市信息、區(qū)/縣信息、路名等等。具體位置信息如以下類所示:

/**
 * 地理編碼地址信息
 */
export interface GeoAddress {
    /**
     * 緯度信息,正值表示北緯,負值表示南緯。
     * 取值范圍為[-90, 90],僅支持WGS84坐標系。
     */
    latitude?: number;
    /**
     * 經(jīng)度信息,正值表示東經(jīng),負值表示西經(jīng)。
     * 取值范圍為[-180, 180],僅支持WGS84坐標系。
     */
    longitude?: number;
    /**
     * 位置描述信息的語言。
     * zh:中文;en:英文。
     */
    locale?: string;
    /**
     * 詳細地址信息。
     */
    placeName?: string;
    /**
     * 國家碼信息。
     */
    countryCode?: string;
    /**
     * 國家信息。
     */
    countryName?: string;
    /**
     * 一級行政區(qū),一般是省/州。
     */
    administrativeArea?: string;
    /**
     * 二級行政區(qū),一般是市。
     */
    subAdministrativeArea?: string;
    /**
     * 城市信息,一般是市。
     */
    locality?: string;
    /**
     * 子城市信息,一般是區(qū)/縣。
     */
    subLocality?: string;
    /**
     * 路名信息。
     */
    roadName?: string;
    /**
     * 子路名信息。
     */
    subRoadName?: string;
    /**
     * 門牌號信息。
     */
    premises?: string;
    /**
     * 郵政編碼信息。
     */
    postalCode?: string;
    /**
     * 聯(lián)系方式信息。
     */
    phoneNumber?: string;
    /**
     * 位置信息附件的網(wǎng)址信息。
     */
    addressUrl?: string;
    /**
     * 附加的描述信息。
     * 目前包含城市編碼cityCode和區(qū)劃編碼adminCode。
     */
    descriptions?: Array< string >;
    /**
     * 附加的描述信息數(shù)量。
     * 取值大于等于0,推薦該值小于10。
     */
    descriptionsSize?: number;
}

以轉(zhuǎn)化當前坐標為例,代碼如下所示:

/**
 * 逆地理編碼請求參數(shù)
 */
export interface ReverseGeoCodeRequest {
    /**
     * 指定位置描述信息的語言。
     * zh:中文;en:英文。
     */
    locale?: string;
    /**
     * 限制查詢結(jié)果在指定的國家區(qū),采用ISO3166-1 alpha-2。
     * CN代表中國。
     */
    country?: string;
    /**
     * 緯度信息。
     */
    latitude: number;
    /**
     * 經(jīng)度信息。
     */
    longitude: number;
    /**
     * 指定返回位置信息的最大個數(shù)。
     */
    maxItems?: number;
}

/**
 * 坐標轉(zhuǎn)化為地理位置信息
 * @param latitude
 * @param longitude
 * @param maxItems
 * @returns
 */
static async getAddressesFromLocation(latitude: number,
  longitude: number, maxItems: number = 1): Promise< geoLocationManager.GeoAddress[] | undefined > {
  const request: geoLocationManager.ReverseGeoCodeRequest = {
    locale: "zh",
    country: "CN",
    latitude,
    longitude,
    maxItems
  };
  let location: geoLocationManager.GeoAddress[] | undefined = undefined;
  try {
    location = await geoLocationManager.getAddressesFromLocation(request);
    console.info(`[AppLogger]坐標轉(zhuǎn)化為地理位置信息:${JSON.stringify(location)}`);
  } catch (error) {
    const err = error as BusinessError;
    console.error(`[AppLogger]坐標轉(zhuǎn)化為地理位置信息異常:${JSON.stringify(err)}`);
  }
  return location;
}


Button('坐標轉(zhuǎn)化為地理位置信息')
  .onClick(async () = > {
    this.location = await LocationUtil.getSingleLocationRequest(geoLocationManager.LocatingPriority.PRIORITY_LOCATING_SPEED);
    if (this.location !== undefined) {
      this.locationArr = await LocationUtil.getAddressesFromLocation(this.location?.latitude, this.location?.longitude);
    }
  })

image20240817155340722.png

把地理位置信息轉(zhuǎn)化為坐標

在導(dǎo)航類App的實際使用場景中,當用戶進行位置搜索時,通常會輸入具體的位置信息,比如某個商場的名稱、某條街道的地址或者某個景點的具體描述等。但是,對于地圖的顯示而言,它所需要的是精確的位置坐標信息,只有這樣才能夠準確地在地圖上進行標注和展示。

在這種情況下,為了實現(xiàn)從用戶輸入的位置描述到地圖所需的坐標信息的轉(zhuǎn)化,開發(fā)者可以調(diào)用getAddressesFromLocationName方法。這個方法就像是一座橋梁,能夠?qū)⒂脩糨斎氲闹庇^的位置描述轉(zhuǎn)化為地圖能夠識別和使用的位置坐標。通過這樣的轉(zhuǎn)化,不僅可以滿足地圖顯示的需求,還能夠為用戶提供更加準確和便捷的導(dǎo)航服務(wù),讓用戶能夠更加輕松地找到自己想要達到的目的地。

以轉(zhuǎn)化用戶輸入地理位置為例,代碼如下所示:

/**
 * 地理編碼請求參數(shù)
 */
export interface GeoCodeRequest {
    /**
     * 位置描述信息的語言。
     * zh:中文;en:英文。
     */
    locale?: string;
    /**
     * 限制查詢結(jié)果在指定的國家區(qū),采用ISO3166-1 alpha-2。
     * CN代表中國。
     */
    country?: string;
    /**
     * 位置信息描述。
     */
    description: string;
    /**
     * 返回結(jié)果信息的最大個數(shù)。
     */
    maxItems?: number;
    /**
     * 最小緯度信息。
     */
    minLatitude?: number;
    /**
     * 最小經(jīng)度信息。
     */
    minLongitude?: number;
    /**
     * 最大緯度信息。
     */
    maxLatitude?: number;
    /**
     * 最大經(jīng)度信息。
     */
    maxLongitude?: number;
}

/**
 * 地理位置轉(zhuǎn)化為坐標信息
 * @param description
 * @param maxItems
 * @returns
 */
static async getAddressesFromLocationName(description: string,
  maxItems: number = 1): Promise< geoLocationManager.GeoAddress[] | undefined > {
  const request: geoLocationManager.GeoCodeRequest = {
    description,
    maxItems
  };
  let location: geoLocationManager.GeoAddress[] | undefined = undefined;
  try {
    location = await geoLocationManager.getAddressesFromLocationName(request);
    console.info(`[AppLogger]地理位置轉(zhuǎn)化為坐標信息:${JSON.stringify(location)}`);
  } catch (error) {
    const err = error as BusinessError;
    console.error(`[AppLogger]地理位置轉(zhuǎn)化為坐標信息異常:${JSON.stringify(err)}`);
  }
  return location;
}

TextInput({ placeholder: "請輸入具體的位置信息..." })
  .onChange((value: string) = > {
    this.val = value;
  })
Button('坐標轉(zhuǎn)化為地理位置信息')
  .onClick(async () = > {
    if (LocationUtil.usedGeocoderAvailable()) {
      this.locationArr = await LocationUtil.getAddressesFromLocationName(this.val, 5);
    }
  })

image20240817170727668.png

使用ForEach渲染列表數(shù)據(jù)

List() {
  ForEach(this.locationArr, (item: geoLocationManager.GeoAddress) = > {
    ListItem() {
      Column({ space: 8 }) {
        Text(item.placeName)
          .fontSize(16)
        Text(`坐標:[${item.latitude}, ${item.longitude}]`)
          .fontSize(12)
        Text(`${item.countryName} ${item.administrativeArea} ${item.locality} ${item.subLocality} ${item.roadName} ${item.subRoadName}`)
          .fontSize(12)
      }
      .width('100%')
      .padding(12)
      .backgroundColor(0xF1F3F5)
      .borderRadius(8)
      .justifyContent(FlexAlign.Start)
    }
  })
}
.width('90%')
.divider({
  strokeWidth: 4,
  color: 0xFFFFFF
})

image20240817193205402.png

審核編輯 黃宇

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

    關(guān)注

    0

    文章

    5

    瀏覽量

    2052
  • HarmonyOS
    +關(guān)注

    關(guān)注

    79

    文章

    1966

    瀏覽量

    29962
收藏 人收藏

    評論

    相關(guān)推薦

    HarmonyOS NEXT應(yīng)用元服務(wù)開發(fā)Intents Kit(意圖框架服務(wù))本地搜索方案概述

    本地搜索”特性例,當用戶在使用音樂應(yīng)用/元服務(wù)產(chǎn)生行為時,應(yīng)用/元服務(wù)可以將音樂的數(shù)據(jù)通過意圖框架API接口共享到HarmonyOS。這里
    發(fā)表于 11-06 10:59

    人員定位技術(shù)向化工廠的智慧平臺提供精準的位置服務(wù)

    化工廠的智慧平臺提供精準的位置服務(wù)。 人員定位系統(tǒng)功能1、三維展示模塊系統(tǒng)平臺采用三維地圖作為基礎(chǔ),實現(xiàn)變電站整體的三維場景瀏覽、報警監(jiān)控、重要數(shù)據(jù)統(tǒng)計、人員精確定位、歷史軌跡查詢、作業(yè)票導(dǎo)入、電子圍欄、作業(yè)過
    的頭像 發(fā)表于 08-30 11:00 ?224次閱讀
    人員定位技術(shù)向化工廠的智慧平臺<b class='flag-5'>提供</b>精準的<b class='flag-5'>位置服務(wù)</b>

    服務(wù)體驗-服務(wù)發(fā)現(xiàn)

    服務(wù)發(fā)現(xiàn),無論線上或線下的方式都可以發(fā)現(xiàn)元服務(wù)。 線上:基于用戶意圖。從精準意圖的搜索、用戶事件觸發(fā)的推薦到主動探索等場景。
    發(fā)表于 07-15 17:02

    HarmonyOS NEXT Developer Beta1中的Kit

    HarmonyOS NEXT Developer Preview1(API 11)版本開始,HarmonyOS SDK以Kit維度提供豐富、完備的開放能力,涵蓋應(yīng)用框架、系統(tǒng)、媒體、圖形、應(yīng)用
    發(fā)表于 06-26 10:47

    鴻蒙原生應(yīng)用元服務(wù)開發(fā)-位置服務(wù)申請權(quán)限

    申請位置權(quán)限開發(fā)指導(dǎo) 場景概述 應(yīng)用在使用位置服務(wù)系統(tǒng)能力前,需要檢查是否已經(jīng)獲取用戶授權(quán)訪問設(shè)備位置信息。如未獲得授權(quán),可以向用戶申請需要
    發(fā)表于 06-18 15:27

    鴻蒙原生應(yīng)用元服務(wù)開發(fā)-位置服務(wù)開發(fā)概述

    ,無論用戶設(shè)備在室內(nèi)或是戶外,都可以準確地確定設(shè)備位置位置服務(wù)除了提供基礎(chǔ)的定位服務(wù)之外,還提供
    發(fā)表于 06-17 17:47

    鴻蒙原生應(yīng)用元服務(wù)開發(fā)-位置服務(wù)獲取設(shè)備信息開發(fā)

    ,如車載、步行導(dǎo)航。 . 在此場景下,保證系統(tǒng)提供位置結(jié)果精度最優(yōu),主要使用GNSS定位技術(shù)提供定位服務(wù),結(jié)合場景特點,在導(dǎo)航啟動之初,
    發(fā)表于 06-14 14:46

    鴻蒙原生應(yīng)用元服務(wù)開發(fā)-位置服務(wù)地理編碼轉(zhuǎn)化開發(fā)

    (逆)地理編碼轉(zhuǎn)化開發(fā) 場景概述 使用坐標描述一個位置,非常準確,但是并不直觀,面向用戶表達并不友好。系統(tǒng)向開發(fā)者提供了以下兩種轉(zhuǎn)化能力。
    發(fā)表于 06-12 17:22

    HarmonyOS開發(fā)技術(shù)全面分析

    、穿戴專有業(yè)務(wù)、IoT 專有業(yè)務(wù)等子系統(tǒng)組成。 ? 硬件服務(wù)子系統(tǒng)集 : HarmonyOS 提供硬件服務(wù),由
    發(fā)表于 02-21 16:31

    鴻蒙應(yīng)用/元服務(wù)開發(fā)-窗口概述

    在一定范圍內(nèi)對窗口的位置和疊加層次進行調(diào)整。 提供窗口動效。 在窗口顯示、隱藏及窗口間切換時,窗口模塊通常會添加動畫效果,以使各個交互過程更加連貫流暢。在HarmonyOS中,應(yīng)用窗口
    發(fā)表于 02-19 10:33

    HarmonyOS SDK 助力新浪新聞打造精致易用的新聞應(yīng)用

    之一,從有聲資訊入手,基于 Speech Kit 朗讀控件上線聽新聞功能,讓新浪新聞充分發(fā)揮 HarmonyOS 原生智能優(yōu)勢,鴻蒙用戶帶來更加智能易用的新聞即時獲取體驗。 朗讀控件,更智能、更精
    發(fā)表于 02-07 15:51

    HarmonyOS位置服務(wù)開發(fā)指南

    ”);通過這些定位技術(shù),無論用戶設(shè)備在室內(nèi)或是戶外,都可以準確地確定設(shè)備位置。 位置服務(wù)除了提供基礎(chǔ)的定位服務(wù)之外,還
    發(fā)表于 11-27 16:02

    【鴻蒙生態(tài)千帆起】HarmonyOS系統(tǒng)級地圖與位置服務(wù),賦能廣大開發(fā)者

    設(shè)備接續(xù)、無縫流轉(zhuǎn)。! 未來,HarmonyOS系統(tǒng)級地圖與位置服務(wù)將深入更多行業(yè)場景,開發(fā)者提供更多更有競爭力的產(chǎn)品及解決方案。
    發(fā)表于 11-22 10:37

    【鴻蒙生態(tài)千帆起】HarmonyOS系統(tǒng)級地圖與位置服務(wù),賦能廣大開發(fā)者

    位置服務(wù)能力。 端云協(xié)同軟硬結(jié)合,提供更全面差異化的位置服務(wù) 華為 終端云服務(wù)地圖 業(yè)務(wù)高級產(chǎn)品經(jīng)理表示, Petal Maps 將為 Harmo
    的頭像 發(fā)表于 11-21 21:10 ?562次閱讀
    【鴻蒙生態(tài)千帆起】<b class='flag-5'>HarmonyOS</b>系統(tǒng)級地圖與<b class='flag-5'>位置服務(wù)</b>,賦能廣大開發(fā)者

    HarmonyOS上使用ArkUI實現(xiàn)計步器應(yīng)用

    介紹 本篇Codelab使用ArkTS語言實現(xiàn)計步器應(yīng)用,應(yīng)用主要包括計步傳感器、定位服務(wù)和后臺任務(wù)功能: 通過訂閱計步器傳感器獲取計步器數(shù)據(jù),處理后顯示。 通過訂閱位置服務(wù)獲取位置數(shù)
    發(fā)表于 11-16 11:17