google-maps - 如何合并多边形(纬度和经度)?

标签 google-maps merge gis polygon latitude-longitude

我在 map 上定义了以纬度和经度作为坐标系的多边形。我想合并所有重叠的多边形。 enter image description here

从这个问题Question

我找到了这个软件:Software

我下载了代码,它非常适合笛卡尔坐标。但是,我不知道如何将它用于纬度和经度。

解决这个问题的最佳方法是什么?

例如,这里是我要合并的多边形:

        var polyA = new List<GpsLocation>();
        var pA1 = new GpsLocation(0, 0);
        polyA.Add(pA1);
        var pA2 = GpsHelper.CreateLocationBasedOnBearingDistance(pA1, 5, 100);
        polyA.Add(pA2);
        var pA3 = GpsHelper.CreateLocationBasedOnBearingDistance(pA2, 95, 100);
        polyA.Add(pA3);
        var pA4 = GpsHelper.CreateLocationBasedOnBearingDistance(pA3, 185, 100);
        polyA.Add(pA4);

        var polyB = new List<GpsLocation>();

        var pB1 = GpsHelper.CreateLocationBasedOnBearingDistance(pA1, 95, 50);
        polyB.Add(pB1);
        var pB2 = GpsHelper.CreateLocationBasedOnBearingDistance(pB1, 5, 100);
        polyB.Add(pB2);
        var pB3 = GpsHelper.CreateLocationBasedOnBearingDistance(pB2, 95, 100);
        polyB.Add(pB3);
        var pB4 = GpsHelper.CreateLocationBasedOnBearingDistance(pB3, 185, 100);
        polyB.Add(pB4);

最佳答案

你可以使用 JSTS library

proof of concept fiddle

screenshot of merged polygon

代码片段:

var googleMaps2JSTS = function(boundaries) {
  var coordinates = [];
  for (var i = 0; i < boundaries.getLength(); i++) {
    coordinates.push(new jsts.geom.Coordinate(
      boundaries.getAt(i).lat(), boundaries.getAt(i).lng()));
  }
  return coordinates;
};
var jsts2googleMaps = function(geometry) {
  var coordArray = geometry.getCoordinates();
  GMcoords = [];
  for (var i = 0; i < coordArray.length; i++) {
    GMcoords.push(new google.maps.LatLng(coordArray[i].x, coordArray[i].y));
  }
  return GMcoords;
}

function initialize() {
  var map = new google.maps.Map(
    document.getElementById("map_canvas"), {
      center: new google.maps.LatLng(37.4419, -122.1419),
      zoom: 13,
      mapTypeId: google.maps.MapTypeId.ROADMAP
    });
  var bounds = new google.maps.LatLngBounds();
  var poly1 = new google.maps.Polygon({
    // map: map,
    paths: [polyPath1]
  });
  for (var i = 0; i < polyPath1.length; i++) {
    bounds.extend(new google.maps.LatLng(polyPath1[i].lat, polyPath1[i].lng));
  }
  var poly2 = new google.maps.Polygon({
    // map: map,
    paths: [polyPath2]
  });
  for (var i = 0; i < polyPath2.length; i++) {
    bounds.extend(new google.maps.LatLng(polyPath2[i].lat, polyPath2[i].lng));
  }
  map.fitBounds(bounds);
  var geometryFactory = new jsts.geom.GeometryFactory();
  var JSTSpoly1 = geometryFactory.createPolygon(geometryFactory.createLinearRing(googleMaps2JSTS(poly1.getPath())));
  JSTSpoly1.normalize();
  var JSTSpoly2 = geometryFactory.createPolygon(geometryFactory.createLinearRing(googleMaps2JSTS(poly2.getPath())));
  JSTSpoly2.normalize();

  var JSTSpolyUnion = JSTSpoly1.union(JSTSpoly2);
  var outputPath = jsts2googleMaps(JSTSpolyUnion);

  var unionPoly = new google.maps.Polygon({
    map: map,
    paths: outputPath,
    strokeColor: '#0000FF',
    strokeOpacity: 0.3,
    strokeWeight: 2,
    fillColor: '#0000FF',
    fillOpacity: 0.8
  });
}
google.maps.event.addDomListener(window, "load", initialize);

var polyPath1 = [{
  lat: 51.510291630150256,
  lng: -0.18530845642089844
}, {
  lat: 51.51045188624856,
  lng: -0.171661376953125
}, {
  lat: 51.50227810647597,
  lng: -0.17131805419921875
}, {
  lat: 51.5019575362143,
  lng: -0.18479347229003906
}, {
  lat: 51.510291630150256,
  lng: -0.18530845642089844
}];
var polyPath2 = [{
  lat: 51.51600708249261,
  lng: -0.17844200134277344
}, {
  lat: 51.50746034612787,
  lng: -0.17844200134277344
}, {
  lat: 51.507353501776365,
  lng: -0.16393661499023438
}, {
  lat: 51.51611390655047,
  lng: -0.1641082763671875
}, {
  lat: 51.51600708249261,
  lng: -0.17844200134277344
}];
html,
body,
#map_canvas {
  height: 100%;
  width: 100%;
  margin: 0px;
  padding: 0px
}
<script src="https://maps.googleapis.com/maps/api/js?libraries=geometry&key=AIzaSyCkUOdZ5y7hMm0yrcCQoCvLwzdM6M8s5qk"></script>
<script src="https://cdn.rawgit.com/bjornharrtell/jsts/gh-pages/1.0.2/jsts.min.js"></script>
<div id="map_canvas"></div>

关于google-maps - 如何合并多边形(纬度和经度)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36051451/

相关文章:

安卓 map : How to animate polyline on Map?

javascript - 如何为 Google Places API 自动完成文本框设置默认值

ruby - 为 shapefile 中的多边形着色

android - 如何使用适用于 Android 的谷歌地图获取特化的医院详细信息?

javascript - 在 vue.js 项目中风格化谷歌地图

git - .gitattributes 中的 merge 策略不起作用

sql - Oracle 11g - 合并单列重复项以创建垂直摘要

java - 对象链表的归并排序(升序)

docker - 使用 docker-compose 运行 GeoNode

gis - 将 CAD 文件转换为形状文件