如何申請key
1、創建新應用
進入[控制臺],創建一個新應用。如果您之前已經創建過應用,可直接跳過這個步驟。


2、添加新Key
在創建的應用上點擊"添加新Key"按鈕,在彈出的對話框中,依次:輸入應用名名稱,選擇綁定的服務為“HarmonyOS平臺”,輸入AppID,如下圖所示:
注意
1個KEY只能用于一個應用(多渠道安裝包屬于多個應用),1個Key在多個應用上使用會出現服務調用失敗。

在閱讀完高德地圖API服務條款后,勾選此選項,點擊“提交”,完成 Key 的申請,此時您可以在所創建的應用下面看到剛申請的 Key 了。
如何獲取AppID
請在當前應用的Ablitiy中使用如下代碼獲取
let flag = bundleManager.BundleFlag.GET_BUNDLE_INFO_WITH_SIGNATURE_INFO;
let bundleInfo = bundleManager.getBundleInfoForSelfSync(flag)
let appId = bundleInfo.signatureInfo.appId;
注意事項
- 獲取AppID之前需要先配置應用的簽名信息。
- 目前通過DevEco Studio連接云真機獲取到的appId不全,只獲取到了"包名_", 使用云真機調試高德地圖SDK時會導致鑒權不通過,正確的appId形式為:"包名_簽名信息", 例如:com.amap.demo_BGtGgVB3ASqU7ar1nHkwX4s0nIexDbEwqNrVoatUDs17GrClWC7V2/zhoYh6tFQHAd5DASWVTEAgvZfzrEGljjs=

獲取定位數據
使用定位SDK之前,需要在 config.json 文件中進行相關權限設置,確保定位功能可以正常使用。
第一步,配置module.json5
首先,聲明權限
...
"requestPermissions": [
{
"name": "ohos.permission.APPROXIMATELY_LOCATION",
"usedScene": {
"abilities": [
"Harmony_location_demoAbility"
],
"when": "always"
}
},
{
"name": "ohos.permission.LOCATION",
"usedScene": {
"abilities": [
"Harmony_location_demoAbility"
],
"when": "always"
}
},
{
"name": "ohos.permission.LOCATION_IN_BACKGROUND",
"usedScene": {
"abilities": [
"Harmony_location_demoAbility"
],
"when": "always"
}
},
{
"name": "ohos.permission.INTERNET",
"usedScene": {
"abilities": [
"Harmony_location_demoAbility"
],
"when": "always"
}
},
{
"name": "ohos.permission.KEEP_BACKGROUND_RUNNING",
"usedScene": {
"abilities": [
"Harmony_location_demoAbility"
],
"when": "always"
}
}
]
...
第二步,向工程中添加定位開發包
從ohpm倉庫獲取定位包,依次添加依賴。
"dependencies": {
"@amap/amap_lbs_common": "1.0.0",
"@amap/amap_lbs_location": "1.0.0"
}
第三步,初始化定位
首先,設置Key
[獲取Key]
AMapLocationManagerImpl.setApiKey("您的key");
初始化隱私政策
AMapLocationManagerImpl.updatePrivacyShow(AMapPrivacyShowStatus.DidShow, AMapPrivacyInfoStatus.DidContain, getContext(this))
AMapLocationManagerImpl.updatePrivacyAgree(AMapPrivacyAgreeStatus.DidAgree, getContext(this))
創建AMapLocationManagerImpl
locationManger?: AMapLocationManagerImpl;
this.locationManger = new AMapLocationManagerImpl(this.context);
動態申請相關權限
reqPermissionsFromUser(permissions: Array< Permissions >): void {
let context: Context = getContext(this) as common.UIAbilityContext;
let atManager: abilityAccessCtrl.AtManager = abilityAccessCtrl.createAtManager();
// requestPermissionsFromUser會判斷權限的授權狀態來決定是否喚起彈窗
atManager.requestPermissionsFromUser(context, permissions).then((data: PermissionRequestResult) = > {
let grantStatus: Array< number > = data.authResults;
let length: number = grantStatus.length;
for (let i = 0; i < length; i++) {
if (grantStatus[i] === 0) {
// 用戶授權,可以繼續訪問目標操作
} else {
// 用戶拒絕授權,提示用戶必須授權才能訪問當前頁面的功能,并引導用戶到系統設置中打開相應的權限
return;
}
}
// 授權成功
}).catch((err: BusinessError) = > {
console.error(`Failed to request permissions from user. Code is ${err.code}, message is ${err.message}`);
})
}
最后,開始請求相關定位信息
如:連續定位
let listener: IAMapLocationListener = {
onLocationChanged: (location) = > {
// todo something
}, onLocationError: (error) = > {
// todo something
}
};
let options: AMapLocationOption = {
priority: geoLocationManager.LocationRequestPriority.FIRST_FIX,
scenario: geoLocationManager.LocationRequestScenario.UNSET,
timeInterval: 2,
distanceInterval: 0,
maxAccuracy: 0,
allowsBackgroundLocationUpdates: true,
locatingWithReGeocode: false,
reGeocodeLanguage: AMapLocationReGeocodeLanguage.Chinese,
isOffset: true
}
this.locationManger?.setLocationListener(AMapLocationType.Updating,listener)
this.locationManger?.setLocationOption(AMapLocationType.Updating,options)
this.locationManger?.startUpdatingLocation()
// 停止定位
// this.locationManger?.stopUpdatingLocation()
如需在后臺定位,則要在應用切入后臺前調用開啟后臺定位任務
this.locationManger?.startContinuousTask()
回到前臺可以停止后臺任務
this.locationManger?.stopContinuousTask()
至此就可以看到定位相關信息。也可依據參考手冊實現單次定位、最后位置等操作。
審核編輯 黃宇
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
定位
+關注
關注
5文章
1587瀏覽量
36698 -
SDK
+關注
關注
3文章
1101瀏覽量
51724 -
定位數據
+關注
關注
0文章
3瀏覽量
1080 -
鴻蒙
+關注
關注
60文章
2963瀏覽量
45899
發布評論請先 登錄
相關推薦
熱點推薦
鴻蒙地圖功能開發【3. 代碼開發】##地圖開發##
以后再去更新這個配置參數。
第二,一定要注意經緯度坐標的坐標系。從大家的慣性認知中,既然我是通過原生鴻蒙的Location Kit獲取的經緯度坐標,那么當然適用于原生鴻蒙的Map Ki
發表于 06-29 22:59
DIY --GPS +VB版谷歌地圖定位個人定位黑匣子
。將自己電腦的網絡IP寫入單片機,通過GPRS模塊 上網,將定位數據發到電腦上在地圖上顯示出來。這是GPS模塊提供的測試軟件,直接接上串口就可以測試模塊的定位性能及數據。后面是我的硬件
發表于 06-21 11:57
【合宙Air551G雙頻定位開發板試用體驗】 獲取定位數據
帶有NEMA解析功能,所以這樣直接可以解析出定位數據。我們是專業做定位產品的廠家,所以直接連接到產品上,直接看效果會比較直接的對模塊做出評估。給產品上電后,成功的獲取到了數據,通過對
發表于 03-25 12:55
鴻蒙應用開發的JS UI框架如何實現高德地圖的訪問?
鴻蒙應用,現在分為Java UI框架和Ark UI框架,其中JS UI開發者框架Ark UI框架,現在高德地圖為鴻蒙應用開發如何Java U
發表于 04-28 11:44
openai api key獲取的三種方案(有一種可以白嫖到 api key)
OpenAI API Key 全攻略:官方獲取、費用詳解與“白嫖”實戰 引言: 想要體驗 OpenAI 強大的 GPT 模型,卻苦于沒有 API Key?別擔心,本文將為你提供一份詳盡
如何獲取 OpenAI API Key?API 獲取與代碼調用示例 (詳解教程)
,催生了從智能聊天到復雜數據分析等前所未有的應用場景。OpenAI API Key 是開啟這些能力的關鍵,它既是身份憑證,也是資源管理和安全保障的核心。然而,安全、高效地獲取、管理和使用 API
HarmonyOS實戰:高德地圖自定義定位圖標展示
的問題,建議點贊收藏! 實現效果 需求分析 首先需要實現一個自定義的圖標替代系統默認的箭頭。 獲取定位權限與位置信息。 獲取定位結果并展示當前位置。 技術實現 在
谷歌地圖GPS定位
的導航體驗。 GPS(全球定位系統)技術起始于軍事應用,現已廣泛用于民用領域。谷歌地圖通過整合這一技術,讓用戶能夠隨時隨地獲取精確的位置信息。以下是谷歌地圖GPS
LuatOS AGPS 輔助定位開發實戰教程
、數據解析、定位模塊調優等實戰環節,附帶完整代碼與調試技巧,助開發者快速上手。 ? 一、AGPS 概述 ? AGPS(Assisted GPS,輔助全球衛星定位系統)通過移動網絡預先
鴻蒙NXET實戰:高德地圖定位SDK【獲取Key+獲取定位數據】(二)
評論