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
},
]
即可计算出区域面积