2016-07-20 7 views

Antwort

2

Sie können die Methode google.maps.geometry.spherical.computeOffset verwenden, um einen Pfad für ein kreisförmiges Polygon mit demselben Radius und Mittelpunkt zu berechnen (erfordert die Bibliothek geometry).

function circlePath(circle) { 
    var numPts = 512; 
    var path = []; 
    for (var i = 0; i < numPts; i++) { 
    path.push(google.maps.geometry.spherical.computeOffset(circle.getCenter(), circle.getRadius(), i * 360/numPts)); 
    } 
    return path; 
} 

Code-Schnipsel:

var geocoder; 
 
var map; 
 

 
function circlePath(circle) { 
 
    var numPts = 512; 
 
    var path = []; 
 
    for (var i = 0; i < numPts; i++) { 
 
    path.push(google.maps.geometry.spherical.computeOffset(circle.getCenter(), circle.getRadius(), i * 360/numPts)); 
 
    } 
 
    return path; 
 
} 
 

 
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 circle = new google.maps.Circle({ 
 
    map: map, 
 
    radius: 1000, 
 
    center: map.getCenter(), 
 
    fillOpacity: 0.2 
 
    }); 
 
    var polygon = new google.maps.Polygon({ 
 
    map: map, 
 
    paths: [circlePath(circle)], 
 
    fillColor: 'red', 
 
    fillOpacity: 0.5, 
 
    strokeColor: 'red' 
 
    }); 
 
    google.maps.event.addDomListener(document.getElementById('circle'), 'click', function() { 
 
    circle.setMap(circle.getMap() == null ? map : null); 
 
    }); 
 
    google.maps.event.addDomListener(document.getElementById('polygon'), 'click', function() { 
 
    polygon.setMap(polygon.getMap() == null ? map : null); 
 
    }); 
 
} 
 
google.maps.event.addDomListener(window, "load", initialize);
html, 
 
body, 
 
#map_canvas { 
 
    height: 100%; 
 
    width: 100%; 
 
    margin: 0px; 
 
    padding: 0px 
 
}
<script src="https://maps.googleapis.com/maps/api/js?libraries=geometry"></script> 
 
<input type="button" id="circle" value="toggle circle" /> 
 
<input type="button" id="polygon" value="toggle polygon" /> 
 

 
<div id="map_canvas"></div>