javascript - 在谷歌地图上绘制多个重叠的圆圈

标签 javascript google-maps google-maps-api-3

我一直在尝试在谷歌地图上绘制多个圆圈。一个半径很大的外圆覆盖所有其他圆圈和其中的多个圆圈。当两个较小的圆圈重叠时,我希望从相交部分删除 alpha .这是我创建的屏幕截图。 This is a screenshot of what i have created.

这是代码:

var bounds = null;
var google_maps = null;
initialize();

function drawCircle(point, radius, dir) { 
    var d2r = Math.PI / 180;   // degrees to radians 
    var r2d = 180 / Math.PI;   // radians to degrees 
    var earthsradius = 3963; // 3963 is the radius of the earth in miles
    var points = 32; 

    // find the raidus in lat/lon 
    var rlat = (radius / earthsradius) * r2d; 
    var rlng = rlat / Math.cos(point.lat() * d2r); 

    var extp = new Array(); 
    if (dir==1) {var start=0;var end=points+1} // one extra here makes sure we connect the
    else{var start=points+1;var end=0}
    for (var i=start; (dir==1 ? i < end : i > end); i=i+dir)  
    {
        var theta = Math.PI * (i / (points/2)); 
        ey = point.lng() + (rlng * Math.cos(theta)); // center a + radius x * cos(theta) 
        ex = point.lat() + (rlat * Math.sin(theta)); // center b + radius y * sin(theta) 
        extp.push(new google.maps.LatLng(ex, ey)); 
        bounds.extend(extp[extp.length-1]);
    }
    return extp;
}

function initialize()
{
    var map_options = {
        center: new google.maps.LatLng(17.385044,78.486671),
        zoom: 15,
        minZoom:9,
        zoomControlOptions: {
            style: google.maps.ZoomControlStyle.SMALL
        },
        mapTypeId: google.maps.MapTypeId.ROADMAP
    };

    google_map = new google.maps.Map(document.getElementById("map_canvas"), map_options);
    google_map.setOptions({styles: $scope.opt.styles});

    bounds = new google.maps.LatLngBounds();
    var myCircles = new google.maps.Polygon({
        paths: [drawCircle(new google.maps.LatLng(17.385044,78.486671), 100, 1),
            drawCircle(new google.maps.LatLng(17.385044,78.486671), 0.5, -1),
            drawCircle(new google.maps.LatLng(17.383044,78.486671), 0.5, -1)],
        strokeColor: "#bababa",
        strokeOpacity: 0.4,
        fillColor: "#bababa",
        fillOpacity: 0.35
    });
    myCircles.setMap(google_map);
}

两个圆的相交部分也必须是透明的。有可能这样做吗?我在互联网上找不到任何东西。

最佳答案

检查是否是demo example link对你有帮助。

这有助于根据您输入的半径找到您绘制的圆。

function initialize() {

var gm = google.maps,
    start_point = new gm.LatLng(17.385044,78.486671),
    map = new gm.Map(document.getElementById('map_canvas'), {
        mapTypeId: gm.MapTypeId.ROADMAP,
        zoom: 16,
        center: start_point
    }),
    marker = new gm.Marker({
        position: start_point,
        map: map,
         //Colors available (marker.png is red):
         //black, brown, green, grey, orange, purple, white & yellow
        icon: 'http://maps.google.com/mapfiles/marker_green.png'
    });
var radius = 500;
var radi= radius/2;
var radi1= radius/4;
var circleOptions = {
        strokeColor: '#FFFF00',
        strokeOpacity: 0.8,
        strokeWeight: 2,
        fillColor: '#FFFF00',
        fillOpacity: 0.35,
        map: map,
        center: start_point,
        radius: radius
    };

  var circleOptions1 = {
        strokeColor: '#F00FF0',
        strokeOpacity: 0.8,
        strokeWeight: 2,
        fillColor: '#F00FF0',
        fillOpacity: 0.35,
        map: map,
        center: start_point,
        radius: radi
    };

  var circleOptions2 = {
        strokeColor: '#F00FF0',
        strokeOpacity: 0.8,
        strokeWeight: 2,
        fillColor: '#F00FF0',
        fillOpacity: 0.35,
        map: map,
        center: start_point,
        radius: radi1
    };
    // Add the circle to the map.
    var markerCircle = new google.maps.Circle(circleOptions);
    var markerCircle1 = new google.maps.Circle(circleOptions1);
      var markerCircle2 = new google.maps.Circle(circleOptions2);

}


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

关于javascript - 在谷歌地图上绘制多个重叠的圆圈,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23150977/

相关文章:

javascript - 在子菜单页面上保持打开状态的垂直菜单下拉菜单

javascript - jQuery 检查电子邮件地址是否是数组元素中字符串的一部分

Android MapView 不以点为中心

javascript - 如何更改 Google map v3 方向上虚线的颜色

javascript - AmChart StartDuration 不起作用

javascript - jQuery fn 等效项

jquery - 如何使用 Google Maps API 禁用鼠标滚轮缩放

Android Google Map Cluster 图标忽略自定义图标

gwt - Eclipse 的示例 "Google Maps API v3 for GWT"项目

javascript - 如何在预先存在的折线上放置标记?