zoukankan      html  css  js  c++  java
  • 百度地图API示例之设置地图显示范围

     

    代码

    复制代码
    <!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 {width: 100%;height: 100%;margin:0;font-family:"微软雅黑";}
            #allmap{width: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=sSelQoVi2L3KofLo1HOobonW"></script>
        <script type="text/javascript" src="http://api.map.baidu.com/library/AreaRestriction/1.2/src/AreaRestriction_min.js"></script>
        <title>设置地图显示范围</title>
    </head>
    <body>
        <div id="allmap"></div>
        <p>将地图显示范围设定在指定区域,地图拖出该区域后会重新弹回。</p>
    </body>
    </html>
    <script type="text/javascript">
        //百度地图API功能    
        var map = new BMap.Map("allmap");
        map.centerAndZoom(new BMap.Point(116.404, 39.915), 13);
        // map.centerAndZoom(new BMap.Point(116.027143, 39.772348),13); // 测试为左下角的位置
        // map.centerAndZoom(new BMap.Point(116.832025, 40.126349),13); // 测试为右上角的位置
        map.enableScrollWheelZoom(); // 允许滚动
        var b = new BMap.Bounds(new BMap.Point(116.027143, 39.772348),new BMap.Point(116.832025, 40.126349)); // 范围 左下角,右上角的点位置 
        try {    // js中尽然还有try catch方法,可以避免bug引起的错误
            BMapLib.AreaRestriction.setBounds(map, b); // 已map为中心,已b为范围的地图
        } catch (e) {
            // 捕获错误异常
            alert(e);
        }
    </script>
    复制代码

    引入更多的类AreaRestriction_min

    /**
     * @fileoverview 百度地图浏览区域限制类,对外开放。
     * 允许开发者输入限定浏览的地图区域的Bounds值,
     * 则地图浏览者只能在限定区域内浏览地图。
     * 基于Baidu Map API 1.2。
     *
     * @author Baidu Map Api Group
     * @version 1.2
     */
     
      /**
       * @namespace BMap的所有library类均放在BMapLib命名空间下
       */
      var BMapLib = window.BMapLib = BMapLib || {};
     
      (function() {
     
          /**
           * @exports AreaRestriction as BMapLib.AreaRestriction
           */
          var AreaRestriction =
              /**
               * AreaRestriction类,静态类,不用实例化
               * @class AreaRestriction类提供的都是静态方法,勿需实例化即可使用。     
               */
              BMapLib.AreaRestriction = function(){
              }
          
          /**
           * 是否已经对区域进行过限定的标识
           * @private
           * @type {Boolean}
           */
          var _isRestricted = false;
     
          /**
           * map对象
           * @private
           * @type {BMap}
           */
          var _map = null;
     
          /**
           * 开发者需要限定的区域
           * @private
           * @type {BMap.Bounds}
           */
          var _bounds = null;
     
          /**
           * 对可浏览地图区域的限定方法
           * @param {BMap} map map对象
           * @param {BMap.Bounds} bounds 开发者需要限定的区域
           *
           * @return {Boolean} 完成了对区域的限制即返回true,否则为false
           */
          AreaRestriction.setBounds = function(map, bounds){
              // 验证输入值的合法性
              if (!map ||
                  !bounds ||
                  !(bounds instanceof BMap.Bounds)) {
                      throw "请检查传入参数值的合法性";
                      return false;
              }
              
              if (_isRestricted) {
                  this.clearBounds();
              }
              _map = map;
              _bounds = bounds;
     
              // 添加地图的moving事件,用以对浏览区域的限制
              _map.addEventListener("moveend", this._mapMoveendEvent);
              _isRestricted = true;
              return true;
          };
     
          /**
           * 需要绑定在地图移动事件中的操作,主要控制出界时的地图重新定位
           * @param {Event} e e对象
           *
           * @return 无返回值
           */
          AreaRestriction._mapMoveendEvent = function(e) {
              // 如果当前完全没有出界,则无操作
              if (_bounds.containsBounds(_map.getBounds())) {
                  return;
              }
     
              // 两个需要对比的bound区域的边界值
              var curBounds = _map.getBounds(),
                    curBoundsSW = curBounds.getSouthWest(),
                    curBoundsNE = curBounds.getNorthEast(),
                    _boundsSW = _bounds.getSouthWest(),
                    _boundsNE = _bounds.getNorthEast();
     
              // 需要计算定位中心点的四个边界
              var boundary = {n : 0, e : 0, s : 0, w : 0};
              
             // 计算需要定位的中心点的上方边界
             boundary.n = (curBoundsNE.lat < _boundsNE.lat) ?
                                         curBoundsNE.lat :
                                         _boundsNE.lat;
     
             // 计算需要定位的中心点的右边边界
             boundary.e = (curBoundsNE.lng < _boundsNE.lng) ?
                                         curBoundsNE.lng :
                                         _boundsNE.lng;
     
             // 计算需要定位的中心点的下方边界
             boundary.s = (curBoundsSW.lat < _boundsSW.lat) ?
                                         _boundsSW.lat :
                                         curBoundsSW.lat;
     
             // 计算需要定位的中心点的左边边界
             boundary.w = (curBoundsSW.lng < _boundsSW.lng) ?
                                         _boundsSW.lng :
                                         curBoundsSW.lng;
             
             // 设置新的中心点
            var center = new BMap.Point(boundary.w + (boundary.e - boundary.w) / 2,
                                                              boundary.s + (boundary.n - boundary.s) / 2);
            setTimeout(function() {
                 _map.panTo(center, {noAnimation : "no"});
             }, 1);
         };
     
         /**
          * 清除对地图浏览区域限定的状态
          * @return 无返回值
          */
         AreaRestriction.clearBounds = function(){
             if (!_isRestricted) {
                 return;
             }
             _map.removeEventListener("moveend", this._mapMoveendEvent);
             _isRestricted = false;
         };
     
     })();

  • 相关阅读:
    Hammer.js 实现移动端库事件
    使用两个队列模拟一个栈
    选择排序算法
    插入排序算法
    找出一个整形数组中第二大的数字
    双向冒泡排序算法
    求一个整形数组的最大子数组之和
    循环删除数组中元素的问题
    关于如何输出if()..else里的内容的问题
    小米2017秋招真题——电话号码分身问题(Java版)
  • 原文地址:https://www.cnblogs.com/ldms/p/5842153.html
Copyright © 2011-2022 走看看