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

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

    瀏覽量

    2219
  • HarmonyOS
    +關注

    關注

    80

    文章

    2153

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    服務發布配置開發者服務信息

    您作為開發者的相關信息將面向元服務發布區域的用戶公開,其中客服聯系方式可能會提供用戶,用于咨詢相關問題。 登錄AppGallery Connect,點擊“APP與元
    發表于 10-31 17:58

    服務配置支持設備

    發布時,您可以為元服務配置分發至多種設備,默認發布設備您創建元服務用時選擇的設備類型,您可以根據實際情況進行修改。您只需發布一次,用戶即可在多種設備上使用您的元
    發表于 10-22 16:54

    HarmonyOSAI編程智能問答

    CodeGenie基于生成式搜索能力,通過查詢生成、內容優選服務高效理解用戶意圖,問答交互式地獲取編碼相關知識。 對話示例 在對話區域輸入需要查詢的問題,開始問答。示例如下: ArkTS如何實現
    發表于 09-03 16:17

    坐標測量機精度保障,盡在蔡司三坐標代測服務套餐

    的ZEISSMetrologyCare蔡司三坐標測量機年度服務套餐致力于您的計量工作保駕護航。ZEISSMetrologyCare蔡司三坐標測量機年度
    的頭像 發表于 07-09 14:03 ?682次閱讀
    三<b class='flag-5'>坐標</b>測量機精度保障,盡在蔡司三<b class='flag-5'>坐標</b>代測<b class='flag-5'>服務</b>套餐

    HarmonyOS 5 入門系列 】鴻蒙HarmonyOS示例項目講解

    HarmonyOS 5 入門系列 】鴻蒙HarmonyOS示例項目講解 ##鴻蒙開發能力 ##HarmonyOS SDK應用服務##鴻蒙金融類應用 (金融理財# 一、前言:移動開發
    的頭像 發表于 07-07 11:57 ?1092次閱讀
    【 <b class='flag-5'>HarmonyOS</b> 5 入門系列 】鴻蒙<b class='flag-5'>HarmonyOS</b>示例項目講解

    HarmonyOS NEXT應用開發-Notification Kit(用戶通知服務)通知類型、級別與渠道

    。 SERVICE_INFORMATION 2 服務提醒。該類型對應SlotLevelLEVEL_HIGH。 CONTENT_INFORMATION 3 內容資訊。該類型對應SlotLevel
    發表于 06-09 14:39

    HarmonyOS NEXT應用開發-Notification Kit(用戶通知服務)更多系統能力

    = _NotificationActionButton 描述通知中顯示的操作按鈕。 系統能力: SystemCapability.Notification.Notification 類型 說明
    發表于 06-04 15:43

    HarmonyOS5云服務技術分享--Serverless抽獎模板部署

    通過endCallback實現中獎消息推送 ? ??安全加固?? 非免認證模式下建議: 添加請求頻率限制 使用HTTPS加密回調 用戶ID做哈希處理 五、常見問題QA ? 部署后訪問顯示空白
    發表于 05-22 20:25

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

    氣的方式探索這個功能,結尾還有實用總結和鼓勵彩蛋哦~? ? 一、HarmonyOS云函數開發:核心能力與價值 HarmonyOS的云函數(Serverless)開發者
    發表于 05-22 17:21

    HarmonyOS5云服務技術分享--登錄郵件功能整理

    登錄頻率限制、異地登錄提醒等規則。 ??云函數擴展??:通過認證觸發器實現注冊成功自動發送歡迎郵件等場景。 結語?? 郵箱認證作為用戶體系的基礎能力,HarmonyOS通過ArkTS API 12提供
    發表于 05-22 16:04

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

    /oh_modules)。 三、結尾總結 通過本文,您已完成AGC認證服務HarmonyOS ArkTS集成流程。后續可結合業務需求擴展登錄方式(如第三方社交賬號),并通過AGC控制臺監控用戶行為
    發表于 05-22 13:20

    基于 Wi-Fi 的定位服務

    以下捕獲使用 location_wifi_get 函數請求 Wi-Fi 定位服務。該事件的總功耗 125.85mC,日志顯示精確度 30.0m。 Got location: met
    發表于 04-17 15:16

    nRF Cloud 支持多種定位服務介紹

    nRF Cloud 中可用的位置服務在定位精度和功耗方面表現不同,您需要根據您的應用需求選擇最適合的一種
    的頭像 發表于 04-14 16:52 ?528次閱讀
    nRF Cloud 支持多種定位<b class='flag-5'>服務</b>介紹

    鴻蒙應用元服務開發-Account Kit獲取華為賬號用戶信息概述

    一、概述 當元服務需要完善用戶個人資料(頭像、手機號、收貨地址、發票抬頭)時,可通過Account Kit提供的相關能力,引導用戶填寫、管理相關信息并完成授權。獲取頭像、手機號、收貨地
    發表于 04-02 11:10

    鴻蒙應用元服務開發-Account Kit概述

    ,守護未成年人健康使用電子設備。有以下優點: 便捷性:統一管控未成年人模式入口,僅需一次設置,元服務聯動生效,避免各個元服務內單獨開啟的繁瑣操作,提升用戶體驗。 全面守護:元服務與系統
    發表于 03-31 12:08