百度地图API使用方法详解

5年以前  |  阅读数:1156 次  |  编程语言:PHP 

最近做了个项目,其中项目中有个需求需要用到百度地图进行导航,通过查阅相关资料参考百度地图api完成了一个例子。

示例一:

API地址:http://developer.baidu.com/map/jsdemo.htm#a1_2


    <!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>
     <!--调用百度api -->
     <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak;=你的密钥"></script> 
     <title>地图展示</title>
    </head>
    <body>
     <div id="allmap"></div>
    </body>
    </html>
    <script type="text/javascript">
     // 百度地图API功能
     var map = new BMap.Map("allmap"); // 创建Map实例
     map.centerAndZoom("西安", 5);  // 初始化地图,用城市名设置地图中心点
     map.addControl(new BMap.MapTypeControl()); //添加地图类型控件
     map.setCurrentCity("深圳");   // 设置地图显示的城市 此项是必须设置的
     map.enableScrollWheelZoom(true);  //开启鼠标滚轮缩放
     var point = new BMap.Point(116.404, 39.915);
     var marker = new BMap.Marker(point); // 创建点
     map.addOverlay(marker); //添加点
     map.removeOverlay(marker); //删除点
     // 创建地址解析器实例
     var myGeo = new BMap.Geocoder();
     //批量解析
     var adds = ["长沙", "深圳", "香港", "郑州 ", "惠州", "南昌", "赣州", "中山", "阳江", "上海", "无锡", "南京"];
     for (var i = 0; i < adds.length; i++) {
      myGeo.getPoint(adds[i], function (point) {
       if (point) {
        var address = new BMap.Point(point.lng, point.lat);
        var marker = new BMap.Marker(address);
        map.addOverlay(marker);
        var opts = {
         width: 120,  // 信息窗口宽度
         height: 70,  // 信息窗口高度
         title: "项目信息" // 信息窗口标题
        }
        var infoWindow = new BMap.InfoWindow("<a href='#' target='blank'>查看详情</a>", opts); // 创建信息窗口对象
        marker.addEventListener("click", function () {
         map.openInfoWindow(infoWindow,address); //开启信息窗口
        });
       }
      }, "深圳市");
     }
     getBoundary("中国");
     function getBoundary(sRegion) {
      var bdary = new BMap.Boundary();
      bdary.get(sRegion, function (rs) { //获取行政区域
       var count = rs.boundaries.length; //行政区域的点有多少个
       for (var i = 0; i < count; i++) {
        var ply = new BMap.Polygon(rs.boundaries[i], { strokeWeight: 2, strokeColor: "#4A7300", fillColor: "#FFF8DC" }); //建立多边形覆盖物
        map.addOverlay(ply); //添加覆盖物
       }
      });
     }
    </script>

效果如下:

示例二:

百度地图API是由JavaScript语言编写的,在使用之前需要将API引用到页面中: 现在新版本的需要密钥,下面用的是旧版的

显示广州火车站简单实例:


    <!DOCTYPE html> 
    <html> 
    <head> 
     <meta charset="utf-8"/> 
     <title>百度地图API的使用</title> 
     <!-- 百度地图API-->
     <script src="http://api.map.baidu.com/api?v=1.2" type="text/javascript"></script> 
     <script type="text/javascript"> 
     function initialize() { 
      //创建地图实例 
      var map = new BMap.Map('map'); 
      //创建一个坐标
      var point =new BMap.Point(113.264641,23.154905);
      //地图初始化,设置中心点坐标和地图级别 
      map.centerAndZoom(point,15); 
     } 
     window.onload = initialize; 
     </script> 
    </head> 
    <body> 
    <!-- 百度地图地图容器-->
     <div id="map" style="width:500px;height:320px"></div> 
    </body> 
    </html>

地图上添加控件:

//添加控件

map.addControl(new BMap.MapTypeControl());

MapTypeControl ---------地图类型控件

CopyrightControl --------版权控件

ScaleControl --------比例尺控件

NavigationControl ------缩放控件

OverviewMapControl ----缩略图控件

创建标注:


    var marker = new BMap.Marker(point);       // 创建标注
    map.addOverlay(marker);      // 将标注添加到地图中

创建信息窗口:


    var infoWindow = new BMap.InfoWindow("I am here"); // 创建信息窗口对象
    map.openInfoWindow(infoWindow,point);     //开启信息窗口

百度地图偏移量:

经度校正值: 0.008774687519;

纬度校正值: 0.00374531687912;

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
贪吃蛇
文件下载
获取IMEI
双位运算符
发送邮件
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
提取后缀名
年的日历图
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例