小程序
小游戏
企业微信
微信支付
扫描小程序码分享
1、如题
2、小程序的地图有没有更多的案例可供CV大法?
2 个回答
加粗
标红
插入代码
插入链接
插入图片
上传视频
大哥 你好 我使用的是高德地图的sdk 在小程序里使用的是腾讯地图的组件 导入坐标串 后 发现画出来的线路 有偏差 请问大哥你解决了吗
你好,麻烦通过点击下方“反馈信息”按钮,提供出现问题的。
/** * 返回两个经纬度之间的距离 * @param {string} lat1 起点纬度 * @param {string} lng1 起点经度 * @param {string} lat2 终点纬度 * @param {string} lng2 终点经度 * @return {string} 返回两个经纬度之间的距离 */ function getDistance(lat1, lng1, lat2, lng2) { function e(lat1, lng1, lat2, lng2) { lat1 = (lat1 * f) / 180; lat2 = (lat2 * f) / 180; lng1 = 2 * Math.asin( Math.sqrt( Math.pow(Math.sin((lat1 - lat2) / 2), 2) + Math.cos(lat1) * Math.cos(lat2) * Math.pow(Math.sin(((lng1 * f) / 180 - (lng2 * f) / 180) / 2), 2), ), ); return (lng1 = Math.round(6378137 * lng1)); } let f = Math.PI; return 1e3 < e(lat1, lng1, lat2, lng2) ? Math.round(e(lat1, lng1, lat2, lng2)) : e(lat1, lng1, lat2, lng2); } /** * 百度地图经纬度转为腾讯地图经纬度 * @param {Number} lat * @param {Number} lng * @returns */ function bdMapToTxMap(lat, lng) { let pi = (3.14159265358979324 * 3000.0) / 180.0; let x = lng - 0.0065; let y = lat - 0.006; let z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * pi); let theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * pi); lng = z * Math.cos(theta); lat = z * Math.sin(theta); return { lng: lng, lat: lat }; } /** * 腾讯地图转百度地图经纬度 * @param {Number} lat * @param {Number} lng * @returns */ function txMapToBdMap(lng, lat) { let x_pi = (3.14159265358979324 * 3000.0) / 180.0; let x = lng; let y = lat; let z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi); let theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi); let lngs = z * Math.cos(theta) + 0.0065; let lats = z * Math.sin(theta) + 0.006; return { lng: lngs, lat: lats, }; }
关注后,可在微信内接收相应的重要提醒。
请使用微信扫描二维码关注 “微信开放社区” 公众号
大哥 你好 我使用的是高德地图的sdk 在小程序里使用的是腾讯地图的组件 导入坐标串 后 发现画出来的线路 有偏差 请问大哥你解决了吗
/** * 返回两个经纬度之间的距离 * @param {string} lat1 起点纬度 * @param {string} lng1 起点经度 * @param {string} lat2 终点纬度 * @param {string} lng2 终点经度 * @return {string} 返回两个经纬度之间的距离 */ function getDistance(lat1, lng1, lat2, lng2) { function e(lat1, lng1, lat2, lng2) { lat1 = (lat1 * f) / 180; lat2 = (lat2 * f) / 180; lng1 = 2 * Math.asin( Math.sqrt( Math.pow(Math.sin((lat1 - lat2) / 2), 2) + Math.cos(lat1) * Math.cos(lat2) * Math.pow(Math.sin(((lng1 * f) / 180 - (lng2 * f) / 180) / 2), 2), ), ); return (lng1 = Math.round(6378137 * lng1)); } let f = Math.PI; return 1e3 < e(lat1, lng1, lat2, lng2) ? Math.round(e(lat1, lng1, lat2, lng2)) : e(lat1, lng1, lat2, lng2); } /** * 百度地图经纬度转为腾讯地图经纬度 * @param {Number} lat * @param {Number} lng * @returns */ function bdMapToTxMap(lat, lng) { let pi = (3.14159265358979324 * 3000.0) / 180.0; let x = lng - 0.0065; let y = lat - 0.006; let z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * pi); let theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * pi); lng = z * Math.cos(theta); lat = z * Math.sin(theta); return { lng: lng, lat: lat }; } /** * 腾讯地图转百度地图经纬度 * @param {Number} lat * @param {Number} lng * @returns */ function txMapToBdMap(lng, lat) { let x_pi = (3.14159265358979324 * 3000.0) / 180.0; let x = lng; let y = lat; let z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi); let theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi); let lngs = z * Math.cos(theta) + 0.0065; let lats = z * Math.sin(theta) + 0.006; return { lng: lngs, lat: lats, }; }