Расчет площади многоугольника, нарисованного на карте Google - PullRequest
18 голосов
/ 27 января 2012

Я ищу точный алгоритм или услугу для расчета площади поверхности Земли, где точки рассчитываются на основе GPS-координат.

Я использую Google Map Api версии 3 и рисую полигоны на основезаписанные координаты, но я не думаю, что стандартные способы расчета площади полигона будут учитывать склоны (холмы).Нужно ли работать с контурами для такой вещи?

Существуют ли какие-либо сторонние сервисы, например ArcGis или другие, которые также учитывают уклоны.

Ответы [ 2 ]

39 голосов
/ 29 января 2012

Да, это определенно возможно. Здесь есть краткое руководство с примером кода:

https://web.archive.org/web/20130301120148/http://geojason.info/demos/line-length-polygon-area-google-maps-v3

Соответствующая часть это:

google.maps.geometry.spherical.computeArea(yourPolygon.getPath());

Официальная документация:

http://code.google.com/apis/maps/documentation/javascript/reference.html#spherical

10 голосов
/ 24 июля 2013

ответ Брэда

google.maps.geometry.spherical.computeArea(yourPolygon.getPath());

правильно, но будьте осторожны, оно применяется только для полигонов, которые не пересекаются. Когда многоугольник начинает самопересекающимися, все идет ужасно неправильно. Вы можете попробовать это по ссылке, которую Брэд дал http://geojason.info/demos/line-length-polygon-area-google-maps-v3/. Просто нарисуйте 4-5 пересекающихся линий и начните играть с вершинами. Расчет площади определенно покажется неправильным.

Если вы не уверены, вот пример:

   var map;

    google.maps.visualRefresh = true;

    google.maps.event.addDomListener(window, 'load', initialize);

    function initialize() {
        var mapOptions = {
            center : new google.maps.LatLng(55.874, -4.287),
            zoom : 16,
            mapTypeId : google.maps.MapTypeId.ROADMAP
        };
        map = new google.maps.Map(document.getElementById("map-canvas"), mapOptions)

        drawExample();
    }

    function drawExample() {
        var pathLeft = [new google.maps.LatLng(55.874, -4.292),
            new google.maps.LatLng(55.875, -4.292),
            new google.maps.LatLng(55.875, -4.290),
            new google.maps.LatLng(55.876, -4.290),
            new google.maps.LatLng(55.876, -4.291),
            new google.maps.LatLng(55.874, -4.291)]

        var polygonLeft = new google.maps.Polygon({
            path : pathLeft,
            map: map
        });

        var areaLeft = google.maps.geometry.spherical.computeArea(polygonLeft.getPath());

        var pathRight = [new google.maps.LatLng(55.874, -4.282),
            new google.maps.LatLng(55.875, -4.282),
            new google.maps.LatLng(55.875, -4.280),
            new google.maps.LatLng(55.8753, -4.2807),
            new google.maps.LatLng(55.876, -4.281),
            new google.maps.LatLng(55.874, -4.281)]

        var polygonRight = new google.maps.Polygon({
            path : pathRight,
            map: map
        });

        var areaRight = google.maps.geometry.spherical.computeArea(polygonRight.getPath());

        console.log("areaLeft: " + areaLeft + "\nareaRight: " + areaRight);
    }

Отчет об ошибке http://code.google.com/p/gmaps-api-issues/issues/detail?id=5624&colspec=ID%20Type%20Status%20Introduced%20Fixed%20Summary%20Stars%20ApiType%20Internal&start=700#makechanges

...