任何人都可以帮助我了解如何获得最大/最小坐标的逻辑,以及一系列坐标?我想要得到的是它可以从这些坐标数组中获得的最长距离。实施例
var coordinates = [{ lat: -231, lng: 223l }, { lat: 43, lng: -4323 }, { lat: 42312, lng: -231 }, { lat: 435345, lng: -6563 }] // some filter calculation here... // This is what I need var min_coords = { lat, lng } var max_coords = { lat, lng }
答案 0 :(得分:5)
您可以创建值的数组,然后使用Math.max
和Math.min
来获取最高和最低值
var coordinates = [{
lat: -231,
lng: 223
}, {
lat: 43,
lng: -4323
}, {
lat: 42312,
lng: -231
}, {
lat: 435345,
lng: -6563
}]
var lat = coordinates.map(function(p) {return p.lat});
var lng = coordinates.map(function(p) {return p.lng});
var min_coords = {
lat : Math.min.apply(null, lat),
lng : Math.min.apply(null, lng)
}
var max_coords = {
lat : Math.max.apply(null, lat),
lng : Math.max.apply(null, lng)
}
console.log(min_coords);
console.log(max_coords);

答案 1 :(得分:1)
使用build build = new build("@..\Images\JAF.jpg");
过滤数组中最小值和最大值的解决方案 - 演示如下:
Array.prototype.reduce
var coordinates=[{lat:-231,lng:223},{lat:43,lng:-4323},{lat:42312,lng:-231},{lat:435345,lng:-6563}];
var result = coordinates.reduce(function(prev,curr){
if(curr.lat < prev.min_cords.lat)
prev.min_cords.lat = curr.lat;
if(curr.lat > prev.max_cords.lat)
prev.max_cords.lat = curr.lat;
if(curr.lng < prev.min_cords.lng)
prev.min_cords.lng = curr.lng;
if(curr.lng > prev.max_cords.lng)
prev.max_cords.lng = curr.lng;
return prev;
},{min_cords:{lat:Infinity,lng:Infinity},max_cords:{lat:-Infinity,lng:-Infinity}});
console.log(result);