欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

百度地图行政区划遮罩+描点+信息窗demo

程序员文章站 2022-03-16 18:19:10
...
工作中用到了百度地图,将用到的代码进行整理,供大家参考。
<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">
    body, html,#allmap {width: 100%;height: 100%;overflow: hidden;margin:0;font-family:"微软雅黑";}
    </style>
    <!-- 开发需要替换** 可以在百度地图开放平台申请 -->
    <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=您的**"></script>
    <!-- 点聚合需引用 -->
    <script type="text/javascript" src="http://api.map.baidu.com/library/TextIconOverlay/1.2/src/TextIconOverlay_min.js"></script>
    <script type="text/javascript" src="http://api.map.baidu.com/library/MarkerClusterer/1.2/src/MarkerClusterer_min.js"></script>
    <title>地图展示</title>
</head>
<body>
    <div id="allmap"></div>
</body>
</html>
<script type="text/javascript">
    // 百度地图API功能
    var map = new BMap.Map("allmap");    // 创建Map实例
    var boundary = ["石家庄市裕华区","石家庄市新华区","石家庄市桥西区","石家庄市长安区"];
    var color = ["#FFD700","#FF83FA","#FF0000","#FF4500"];
    var address = ["石家庄市铁道大学","石家庄市物联网大厦","石家庄科技中心","石家庄植物园","石家庄市裕华区南二环东路河北师范大学"];

    map.centerAndZoom(new BMap.Point(114.527, 38.071), 13);  // 初始化地图,设置中心点坐标和地图级别
    //map.centerAndZoom("河北", 9);  // 初始化地图,第一个参数可以使用中心点坐标,也可以使用城市名称;第二个参数为地图级别
    //添加地图类型控件 
    map.addControl(new BMap.MapTypeControl({
        mapTypes:[
            BMAP_NORMAL_MAP,
            BMAP_HYBRID_MAP
        ]}));     
    //map.setCurrentCity("北京");          // 百度注释(设置地图显示的城市 此项是必须设置的 )  不设置也不影响地图显示,不知道具体作用
    map.enableScrollWheelZoom(true);     //开启鼠标滚轮缩放
    for (var i = 0; i < boundary.length; i++) {
        getBoundary(boundary[i],color[i]);  //行政区划覆盖遮罩
    }
    for (var j = 0; j < address.length; j++) {
        getPoint(address[j]);  //地图描点
    }

    //点聚合
    /* var markers = [];
    for (var i = 0; i < 10; i++) {
       pt = new BMap.Point(Math.random() * 40 + 85, Math.random() * 30 + 21);
       markers.push(new BMap.Marker(pt));
    }
    var markerClusterer = new BMapLib.MarkerClusterer(map, {markers:markers}); */

    //单击获取点击的经纬度
    /* map.addEventListener("click",function(e){
        alert(e.point.lng + "," + e.point.lat);
    }); */



    function getBoundary(area,color){       
        var bdary = new BMap.Boundary();
        bdary.get(area, function(rs){       //获取行政区域
            //map.clearOverlays();        //清除地图覆盖物       
            var count = rs.boundaries.length; //行政区域的点有多少个
            if (count === 0) {
                alert('未能获取当前输入行政区域');
                return ;
            }
            var pointArray = [];
            for (var i = 0; i < count; i++) {
                var ply = new BMap.Polygon(rs.boundaries[i], {strokeColor:"green",fillColor: color ,fillOpacity:"0.3",strokeOpacity:0.3,strokeWeight: 2}); //建立多边形覆盖物
                map.addOverlay(ply);  //添加覆盖物
                pointArray = pointArray.concat(ply.getPath());
            }    
            //map.setViewport(pointArray);    //调整视野  
        });   
    }
    // 将地址解析结果显示在地图上,并调整地图视野
    function getPoint(address) {
        // 创建地址解析器实例
        var myGeo = new BMap.Geocoder();
        myGeo.getPoint(address, function(point){
            if (point) {
                //map.centerAndZoom(point, 16);
                var marker = new BMap.Marker(point);
                map.addOverlay(marker);  //描点
                var opts = {
                    width : 280,     // 信息窗口宽度
                    height: 150,     // 信息窗口高度
                    title : "<span class='content'>详细信息</span>" , // 信息窗口标题
                }
                var infoWindow = new BMap.InfoWindow("<font class='content'>地址:"+address+"<br/>坐标:"+point.lng+"," +point.lat+
                        "<br/><a href='javascript:void(0)' onclick='alert(\"啦啦啦!!!\")' style='font-size:18px;color:blue;text-decoration:underline;'>点击有惊喜!!!</a></font>"
                        ,opts);  //创建信息窗口对象 
                //鼠标点击事件
                marker.addEventListener("click", function(){          
                    map.openInfoWindow(infoWindow,point); //开启信息窗口
                    //map.centerAndZoom(point,14);
                });
                //鼠标移入事件
                /* marker.addEventListener("mouseover", function(){            
                    map.openInfoWindow(infoWindow,point); //开启信息窗口  
                }); */
            }else{
                alert("您选择地址没有解析到结果!"); 
            }
        }, "石家庄市");
    }
</script>

百度地图行政区划遮罩+描点+信息窗demo

相关标签: 百度地图