【百度地图API】制做多途经点的线路导航——路线坐标规划

1、建立地图javascript

首先要告诉你们的是,API1.2版本取消密钥,取消服务设置,你们能够采用更加简短的方式引用API的JS啦~php

<script type="text/javascript" src="http://api.map.baidu.com/api?v=1.2"></script>

  

你们跟我一块儿来建立一张简单的地图:html

var map = new BMap.Map("container");
map.centerAndZoom(new BMap.Point(116.404, 39.915), 13);

  

而后为地图加上一些合适的控件:java

map.addControl(new BMap.NavigationControl()); // 添加平移缩放控件
map.addControl(new BMap.ScaleControl()); // 添加比例尺控件
map.addControl(new BMap.OverviewMapControl()); //添加缩略地图控件

  

我手工找到的重庆、西安、北京三个城市的坐标点,使用坐标拾取工具(请点击)能够轻松找到这三个经纬度。api

固然,你也可使用localsearch类的search方法。这个能够随意。数组

找到坐标点以后,建立三个点对象。函数

var myP1 = new BMap.Point(106.521436,29.532288); //起点-重庆
var myP2 = new BMap.Point(108.983569,34.285675); //终点-西安
var myP3 = new BMap.Point(116.404449,39.920423); //终点-北京

  

2、建立一个驾车导航和两个驾车搜索工具

好啦,如今来建立一个驾车导航吧~动画

这句话是否是很简单?用这句话就能够建立驾车导航啦。ui

var driving = new BMap.DrivingRoute(map); //建立驾车实例

  

而后写两个搜索方法:

第一个是搜索从重庆到西安的,第二个是从西安到北京的。

driving.search(myP1, myP2);                 //第一个驾车搜索
driving.search(myP2, myP3); //第二个驾车搜索

  

3、本身绘制折线

接下来,咱们在回调函数setSearchCompleteCallback中,把搜索完毕的路线绘制出来。

注意哦,这里是两个搜索的路线都绘制出来了哦~~

就这么简单的三句话,很简单吧。

第一句、获取数组

第二句、建立折线

第三句、添加折线覆盖物

    driving.setSearchCompleteCallback(function(){
var pts = driving.getResults().getPlan(0).getRoute(0).getPath(); //经过驾车实例,得到一系列点的数组

var polyline = new BMap.Polyline(pts);
map.addOverlay(polyline);
}

  

这个时候,整个驾车导航就是这个样子滴,简直充满了喜感,像一条蚯蚓呢  O(∩_∩)O~

4、添加起点、终点、途经点marker

其实这个途经点,能够作成像百度地图首页的驾车导航那样,有红绿色的起点终点图标。以下图:

注意:这一点,你们随意,你们想加marker(能够更换任意的icon图片),或者想加label,甚至是别的什么覆盖物,都是OK的。

API技术咨询
请先下载百度HI聊天工具
JS版HI群:1357363
移动版HI群:1363111

  

可是呢,我仍是喜欢红色的标注啦,我还能够加上文字标注。

因此,我简单地用红色marker加label来表示了。以下图。

添加marker和label的代码以下:

复制代码
        var m1 = new BMap.Marker(myP1); //建立3个marker
var m2 = new BMap.Marker(myP2);
var m3 = new BMap.Marker(myP3);
map.addOverlay(m1);
map.addOverlay(m2);
map.addOverlay(m3);

var lab1 = new BMap.Label("起点",{position:myP1}); //建立3个label
var lab2 = new BMap.Label("途径点",{position:myP2});
var lab3 = new BMap.Label("终点",{position:myP3});
map.addOverlay(lab1);
map.addOverlay(lab2);
map.addOverlay(lab3);
复制代码

  

5、调整到最佳视野

我的认为setViewport是个很是有用的好东西。由于它能够把你的标注展现到一个最完美的视野内。

若是不加setViewport,你的地图可能只会出现一半的有效视野,而不是完整的3个标注都有。以下图:

代码很简单,先来看看类参考

就是说,只要有点对象数组传进去,系统就会帮你完成最佳视野的展现!!

map.setViewport([myP1,myP2,myP3]);          //调整到最佳视野

小贴士:你能够作一个延时动画,让最佳视野的展现更漂亮! 

另外,marker也是能够有动画的,不要忽略了。详见:http://dev.baidu.com/wiki/static/map/API/examples/?v=1.2&3_1#3&1 

6、完整代码

复制代码
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>驾车途经点</title>
<script type="text/javascript" src="http://api.map.baidu.com/api?v=1.2"></script>
</head>
<body>
<p><input type='button' value='开始' onclick='run();' /></p>
<div style="width:820px;height:500px;border:1px solid gray" id="container"></div>

</body>
</html>
<script type="text/javascript">
var map = new BMap.Map("container");
map.centerAndZoom(new BMap.Point(116.404, 39.915), 13);
map.addControl(new BMap.NavigationControl()); // 添加平移缩放控件
map.addControl(new BMap.ScaleControl()); // 添加比例尺控件
map.addControl(new BMap.OverviewMapControl()); //添加缩略地图控件

var myP1 = new BMap.Point(106.521436,29.532288); //起点-重庆
var myP2 = new BMap.Point(108.983569,34.285675); //终点-西安
var myP3 = new BMap.Point(116.404449,39.920423); //终点-北京

window.run = function (){
map.clearOverlays(); //清除地图上全部的覆盖物
var driving = new BMap.DrivingRoute(map); //建立驾车实例
driving.search(myP1, myP2); //第一个驾车搜索
driving.search(myP2, myP3); //第二个驾车搜索
driving.setSearchCompleteCallback(function(){
var pts = driving.getResults().getPlan(0).getRoute(0).getPath(); //经过驾车实例,得到一系列点的数组 var polyline = new BMap.Polyline(pts); map.addOverlay(polyline); var m1 = new BMap.Marker(myP1); //建立3个marker var m2 = new BMap.Marker(myP2); var m3 = new BMap.Marker(myP3); map.addOverlay(m1); map.addOverlay(m2); map.addOverlay(m3); var lab1 = new BMap.Label("起点",{position:myP1}); //建立3个label var lab2 = new BMap.Label("途径点",{position:myP2}); var lab3 = new BMap.Label("终点",{position:myP3}); map.addOverlay(lab1); map.addOverlay(lab2); map.addOverlay(lab3); setTimeout(function(){ map.setViewport([myP1,myP2,myP3]); //调整到最佳视野 },1000); });}</script>
复制代码
相关文章
相关标签/搜索