百度地图api 的MarkerClusterer 的使用

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了百度地图api 的MarkerClusterer 的使用相关的知识,希望对你有一定的参考价值。

 首先定义

// 百度地图API功能
    var map = new BMap.Map("allmap");
    map.centerAndZoom(new BMap.Point(116.404, 39.915), 5);//中心城市
    map.enableScrollWheelZoom();

之后 开始for循环 出需要的标注点

当然 也可以定义一个数组

var MAX = 10000;
    var markers = [];
    var pt = null;
    var i = 0;
    for (; i < MAX; i++) {
       pt = new BMap.Point(Math.random() * 40 + 85, Math.random() * 30 + 21);
       markers.push(new BMap.Marker(pt));
    }
    //最简单的用法,生成一个marker数组,然后调用markerClusterer类即可。
    var markerClusterer = new BMapLib.MarkerClusterer(map, {markers:markers});

 

 以上就可以查询效果图不过标注点一多就开始卡的要死,所以百度了一下http://www.cnblogs.com/anyuan9/p/6232137.html

这篇文章给我们介绍了MarkerClusterer 这个js文件可以优化一下。

 

但这还不是我们想要的模板

如果要在某一个标注上添加一个事件呢

 

addClickHandler("员工编号:"+codes[j]+"<br/>经度:"+lats[j]+"<br/>纬度:"+lons[j]+"<br/>时间:"+times[j],mk);

 

var opts = {
                width : 250,     // 信息窗口宽度
                height: 120,     // 信息窗口高度
                title : "信息窗口" , // 信息窗口标题
                enableMessage:true//设置允许信息窗发送短息
               };
        function addClickHandler(content,marker){
        marker.addEventListener("click",function(e){
            openInfo(content,e);
            });
    }
    function openInfo(content,e){
        var p = e.target;
        var point = new BMap.Point(p.getPosition().lng, p.getPosition().lat);
        var infoWindow = new BMap.InfoWindow(content,opts);  // 创建信息窗口对象 
        map.openInfoWindow(infoWindow,point); //开启信息窗口
    }

 

依次调用这个方法就ok了。下面展现效果图:

 

 技术分享

 

以上是关于百度地图api 的MarkerClusterer 的使用的主要内容,如果未能解决你的问题,请参考以下文章

Google Maps api Detect使用markerclusterer点击标记[重复]

Google MAP API,对 MarkerClusterer 的限制

谷歌地图:在markerclusterer上方渲染标记

无法在谷歌地图markerclusterer中应用自定义图标进行聚类,因为无法提供位置数据

使用markerclusterer v3获取谷歌地图范围内的标记列表

百度地图聚合功能自定义聚合文字