uniapp + 获取定位并计算当前线路中离我最近的站

使用微信的 jsapi 获取定位

const jweixin = require('jweixin-module')

reqWxSignature().then(r => {
	let data = r.data
	jweixin.config({
		appId: data.appId,
		timestamp: data.timestamp,
		nonceStr: data.nonceStr,
		signature: data.signature,
		jsApiList: [ 'getLocation' ]
	});
	setTimeout(() => {
		jweixin.getLocation({
		  	type: 'wgs84', // 默认为wgs84的gps坐标,如果要返回直接给openLocation用的火星坐标,可传入'gcj02'
		  	success: (res) => {
				this.curLngLat = { lat:res.latitude, lng:res.longitude };
		  	},
			fail:() => {
				uni.showToast({ title:"获取定位失败" })
			}
		},500)
	})
})

计算两个经纬度之间的直线距离

getDistance(point1, point2) {
  const earthRadius = 6378137; // 地球半径,单位:米
  const radLat1 = point1.latitude * Math.PI / 180;
  const radLat2 = point2.latitude * Math.PI / 180;
  const a = radLat1 - radLat2;
  const b = point1.longitude * Math.PI / 180 - point2.longitude * Math.PI / 180;
  const 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)));
  return s * earthRadius;
}

获取离我最近的站点

// points:线路中所有的站点经纬度数组
findNearestPoint(currentLat, currentLng, points) {
	let minDistance = Infinity;
	let nearestPoint = null;
	for (let i = 0; i < points.length; i++) {
		const point = points[i];
		const distance = this.getDistance({latitude:currentLat,longitude:currentLng}, point);
		if (distance < minDistance) {
			minDistance = distance;
			nearestPoint = point;
		}
	}
	return nearestPoint;
},
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值