微信小程序—经纬度逆地址解析的实现「建议收藏」

微信小程序—经纬度逆地址解析的实现「建议收藏」小ZXZ小

大家好,又见面了,我是你们的朋友全栈君。

前言

最近遇到工作中遇到一个需求,当用户打开小程序时,小程序页面中对应的位置信息变为用户当前位置,且用户能更改当前地址信息;看到这个需求我想大部分人和我想到的就是使用微信官方API中的wx.getLocation来实现,通过它我们能拿到当前位置的经纬度,之后将经纬度转换为地址信息。

微信小程序—经纬度逆地址解析的实现「建议收藏」

第一步:

获取当前位置的经纬度,微信官方文档中明确指出在调用wx.getLocation前是需要用户授权的,我们需要考虑到当用户拒绝授权的情况发生,因此我的做法是直接调用wx.getLocation,在失败的回调中去处理用户未授权或者拒绝的情况,代码如下:

// 授权获取地址信息
checkAuth(callback) {
  wx.getLocation({
    type: 'gcj02',
    isHighAccuracy: true, // 开启高精度
    success(res) {
      // res 返回值 { accuracy: 65, errMsg: "getLocation:ok", horizontalAccuracy: 65, latitude: 22.53332, longitude: 113.93041, speed: -1, verticalAccuracy: 65 }
      callback(res);
    },
    fail: function(error) {
      wx.showModal({
        title: '是否授权当前位置',
        content: '需要获取您的地理位置,请确认授权,否则地图功能将无法使用',
        success: (res) => {
          if (res.confirm) {
            wx.openSetting({
              success: function (data) {
                if (data.authSetting["scope.userLocation"]) {
                  wx.getLocation({
                    type: 'gcj02',
                    isHighAccuracy: true,         // 开启高精度
                    success(res) {
                      // res 返回值 { accuracy: 65, errMsg: "getLocation:ok", horizontalAccuracy: 65, latitude: 22.53332, longitude: 113.93041, speed: -1, verticalAccuracy: 65 }
                      callback(res);
                    }
                  })
                } else {
                  wx.showToast({
                    title: '授权失败',
                    icon: 'success',
                    duration: 1000
                  })
                }
              }
            })
          }
        },
      })     
    }
  })
}

注: 这里有个小坑,我之前在开发者工具上调试,拿到的经纬度去做地址逆向解析始终不对,代码查了又查,一次又一次的debugger弄了2小时都没解决,之后在开发者社区中看到网友给的说法是开发者工具中的经纬度是错的,但是手机上不会,经测试ok;在这里要感谢这位网友。

 

第二步:

在没有查阅相关文档之前一直以为,这类地址信息前端只需要拿到经纬度去调后端接口,后端返回前端想要的数据,地址的逆向解析是由后端来做的,也是在查阅相关文档的过程中看到了微信官方提供的解决方案,腾讯位置服务之逆地址解析

我们首先需要申请开发者秘钥,申请完成我们将得到一个key

微信小程序—经纬度逆地址解析的实现「建议收藏」

根据官方文档我们需要下载微信小程序javascriptSDK并引入到项目中,

// 引入SDK核心类,js文件根据自己业务,位置可自行放置
var QQMapWX = require('../../utils/qqmap-wx-jssdk.min.js');

// 实例化API核心类
var qqmapsdk = new QQMapWX({
  key: 'xxxx-xxxx-xxxx'    // 这里就是申请的key
});

// 获取地址信息
getAddressInfo() {
    var that = this;
    var location = {
        latitude: that.data.latitude,
        longitude: that.data.longitude
    };
  
    qqmapsdk.reverseGeocoder({
        location,
        get_poi: 1,        // 是否返回周边POI列表:1.返回;0不返回(默认)
        poi_options: "policy=2;radius=5000",
        success: res => {
          var res = res.result;

          that.setData({
            activeAddress: res.address,    // 当前经纬度解析的地址
            addressList: res.pois,         // 附近的地址列表信息
          });
        },
  
        fail: function(error) {
          console.error(error);
        },
  
        complete: function(res) {
          // console.log(res);
        }
    })
}

这里有几个坑需要注意poi_options的值中存在多个参数需要用”;”来隔开,第二个就是一定不要忘了在小程序中配置安全域名”https://apis.map.qq.com“,另外就是每个key的每个服务接口是存在限制的。

完整代码如下:

// 引入SDK核心类,js文件根据自己业务,位置可自行放置
var QQMapWX = require('../../utils/qqmap-wx-jssdk.min.js');
var qqmapsdk;

Page({

  /**
   * 页面的初始数据
   */
  data: {

  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {

    // 实例化API核心类
    qqmapsdk = new QQMapWX({
      key: 'xxxx-xx-xxxx-xxxx'
    });

    this.getAddressInfo();
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {
    
  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  },

  // 授权获取地址信息
  checkAuth(callback) {
    wx.getLocation({
      type: 'gcj02',
      isHighAccuracy: true,         // 开启高精度
      success(res) {
        callback(res);
      },
      fail: function() {
        wx.showModal({
          title: '是否授权当前位置',
          content: '需要获取您的地理位置,请确认授权,否则地图功能将无法使用',
          success: (res) => {
            if (res.confirm) {
              wx.openSetting({
                success: function (data) {
                  if (data.authSetting["scope.userLocation"]) {
                    wx.getLocation({
                      type: 'gcj02',
                      isHighAccuracy: true,         // 开启高精度
                      success(res) {
                        callback(res);
                      }
                    })
                  } else {
                    wx.showToast({
                      title: '授权失败',
                      icon: 'success',
                      duration: 1000
                    })
                  }
                }
              })
            }
          },
        })     
      }
    })
  },

  // 获取地址信息
 getAddressInfo() {
    
    var that = this;
    that.checkAuth((res) => {

      var location = {
        latitude: res.latitude,
        longitude: res.longitude
      };
  
      qqmapsdk.reverseGeocoder({
        location: location,
        get_poi: 1,        // 是否返回周边POI列表:1.返回;0不返回(默认)
        poi_options: "policy=2;radius=5000",
        success: res => {
          var res = res.result;
          that.setData({
            activeAddress: res.address,
            addressList: res.pois
          });
        },
  
        fail: function(error) {
          console.error(error);
        },
  
        complete: function(res) {
          // console.log(res);
        }
      })
    })
  }
})

最近才发现又几年没写东西了,一直都是在忙做项目改bug,或者说是写bug?  ?  ?  ,刚好今天不太忙,又碰巧想写点什么。

欢迎讨论交流,如果文章对您有一丝帮助,请不啬点赞哦。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/158827.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 十天征服单片机百度云_郭天祥十天征服单片机视频下载地址

    十天征服单片机百度云_郭天祥十天征服单片机视频下载地址高级教材《十天学会单片机和C语言编程》ed2k://|file|[十天学会单片机和C语言编程].Lesson1.rar|449712628|262b8896ad6828cd33ed7189fe94cb2d|h=76MXIF34BFV3VUPLLBN3ASNOVCACHTO3|7b&Y0}8J9w,P0E:|-}’Oed2k://|file|[十天学会单片机和C语言编程]…

    2022年5月2日
    35
  • int8 int16 int32 int64 float16 float32

    int8 int16 int32 int64 float16 float32int8取值范围是-128-127Int16意思是16位整数(16bitinteger),相当于short占2个字节-32768~32767Int32意思是32位整数(32bitinteger),相当于int占4个字节-2147483648~2147483647Int64意思是64位整数(64bitinterger),相当于longlong占8个字节-9223372036854775808~92233720368547

    2022年8月15日
    5
  • 常用黑盒测试方法_黑盒测试各种方法

    常用黑盒测试方法_黑盒测试各种方法定义:黑盒测试又称功能测试。黑盒测试就是把测试对象看成一个不能打开的黑盒子,在完全不考虑程序的内部结构和处理过程的情况下,只依据程序的需求规格说明书,检查程序的功能是否符合他的功能说明。黑盒测试主要发现的缺陷类型:1、功能错误或遗漏;2、界面错误;3、数据库错误;4、性能错误;5、初始化和终止错误。黑盒测试的基本思路:黑盒测试是以用户的角度,从输入数据与输出数据的对应关系出发进行测试的,又称为数据驱动测试。黑盒测试是在程序外部接口进行的测试。黑盒测试选择…

    2022年10月4日
    5
  • 分享S60 精品软件集

    分享S60 精品软件集此贴软件列表中蓝色是中文版,绿色是英文版【管理类】【手机文件管理类】SeleQ.v1.65简体中文完全版文件管理软件System.Explorer.v1.70英文激活成功教程版SELEQ1.70文件管理软件System.Explorer.v1.70中文激活成功教程版SystemExplorerv1.8系统探索器完全汉化安装版NEW读卡器专用的SELEQ安装方法读卡器专用的SmartFileman安装软件文件管

    2022年7月11日
    26
  • ntp网络时间协议_ntp网络时间协议特性

    ntp网络时间协议_ntp网络时间协议特性NTP是网络时间协议(NetworkTimeProtocol),它是用来同步网络中各个计算机的时间的协议。  原理:NTP要提供准确的时间,就必须有准确的时间来源,那可以用格林尼治时间吗?答案是否定的。因为格林尼治时间是以地球自转为基础的时间计量系统,但是地球每天的自转是有些不规则的,而且正在缓慢加速,因此,格林尼治时间已经不再被作为标准时间使用。新的标准时间,是由原子钟报时的

    2022年10月12日
    3
  • 如何免费下载付费音乐歌曲,6个网站+8个APP

    如何免费下载付费音乐歌曲,6个网站+8个APP现在听音乐的软件,QQ音乐,酷狗,网易云等,很多歌曲可以在线听。但是下载某些歌曲或者在线听高品质无损的都需要付费。这一期,给大家推荐的是免费下载付费歌曲工具,包括网站跟APP。网站篇1.VIP

    2022年7月1日
    70

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号