计算地图区域面积

computeSignedArea(path) {
		if (path.length > 0) {
		let _this = this;
		let radius = 6371000
		let len = path.length;
		if (len < 3) return 0;
		let total = 0;
		let prev = path[len - 1];
		if (prev.latitude && prev.longitude) {
			let prevTanlant = Math.tan((Math.PI / 2 - parseFloat(prev.latitude) / 180 * Math.PI) / 2);
			let prevTanLat = Math.tan((Math.PI / 2 - prev.latitude / 180 * Math.PI) / 2);
			let prevLng = (prev.longitude) / 180 * Math.PI;
			    for (let i in path) {
					let tanLat = Math.tan((Math.PI / 2 - (path[i].latitude) / 180 * Math.PI) / 2);
					let lng = (path[i].longitude) / 180 * Math.PI;
					total += this.polarTriangleArea(tanLat, lng, prevTanLat, prevLng);
							prevTanLat = tanLat;
							prevLng = lng;
					}
					let area = Math.abs(total * (radius * radius));
					return area;
				}
			}
},
polarTriangleArea(tan1, lng1, tan2, lng2) {
				let deltaLng = lng1 - lng2;
				let t = tan1 * tan2;
				return 2 * Math.atan2(t * Math.sin(deltaLng), 1 + t *Math.cos(deltaLng));
},

只需要传入点位坐标类似于----------------->

points: [
                        {
                        latitude: 30.627291,
                        longitude: 114.343762
                    }, {
                        latitude: 30.627292,
                        longitude: 114.343763,
                    }, {
                        latitude: 30.627291,
                        longitude: 114.343762
                    },
            ]

即可计算出区域面积

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值