如何使用坐标数组获得最大/最小边界

时间:2016-11-09 11:33:40

标签: javascript arrays coordinates

任何人都可以帮助我了解如何获得最大/最小坐标的逻辑,以及一系列坐标?我想要得到的是它可以从这些坐标数组中获得的最长距离。实施例

    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 }

2 个答案:

答案 0 :(得分:5)

您可以创建值的数组,然后使用Math.maxMath.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);