基于百度地图api实现计算目标点与自身位置的距离(js)

导入api

下面展示一些 内联代码片

```javascript

<script type="text/javascript" src="https://api.map.baidu.com/api?v=3.0&ak=百度地图密钥">

获取自身定位

  1. 创建容器
<div id="container"></div> 
  1. 引入地图
var map = new BMap.Map("container");
var point = new BMap.Point(116.331398,39.897445);
map.centerAndZoom(point,19);
  1. 获取定位
var geolocation = new BMap.Geolocation();
geolocation.getCurrentPosition(function(r){
    console.log(r)  
	if(this.getStatus() == BMAP_STATUS_SUCCESS){
		var mk = new BMap.Marker(r.point);
		map.addOverlay(mk);
		map.panTo(r.point);
        console.log(point)
		console.log('您的位置:'+r.point.lng+','+r.point.lat);
	}
	else {
		console.log('failed'+this.getStatus());
	} 
})

获取目标点定位

通过在地图上的点击事件触发

var geoc = new BMap.Geocoder();    
map.addEventListener("click", function(e){ 
  
    var pt = e.point;
    //alert(getDistance(r.point.lng,r.point.lat,pt.lat,pt.lng))
    console.log(point.lat,point.lng,pt.lat,pt.lng)
    var dis= getDistance(point.lat,point.lng,pt.lat,pt.lng)
    console.log(dis);     
});

通过经纬度计算距离的函数

function getDistance(lat1, lng1, lat2, lng2) {
		var distance_str = "";
		// 四个值都存在进行距离计算
		if (lat1 != undefined && lng1 != undefined && lat2 != null && lng2 != null) {
			lat2 = lat2 * 1
			lng2 = lng2 * 1
			var radLat1 = rad(lat1);
			var radLat2 = rad(lat2);
			var a = radLat1 - radLat2;
			var b = rad(lng1) - rad(lng2);
			var s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2) +
				Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(b / 2), 2)));
			s = s * 6378.137; // EARTH_RADIUS;
			s = Math.round(s * 10000) / 10000; //输出为公里
			var distance = s;
			if (distance) {
				if (parseInt(distance) >= 1) {
					distance_str = distance.toFixed(1) + "km";
				} else {
					distance_str = distance * 1000 + "m";
				}
			}
		}
		return distance_str;
	} 
    function rad(d) {
    return d * Math.PI / 180.0;
    }

这里有几种距离计算公式

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
百度地图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进行距离计算的一些示例代码和注意事项。希望对你有帮助!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值