当前位置: 首页 > ops >正文

HarmonyOS实战:高德地图定位功能完整流程详解

前言

地图定位功能相信很多人都用过,在鸿蒙的应用程序开发中,使用高德地图的定位功能变得十分常见,那么在鸿蒙中一次完整的地位功能怎么实现?如果定位失败了,能否获取前几次的定位呢?本篇文章带你实现一个完整的定位功能流程,建议点赞收藏!

需求分析

要想实现一个完整的定位需求流程,就必须要做好准备工作,了解实现需求的具体步骤。

  • 权限申请
  • 检查 GPS 是否打开
  • 单次定位还是多次定位
  • 定位失败处理

技术实现

要想实现一次完整的定位流程,必须根据需要分析一步步去实现,由于高德地图的引入太过于简单,这里一笔带过。重点讲解完整实现的步骤。

  1. 添加基本定位权限,在 entry 模块下的 module.json5 中添加定位必要的两个权限。
 {// user_grant"name": "ohos.permission.APPROXIMATELY_LOCATION","reason": "$string:location_permissions_reason","usedScene": {"abilities": ["EntryAbility"],"when": "always"}},{// user_grant"name": "ohos.permission.LOCATION","reason": "$string:location_permissions_reason","usedScene": {"abilities": ["EntryAbility"],"when": "always"}},
  1. 在页面中进行权限申请,一般是在 onPageShow 生命周期方法中申请,先检查系统 GPS 定位开关是否开启,如果没有开启则提示用户跳转到系统指定位置打开。
 let location =  geoLocationManager.isLocationEnabled()if (!location) {let dialog = new OpenSystemGPSEHelper()dialog.show(this.getUIContext(),getContext(this) as common.UIAbilityContext,()=>{this.currentCity = "定位失败"})}//GPS跳转页面
context.startAbility({bundleName: "com.huawei.hmos.settings",abilityName: "com.huawei.hmos.settings.MainAbility",uri: "location_manager_settings"},
  1. 确认 GPS 打开之后,开始 申请 用户权限。
 static applyPermission(context: common.UIAbilityContext, permissions: Array<Permissions>, grantedBlock: () => void,deniedBlock?: () => void) {let atManager = abilityAccessCtrl.createAtManager()let permissionGrantedNumber: number = 0 atManager.requestPermissionsFromUser(context, permissions).then((data) => {for (let index = 0; index < data.authResults.length; index++) {if (data.authResults[index] == 0) { permissionGrantedNumber++;}}if (permissionGrantedNumber == permissions.length) {grantedBlock()} else {if (deniedBlock) {deniedBlock()} else {PermissionUtil.openPermissionsInSystemSettings(context)}}})}
  1. 如果用户打开权限,则直接开始定位服务,否则提示用户跳转到系统指定位置打开权限。
 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. 确认定位权限没问题后,开始定位,高德提供的定位有多次和单次,这里使用单次定位。
let listener: IAMapLocationListener = {onLocationChanged: (location) => {console.log("当前定位1:"+location.latitude+",---longitude:"+location.longitude)this.transformCity(location.latitude,location.longitude)}, onLocationError: (error) => {}};LocationManager.getInstance().addListener(listener)LocationManager.getInstance().initLocation()// 定位参数配置let options: AMapLocationOption = {//定位优先配置选项priority: geoLocationManager.LocationRequestPriority.FIRST_FIX,//定位场景设置scenario: geoLocationManager.LocationRequestScenario.UNSET,//定位精度 单位:米maxAccuracy: 0,//指定单次定位超时时间singleLocationTimeout: 3000,//定位是否返回逆地理信息locatingWithReGeocode: true,//逆地址语言类型reGeocodeLanguage: AMapLocationReGeocodeLanguage.Chinese,isOffset: false //是否加偏}// 设置配置this.locationManger?.setLocationOption(AMapLocationType.Single, options)if (this.listener != undefined) {// 监听this.locationManger?.setLocationListener(AMapLocationType.Single, this.listener)}// 启动定位this.locationManger?.requestSingleLocation()
  1. 定位成功拿到定位的信息,在实际开发中尽管设置中已经设置返回逆地理信息,但并没有返回具体信息,这点实在是无法理解,只能得到当前位置的经纬度。这个时候需要将经纬度转换为当前位置名称。
  2. 在开发中通过使用华为官方系统中的 api,对经纬度进行逆编码才能获取准备的位置名称。
 let reverseGeocodeRequest:geoLocationManager.ReverseGeoCodeRequest = {"latitude":latitude, "longitude":longitude, "maxItems": 1};try {geoLocationManager.getAddressesFromLocation(reverseGeocodeRequest, (err, data) => {})
  1. 如果地图定位失败,则可以根据高德地图提供的方法,尝试拿取历史定位信息。
 LocationManager.getInstance().getLastLocation({onLocationChanged: (location) => {console.info('地图定位缓存获取成功:  ' + JSON.stringify(location))if (success) {success()}}, onLocationError: (e) => {console.info('地图定位缓存获取失败:  ' + JSON.stringify(e))if (success) {success()}}})
  1. 如果历史定位信息也获取失败,这时就能使用默认定位位置了。
     

总结

定位功能实现起来比较简单,但是完整的定位流程及细节处理才是本篇文章的关键,相信看完本篇文章你已经学会在鸿蒙中怎么使用高德定位功能了,快去动手尝试一下吧!

http://www.xdnf.cn/news/8527.html

相关文章:

  • 《Spark/Flink/Doris离线实时数仓开发》目录
  • Linux目录介绍+Redis部署(小白篇)
  • 基于大模型的髋关节骨关节炎预测与治疗方案研究报告
  • client.chat.completions.create方法参数详解
  • 指令集架构、微架构、厂商对应关系
  • 浏览器强缓存还未过期,但服务器资源已经变了怎么办?
  • 打破产品思维--启示录:打造用户喜欢的产品--实战6
  • 动静态库--
  • 软件开发MVC三层架构杂谈
  • Android-OkHttp与Retrofit学习总结
  • 【疑难杂症】Vue前端下载文件无法打开 已解决
  • WebAssembly:开启跨平台高性能编程的新时代
  • 游戏引擎学习第309天:用于重叠检测的网格划分
  • 后端开发概念
  • 独立机构软件第三方检测:流程、需求分析及电商软件检验要点?
  • SystemUtils:你的Java系统“探照灯“——让环境探测不再盲人摸象
  • SQL每日一练(3)
  • XOR符号
  • esp32+IDF V5.1.1版本编译freertos报错
  • 机器学习——支持向量机(SVM)
  • 怎么开发一个网络协议模块(C语言框架)之(四) 信号量初始化
  • 【Java Web】3.SpringBootWeb请求响应
  • Spring 框架的JDBC 模板技术
  • 使用Python控制Arduino——入门与实战
  • Axure酒店管理系统原型
  • 【如何做好一份技术文档?】用Javadoc与PlantUML构建高质量技术文档(API文档自动化部署)
  • 正则表达式进阶(四):性能优化与调试技巧
  • STM32中的IIC协议和OLED显示屏
  • day26CSS-Sass、Stylus、Less
  • 使用Spring Boot和Spring Security结合JWT实现安全的RESTful API