有没有办法根据传单中的缩放级别调整标记图标的大小?

时间:2013-06-29 15:58:29

标签: javascript mapping leaflet

我正在为学校制作一个项目,我需要根据传单地图中的缩放级别调整标记图标的大小,是否有一种简单的方法可以实现此目的?网上的任何教程?在此先感谢您的帮助!!!

2 个答案:

答案 0 :(得分:23)

为了在放大/缩小时更改标记的大小,您需要处理该事件。

map.on('zoomend', function() { });

只要地图完成放大或缩小,就会调用zoomend事件。请参阅API here

现在,在此功能中,您可以调用自定义代码以更改标记的大小。例如,假设您想采用一种简单的方法,并将圆形标记的大小设置为等于地图缩放级别的大小。请参阅CircleMarker here

的API
// Create some marker that will be resized on the map zooming
var myMarker = new L.CircleMarker([10,10], { /* Options */ });

map.on('zoomend', function() {
  var currentZoom = map.getZoom();
  myMarker.setRadius(currentZoom);
});

现在,只要地图放大或缩小,标记的大小就会改变。

答案 1 :(得分:6)

我不确定Stophace指的是circleMarkers没有改变尺寸,但是,添加到批准的答案...如果你想调整circleMakers的大小或改变任何其他造型选项(我发现改变重量是有帮助的连同半径),您可以使用以下方法:

    map.on('zoomend', function() {
        var currentZoom = map.getZoom();
        var myRadius = currentZoom*(1/2); //or whatever ratio you prefer
        var myWeight = currentZoom*(1/5); //or whatever ratio you prefer
            layername.setStyle({radius: myRadius, weight: setWeight});
    });

layername 将替换为包含circleMarkers的任何图层的名称...当然,您可以根据自己的需要更改分数。

我猜OP的学校项目已经完成,但我希望这能帮助那些有同样问题的人!