• 给地图增加自定义覆盖物


    <!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 { 100%;height: 100%;margin:0;font-family:"微软雅黑";}
            #allmap{100%;height:500px;}
            p{margin-left:5px; font-size:14px;}
        </style>
        <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=yaDRGoon5YoRzAAwH781yUgn"></script>
        <title>添加自定义覆盖物</title>
    </head>
    <body>
    <div id="allmap"></div>
    <div id="control">
        <input type="button" onclick="hide_show()" value="点击">
    </div>
    </body>
    </html>
    <script type="text/javascript">
        // 百度地图API功能
        var mp = new BMap.Map("allmap");//创建地图实例
        mp.centerAndZoom(new BMap.Point(116.3964,39.9093), 15);
        ////地图初始化,设置中心点坐标和地图级别。地图必须经过初始化才可以执行其他操作
        mp.enableScrollWheelZoom();
        // 复杂的自定义覆盖物
        function ComplexCustomOverlay(point){
            this._point = point;
    
        }
        ComplexCustomOverlay.prototype = new BMap.Overlay();
        ComplexCustomOverlay.prototype.initialize = function(map){
            this._map = map;
            var div = this._div = document.createElement("div");
            div.style.position = "absolute";
            div.style.zIndex = BMap.Overlay.getZIndex(this._point.lat);//聚合功能?
            div.style.height = "45px";
            div.style.width="45px";
    
            var arrow = this._arrow = document.createElement("img");
            arrow.src = "1.png";/*加入图片路径*/
            arrow.style.width = "100px";
            arrow.style.height = "100px";
            arrow.style.top = "22px";
            arrow.style.left = "10px";
            div.appendChild(arrow);
    
    
            mp.getPanes().labelPane.appendChild(div);//getPanes(),返回值:MapPane,返回地图覆盖物容器列表  labelPane呢???
    
            return div;
    
        }
    
        ComplexCustomOverlay.prototype.draw = function(){
            var map = this._map;
            var pixel = map.pointToOverlayPixel(this._point);
            this._div.style.left = pixel.x - parseInt(this._arrow.style.left) + "px";
            this._div.style.top  = pixel.y - 30 + "px";
        }
    
    
        var myCompOverlay = new ComplexCustomOverlay(new BMap.Point(116.407845,39.914101));
    
        mp.addOverlay(myCompOverlay);//将标注添加到地图中
    
        var show=0;
        function hide_show(){
            if(show==0){
                myCompOverlay.hide();
                show=1;
            }else{
                myCompOverlay.show();
                show=0;
            }
        }
    
    </script>
  • 相关阅读:
    装箱拆箱操作
    《设计原本》试读:什么是设计
    代码大全中英文要点
    JSON对象和字符串之间的相互转换
    《设计原本》试读:何为真实?设计的概念
    Facebook后台技术探秘 世界最大的PHP网站
    重构模式:用异步计算替代长计算
    生命不息编程不止 Facebook CEO还在写代码
    万能的js复制按钮
    《网站设计解构》试读:1.1 可重用策略
  • 原文地址:https://www.cnblogs.com/iriliguo/p/7047497.html
Copyright © 2020-2023  润新知