微信小程序 腾讯地图显示偏差问题解决


Posted in Javascript onJuly 27, 2019

背景

在小程序中使用map组件,可以调用腾讯地图的API,将一些固定的点标记到地图界面上,点的经纬度获取是通过android端百度地图API获取的,所以此时将这个位置点信息直接设置上去会出现偏差,而且偏差还比较大

小程序设置位置点

关于如何在map组件上设置位置点,详细请查看腾讯官方文档
首先看一下map组件:

<map id="map" longitude="113.324520" latitude="23.099994" scale="14" controls="{{controls}}" bindcontroltap="controltap" markers="{{markers}}" bindmarkertap="markertap" polyline="{{polyline}}" bindregionchange="regionchange" show-location style="width: 100%; height: 300px;"></map>

其markers是需要设置在地图界面的位置点数组,数组中的元素就是一个对象。

markers: [{
   iconPath: "/resources/others.png",
   id: 0,
   latitude: 23.099994,
   longitude: 113.324520,
   width: 50,
   height: 50
  },
  iconPath: "/resources/others.png",
   id: 0,
   latitude: 23.094994,
   longitude: 113.424520,
   width: 50,
   height: 50
  }],

这里的latitude和longitude如果直接给其他地图定位的点,那么相同的这个点位置,在小程序中会出现偏差;

原因

小程序中的定位方式默认的是wgs84,而百度地图中使用的是BD09 ,还有gcj02。所以这里会出现偏差。

解决方案

使用离线的js库gcoord,将位置信息进行一次转换;

首先下载这个js库,放至某一个目录下,我这里是utils下

在需要的界面导入

import gcoord from '../../../utils/gcoord.js'

调用转换函数

var result = gcoord.transform(
       [resArr[i].JD, resArr[i].WD],  // 经纬度坐标
       gcoord.BD09,         // 当前坐标系(百度)
       gcoord.GCJ02);

这里在小程序中修改为gcj02,国测数据,因此转为gcj02;

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
图片之间的切换
Jun 26 Javascript
6款经典实用的jQuery小插件及源码(对话框/提示工具等等)
Feb 04 Javascript
js截取小数点后几位的写法
Nov 14 Javascript
jsPDF导出pdf示例
May 02 Javascript
基于js与flash实现的网站flv视频播放插件代码
Oct 14 Javascript
实现JavaScript高性能的数据存储
Dec 11 Javascript
vue+vux实现移动端文件上传样式
Jul 28 Javascript
Javascript刷新页面的实例
Sep 23 Javascript
详解Vuex管理登录状态
Nov 13 Javascript
Node.js创建Web、TCP服务器
Dec 05 Javascript
vue-router启用history模式下的开发及非根目录部署方法
Dec 23 Javascript
Vue打包后访问静态资源路径问题
Nov 08 Javascript
基于layPage插件实现两种分页方式浅析
Jul 27 #Javascript
基于ssm框架实现layui分页效果
Jul 27 #Javascript
layUI实现前端分页和后端分页
Jul 27 #Javascript
layui实现数据分页功能(ajax异步)
Jul 27 #Javascript
layui实现数据表格table分页功能(ajax异步)
Jul 27 #Javascript
layui实现数据分页功能
Jul 27 #Javascript
layUI实现列表查询功能
Jul 27 #Javascript
You might like
PHP VS ASP
2006/10/09 PHP
php递归获取目录内文件(包含子目录)封装类分享
2013/12/25 PHP
CI框架装载器Loader.php源码分析
2014/11/04 PHP
PHP中mysqli_affected_rows作用行数返回值分析
2014/12/26 PHP
php实现excel中rank函数功能的方法
2015/01/20 PHP
三个思路解决laravel上传文件报错:413 Request Entity Too Large问题
2017/11/13 PHP
Laravel 解决419错误 -ajax请求错误的问题(CSRF验证)
2019/10/25 PHP
XHTML-Strict 内允许出现的标签
2006/12/11 Javascript
JavaScript 事件参考手册
2008/12/24 Javascript
JavaScript delete操作符应用实例
2009/01/13 Javascript
javascript 全选与全取消功能的实现代码
2012/12/23 Javascript
JQUERY 获取IFrame中对象及获取其父窗口中对象示例
2013/08/19 Javascript
jquery鼠标停止移动事件
2013/12/21 Javascript
javascript创建createXmlHttpRequest对象示例代码
2014/02/10 Javascript
jQuery中[attribute!=value]选择器用法实例
2014/12/31 Javascript
JavaScript实现数字数组正序排列的方法
2015/04/06 Javascript
Angularjs中如何使用filterFilter函数过滤
2016/02/06 Javascript
解决node.js安装包失败的几种方法
2016/09/02 Javascript
JavaScript递归操作实例浅析
2016/10/31 Javascript
整理一些最近经常遇到的前端面试题
2017/04/25 Javascript
详解axios中封装使用、拦截特定请求、判断所有请求加载完毕)
2019/04/09 Javascript
Vue的transition-group与Virtual Dom Diff算法的使用
2019/12/09 Javascript
微信小程序scroll-view隐藏滚动条的方法详解
2020/03/25 Javascript
基于JavaScript获取url参数2种方法
2020/04/17 Javascript
JS 创建对象的模式实例小结
2020/04/28 Javascript
vue 数据操作相关总结
2020/12/17 Vue.js
Python列表解析配合if else的方法
2018/06/23 Python
Kiwi.com中国:找到特价机票并发现新目的地
2019/10/27 全球购物
成人高等教育毕业生自我鉴定
2013/10/22 职场文书
计算机应用专业学生的自我评价分享
2013/11/03 职场文书
本科毕业生求职自荐信
2014/02/03 职场文书
大学毕业生推荐信
2014/07/09 职场文书
银行贷款委托书范本
2014/10/11 职场文书
先进班组材料范文
2014/12/25 职场文书
Golang解析JSON对象
2022/04/30 Golang
Docker容器harbor私有仓库部署和管理
2022/08/05 Servers