精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

3天內不再提示

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

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

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

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

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

查看地理編碼與逆地理編碼服務是否可用

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

let isAvailable = geoLocationManager.isGeocoderAvailable();

把坐標轉化為地理位置信息

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

為了能夠讓用戶更加直觀地理解位置信息,開發者可以調用getAddressesFromLocation方法,該方法能夠將坐標形式的位置信息轉化為地理位置信息。比如國家信息、行政區、城市信息、區/縣信息、路名等等。具體位置信息如以下類所示:

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

以轉化當前坐標為例,代碼如下所示:

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

/**
 * 坐標轉化為地理位置信息
 * @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]坐標轉化為地理位置信息:${JSON.stringify(location)}`);
  } catch (error) {
    const err = error as BusinessError;
    console.error(`[AppLogger]坐標轉化為地理位置信息異常:${JSON.stringify(err)}`);
  }
  return location;
}


Button('坐標轉化為地理位置信息')
  .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

把地理位置信息轉化為坐標

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

在這種情況下,為了實現從用戶輸入的位置描述到地圖所需的坐標信息的轉化,開發者可以調用getAddressesFromLocationName方法。這個方法就像是一座橋梁,能夠將用戶輸入的直觀的位置描述轉化為地圖能夠識別和使用的位置坐標。通過這樣的轉化,不僅可以滿足地圖顯示的需求,還能夠為用戶提供更加準確和便捷的導航服務,讓用戶能夠更加輕松地找到自己想要達到的目的地。

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

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

/**
 * 地理位置轉化為坐標信息
 * @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]地理位置轉化為坐標信息:${JSON.stringify(location)}`);
  } catch (error) {
    const err = error as BusinessError;
    console.error(`[AppLogger]地理位置轉化為坐標信息異常:${JSON.stringify(err)}`);
  }
  return location;
}

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

image20240817170727668.png

使用ForEach渲染列表數據

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

審核編輯 黃宇

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

    關注

    0

    文章

    5

    瀏覽量

    2056
  • HarmonyOS
    +關注

    關注

    79

    文章

    1967

    瀏覽量

    30033
收藏 人收藏

    評論

    相關推薦

    HarmonyOS NEXT應用元服務開發Intents Kit(意圖框架服務)綜述

    ,準確且及時地獲取到用戶顯性、潛在意圖,從而實現個性化、多模態、精準的智慧分發。 三、智慧分發 方便開發者接入,智慧分發提供了多種特性類別,當前已開放習慣推薦、事件推薦、技能調用-語音、本地搜索,后續
    發表于 11-28 10:43

    HarmonyOS NEXT應用元服務開發Intents Kit(意圖框架服務)習慣推薦方案概述

    應用/元服務HarmonyOS交互。 當用戶使用應用/元服務播放歌單時,應用/元服務可以向Intents Kit共享該意圖,并
    發表于 11-19 17:59

    HarmonyOS NEXT應用元服務開發Intents Kit(意圖框架服務)本地搜索方案概述

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

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

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

    服務體驗-服務發現

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

    HarmonyOS NEXT Developer Beta1最新術語表

    服務 原名原子化服務,是HarmonyOS提供的一種面向未來的服務提供方式,是有獨立入口的(
    發表于 06-27 16:16

    HarmonyOS NEXT Developer Beta1中的Kit

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

    鴻蒙原生應用元服務開發-位置服務申請權限

    申請位置權限開發指導 場景概述 應用在使用位置服務系統能力前,需要檢查是否已經獲取用戶授權訪問設備位置信息。如未獲得授權,可以向用戶申請需要
    發表于 06-18 15:27

    鴻蒙原生應用元服務開發-位置服務開發概述

    ,無論用戶設備在室內或是戶外,都可以準確地確定設備位置。 位置服務除了提供基礎的定位服務之外,還提供
    發表于 06-17 17:47

    鴻蒙原生應用元服務開發-位置服務獲取設備信息開發

    ,如車載、步行導航。 . 在此場景下,保證系統提供位置結果精度最優,主要使用GNSS定位技術提供定位服務,結合場景特點,在導航啟動之初,
    發表于 06-14 14:46

    鴻蒙原生應用元服務開發-位置服務地理編碼轉化開發

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

    鴻蒙開發學習【地圖位置服務組件】

    移動終端設備已經深入人們日常生活的方方面面,如查看所在城市的天氣、新聞軼事、出行打車、旅行導航、運動記錄。這些習以為常的活動,都離不開定位用戶終端設備的位置
    的頭像 發表于 03-23 21:38 ?442次閱讀
    鴻蒙開發學習【地圖<b class='flag-5'>位置服務</b>組件】

    HarmonyOS開發技術全面分析

    、穿戴專有業務、IoT 專有業務等子系統組成。 ? 硬件服務子系統集 : HarmonyOS 提供硬件服務,由
    發表于 02-21 16:31

    鴻蒙應用/元服務開發-窗口概述

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

    HarmonyOS SDK 助力新浪新聞打造精致易用的新聞應用

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