百度地图API之如何制作驾车导航

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了百度地图API之如何制作驾车导航相关的知识,希望对你有一定的参考价值。

答案是,使用数据接口。数据接口,可以让百度地图API的数据,按照自定义的形式展示。 这个功能非常实用,学会这个方法,可以让您的地图更加接近百度地图的功能!一、创建地图与网页样式 创建一张简单的地图,只需要3句话。varmap =newBMap.Map("container"); //创建Map实例 varpoint =newBMap.Point(116.404, 39.915); //创建点坐标 map.centerAndZoom(point,15); //初始化地图,设置中心点坐标和地图级别。 然后,我们制作出两个输入框,分别是起点输入框,和终点输入框。 从<input class="txt"type="text"value="机场"id="startInput"/>到<input class="txt"type="text"value="西站"id="endInput"/> <input type="button"value="驾车"onclick="mDriving()"/> 使用“驾车”按钮,获取输入框中的数据。functionmDriving()varstartPlace =document.getElementById("startInput").value;varendPlace =document.getElementById("endInput").value; 二、创建搜索实例 对于起点和终点,我们需要创建2个不同的搜索实例://创建2个搜索实例 varstartSearch =newBMap.LocalSearch(map,startOption);varendSearch =newBMap.LocalSearch(map,endOption); 在点击“驾车”按钮后,开始搜索起点和终点都有哪些符合关键词的地方(POI点)。functionmDriving()varstartPlace =document.getElementById("startInput").value;varendPlace =document.getElementById("endInput").value; startSearch.search(startPlace); endSearch.search(endPlace); document.getElementById("box").style.display="block"; 三、搜索的数据接口 由于AJAX是异步加载的,我们使用百度地图API提供的回调函数onSearchComplete,来完成对搜索成功后的操作。 当搜索成功后,把每一个搜索结果(POI),按照我们自定义的方式,列在面板中。其实,这里我们只使用了数据接口,没用百度默认的结果面板。varstartOption = onSearchComplete: function(results)//判断状态是否正确if(startSearch.getStatus() ==BMAP_STATUS_SUCCESS) startResults =results;vars =[];for(vari =0;i <results.getCurrentNumPois(); i ++) s.push("<div><p><a onmouseover='map.openInfoWindow(startInfowin,startResults.getPoi("+i +").point);' href='#'>"); s.push(results.getPoi(i).title); s.push("</a></p><p>"); s.push(results.getPoi(i).address); s.push("</p></div>"); document.getElementById("startPanel").innerhtml =s.join(""); elsestartResults =null; ; 当用户鼠标移到起点面板的标题处,我们在地图上打开一个信息窗口。里面放“选为起点”的按钮。varstartInfowin =newBMap.InfoWindow("<p class='t-c'><input value='选为起点' type='button' onclick='startDeter();' /></p>"); 用户点击“选为起点”的按钮后,选定该点为起点,并隐藏起点面板,让用户选择终点。 为了方便看清起点的位置,我们需要在地图上打个红色的标注。并且,再次选择起点时,要清楚上一次的标注。functionstartDeter() map.clearOverlays(); startPoint =startInfowin.getPosition();varmarker =newBMap.Marker(startPoint); map.addOverlay(marker); document.getElementById("startPanel").style.display="none"; 同理,制作终点的面板。这里需要注意的是,终点和起点不同,选择终点之后,需要创建一个驾车实例,并且绘制出驾车路线。 所以要做一个判断,用户是否已经选择了起点。如果没有,提示用户要先选择起点。functionendDeter() if(startPoint==null)alert("请先选择起点!");else endPoint =endInfowin.getPosition(); driving.search(startPoint,endPoint); document.getElementById("endPanel").style.display="none"; 四、创建驾车实例和结果面板 在选择完毕确定的终点和起点后,驾车的结果就明了了。 一句话,轻松搞定。 vardriving =newBMap.DrivingRoute(map, renderOptions:map: map, autoViewport: true,panel:drivingPanel);五、页面样式完善 为了让页面干净好看,我们可以把不必要的结果展示暂时隐藏起来,当需要它们的时候,再展开。 参考技术A

一、创建地图与网页样式

创建一张简单的地图,只需要3句话。

varmap =newBMap.Map("container"); //创建Map实例   
varpoint =newBMap.Point(116.404, 39.915); //创建点坐标   
map.centerAndZoom(point,15); //初始化地图,设置中心点坐标和地图级别。

然后,制作出两个输入框,分别是起点输入框,和终点输入框。

从<input class="txt"type="text"value="机场"id="startInput"/>到<input class="txt"type="text"value="西站"id="endInput"/>  <input type="button"value="驾车"onclick="mDriving()"/>使用“驾车”按钮,获取输入框中的数据。

functionmDriving()varstartPlace =document.getElementById("startInput").value;varendPlace =document.getElementById("endInput").value;

二、创建搜索实例

对于起点和终点,我们需要创建2个不同的搜索实例:

//创建2个搜索实例  varstartSearch =newBMap.LocalSearch(map,startOption);varendSearch =newBMap.LocalSearch(map,endOption); 在点击“驾车”按钮后,开始搜索起点和终点都有哪些符合关键词的地方(POI点)。

 

functionmDriving()varstartPlace =document.getElementById("startInput").value;varendPlace =document.getElementById("endInput").value;  startSearch.search(startPlace);  endSearch.search(endPlace);  document.getElementById("box").style.display="block";   

参考资料:http://baidutech.blog.51cto.com/4114344/744324/

百度地图API怎样制作多途经点的线路导航——驾车篇

摘要:

  休假结束,酸奶小妹要从重庆驾车去北京。但是途中要去西安奶奶家拿牛奶饼干呢!

用百度地图API,能不能帮我实现这个愿望呢?

------------------------------------------------------------------------------------------------------------------------

一、创建地图

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

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

  

大家跟我一起来创建一张简单的地图:

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());              //加入缩略地图控件

  

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

当然。你也能够使用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);    //终点-北京

  

二、创建一个驾车导航和两个驾车搜索

好啦。如今来创建一个驾车导航吧~

这句话是不是非常easy?用这句话就能够创建驾车导航啦。

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

  

然后写两个搜索方法:

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

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

  

三、自己绘制折线

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

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

就这么简单的三句话,非常easy吧。

第一句、获取数组

第二句、创建折线

第三句、加入折线覆盖物

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

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

  

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

四、加入起点、终点、途经点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);
复制代码

  

五、调整到最佳视野

个人觉得setViewport是个很实用的好东西。由于它能够把你的标注展示到一个最完美的视野内。

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

代码非常easy,先来看看类參考

就是说。仅仅要有点对象数组传进去,系统就会帮你完毕最佳视野的展示。!

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

小贴士:你能够做一个延时动画,让最佳视野的展示更美丽。 

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

六、完整代码

复制代码
<!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>

复制代码

  

以上是关于百度地图API之如何制作驾车导航的主要内容,如果未能解决你的问题,请参考以下文章

百度地图API详解之公交导航

百度地图API —— 制作多途经点的线路导航

Android 百度地图API 如何计算两个坐标之间的驾车距离?

如何在H5中调用百度地图APP和高德地图APP

百度地图怎么设置

如何制作离线地图