小程序计算商家和用户的距离

计算商家和用户的距离必须要用到他们的经纬度

1进入腾讯位置服务选择微信小程序JavaScript申请密钥
2下载SDK

3在所需的页面引入

// 引入SDK核心类
import QQMapWX from 'xxx/qqmap-wx.js';
 
// 实例化API核心类
let qqMap = new QQMapWX({
    key: '开发密钥(key)' // 必填
});

4根据地址转经纬度

mainPoints(e) {  //e为用户的地址
        qqMap.geocoder({
            address: e.detail.value
            complete: res => {
                 console.log(res.result.location);   //获取到到经纬度
                } else {
                    console.log('无法定位到该地址,请确认地址信息!');
                }
            }
        });
    }

5根据商家和用户的经纬度计算他的距离

distance = function(la1, lo1, la2, lo2) { 
	var La1 = la1 * Math.PI / 180.0;
	var La2 = la2 * Math.PI / 180.0;
	var La3 = La1 - La2;
	var Lb3 = lo1 * Math.PI / 180.0 - lo2 * Math.PI / 180.0;
	var s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(La3 / 2), 2) + Math.cos(La1) * Math.cos(La2) * Math.pow(Math.sin(
		Lb3 / 2), 2)));
	s = s * 6378.137; //地球半径
	s = Math.round(s * 10000) / 10000;
	return s  //计算
	
}
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
百度地图API可以用于在小程序中进行距离计算。在使用百度地图API进行距离计算时,需要注意以下几点: 1. 数据格式:确保输入的经纬度数值正确,并与对应的坐标系一一对应。 2. 数据容量:个人账号有查询数量限制,建议一次性不要调用次数太多。 3. 坐标系:注意自己的数据是wgs84、gcj02或其他坐标系。 4. 公共交通一体化:百度地图查询公共交通路径时,一般将公交和地铁放在一起组合查询,可以得到公共交通的总出行距离,但无法得到公交和地铁各自的出行距离。 在小程序中使用百度地图API进行距离计算的示例代码如下: ```javascript <script type="text/javascript" src="https://api.map.baidu.com/api?v=3.0&ak=百度地图密钥"></script> // 获取自身定位 var map = new BMap.Map("container"); var point = new BMap.Point(116.331398,39.897445); map.centerAndZoom(point,19); // 获取定位 var geolocation = new BMap.Geolocation(); geolocation.getCurrentPosition(function(r){ if(this.getStatus() == BMAP_STATUS_SUCCESS){ var mk = new BMap.Marker(r.point); map.addOverlay(mk); map.panTo(r.point); console.log('您的位置:', r.point.lng, ',', r.point.lat); } else { console.log('failed', this.getStatus()); } }) // 获取目标点定位 ``` 在wxml页面中,可以使用以下代码来实现百度地图API距离计算的功能: ```html <button bindtap="access">获取位置</button> <form bindsubmit="formSubmit"> <label>终点坐标: <input style="border:1px solid #000;" name="dest"></input></label> <button form-type="submit">计算距离</button> </form> <view wx:for="{{distance}}" wx:key="index"> <view>起点到终点的步行距离为{{item}}米</view> </view> <map id="myMap" markers="{{markers}}" style="width:100%;height:300px;" longitude="{{poi.longitude}}" latitude="{{poi.latitude}}" scale='16' show-location></map> ``` 以上是关于在小程序中使用百度地图API进行距离计算的一些示例代码和注意事项。希望对你有帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值