使用onLocationChange方法持续监听地址,根据定位精度字段判断是否使用此次定位的经纬度。
已经会定位的直接跳 七、相对精确的获取经纬度地址
一、注册账号 把信息都输入就好了
腾讯位置服务 - 立足生态,连接未来
文章图片
二、创建应用和Key
1.进入控制台
2.创建应用
文章图片
3.创建Key
启用产品勾选WebServiceAPI和微信小程序,填写相应信息。
文章图片
三、登录微信公众平台后台 增加request合法域名:https://apis.map.qq.com
开发管理 —— 开发设置 —— 服务器域名 —— 修改
文章图片
四、下载微信小程序JavaScriptSDK 下载后放到自己的项目中
微信小程序JavaScript SDK | 腾讯位置服务
五、代码实现
var QQMap = require('../../js_sdk/qqmap-wx-jssdk.min.js') // SDK放置的路径
var qqmapsdk = new QQMap({
key: '**************' // 自己的Key
});
六、一般获取经纬度地址 在比较繁华的地方,一般用这个就够了。
wx.getLocation({
type: 'wgs84',
success: res => {
console.log(res);
//获取到经纬度值
qqmapsdk.reverseGeocoder({ // 根据经纬度转化为地址
location: {
latitude: res.latitude,
longitude: res.longitude
},
success: res => {
console.log(res);
}
})
}
});
七、相对精确的获取经纬度地址 1.获取位置监听的权限
uni.authorize({
scope: 'scope.userLocation',
success(res) {
console.log(res);
}
})
2.开启位置监听
wx.startLocationUpdate({
success: res => {
console.log(res);
},
fail: res => {
console.log(res);
//在这里处理开启失败的业务逻辑
}
})
3.监听实时地理位置变化
let index = 0;
const _locationChangeFn = function(res) {
console.log('location change', res)
index++;
//res.accuracy 代表定位精度, 这里根据定位精度和定位次数进行一个综合判断,根据用户在当前页面的停留时间进行相应的修改
if (index > 10 || (res.accuracy < 35 && index > 5)) {wx.offLocationChange();
wx.stopLocationUpdate();
qqmapsdk.reverseGeocoder({// 根据经纬度转化为地址
location: {
//纬度
latitude: res.latitude,
//经度
longitude: res.longitude
},
success: function(res1) {
console.log(res1.result);
},
fail: function(res1) {
console.log(res1);
}
})
}}//监听实时地理位置变化事件
wx.onLocationChange(_locationChangeFn)
这样定位出来的地址可能差不多,但是经纬度要比直接用getLocation获取到的更准确。
【微信小程序|uni-app 开发微信小程序定位】
推荐阅读
- 前端|uniapp开发微信小程序利用腾讯地图实现定位功能
- 微信小程序|微信小程序+mysql实现增删改查
- vue.js|vue 项目调取本地摄像头可切换摄像头并拍照生成图片
- vue.js|VUE实现调用摄像头和拍照功能
- vue|vue pc端调用摄像头进行拍照并实现裁剪上传
- javascript|说一说实战项目升级从vue2到vue3 之main.js 区别
- Vue日常总结|vue的动态组件和异步组件及keep-alive
- Vue日常总结|vue-cli v4.5.17脚手架创建项目与运行原理
- Vue日常总结|后台管理系统模板