1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 【百度地图API】如何制作多途经点的线路导航——驾车篇

【百度地图API】如何制作多途经点的线路导航——驾车篇

时间:2021-12-09 05:49:47

相关推荐

【百度地图API】如何制作多途经点的线路导航——驾车篇

摘要:

休假结束,酸奶×××要从重庆驾车去北京。可是途中要去西安奶奶家拿牛奶饼干呢!用百度地图API,能不能帮我实现这个愿望呢?

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

一、创建地图

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

<scripttype="text/javascript"src="http://api./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); //终点-北京

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

好啦,现在来创建一个驾车导航吧~

这句话是不是很简单?用这句话就可以创建驾车导航啦。

vardriving=newBMap.DrivingRoute(map);//创建驾车实例

然后写两个搜索方法:

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

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

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

三、自己绘制折线

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

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

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

第一句、获取数组

第二句、创建折线

第三句、添加折线覆盖物

driving.setSearchCompleteCallback(function(){varpts=driving.getResults().getPlan(0).getRoute(0).getPath();//通过驾车实例,获得一系列点的数组varpolyline=newBMap.Polyline(pts);map.addOverlay(polyline);}

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

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

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

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

API技术咨询

请先下载百度HI聊天工具

JS版HI群:1357363

移动版HI群:1363111

但是呢,我还是喜欢红色的标注啦,我还可以加上文字标注。

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

添加marker和label的代码如下:

varm1=newBMap.Marker(myP1);//创建3个markervarm2=newBMap.Marker(myP2);varm3=newBMap.Marker(myP3);map.addOverlay(m1);map.addOverlay(m2);map.addOverlay(m3);varlab1=newBMap.Label("起点",{position:myP1});//创建3个labelvarlab2=newBMap.Label("途径点",{position:myP2});varlab3=newBMap.Label("终点",{position:myP3});map.addOverlay(lab1);map.addOverlay(lab2);map.addOverlay(lab3);

五、调整到最佳视野

个人认为setViewport是个非常有用的好东西。因为它可以把你的标注展示到一个最完美的视野内。

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

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

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

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

小贴士:你可以做一个延时动画,让最佳视野的展示更漂亮!

另外,marker也是可以有动画的,不要忽略了。详见:/wiki/static/map/API/examples/?v=1.2&3_1#3&1

六、完整代码

<!DOCTYPEhtml><html><head><metahttp-equiv="Content-Type"content="text/html;charset=gb2312"/><title>驾车途经点</title><scripttype="text/javascript"src="http://api./api?v=1.2"></script></head><body><p><inputtype='button'value='开始'οnclick='run();'/></p><divstyle="width:820px;height:500px;border:1pxsolidgray"id="container"></div></body></html><scripttype="text/javascript">varmap=newBMap.Map("container");map.centerAndZoom(newBMap.Point(116.404,39.915),13);map.addControl(newBMap.NavigationControl());//添加平移缩放控件map.addControl(newBMap.ScaleControl());//添加比例尺控件map.addControl(newBMap.OverviewMapControl());//添加缩略地图控件varmyP1=newBMap.Point(106.521436,29.532288);//起点-重庆varmyP2=newBMap.Point(108.983569,34.285675);//终点-西安varmyP3=newBMap.Point(116.404449,39.920423);//终点-北京window.run=function(){map.clearOverlays();//清除地图上所有的覆盖物vardriving=newBMap.DrivingRoute(map);//创建驾车实例driving.search(myP1,myP2);//第一个驾车搜索driving.search(myP2,myP3);//第二个驾车搜索driving.setSearchCompleteCallback(function(){varpts=driving.getResults().getPlan(0).getRoute(0).getPath();//通过驾车实例,获得一系列点的数组varpolyline=newBMap.Polyline(pts);map.addOverlay(polyline);varm1=newBMap.Marker(myP1);//创建3个markervarm2=newBMap.Marker(myP2);varm3=newBMap.Marker(myP3);map.addOverlay(m1);map.addOverlay(m2);map.addOverlay(m3);varlab1=newBMap.Label("起点",{position:myP1});//创建3个labelvarlab2=newBMap.Label("途径点",{position:myP2});varlab3=newBMap.Label("终点",{position:myP3});map.addOverlay(lab1);map.addOverlay(lab2);map.addOverlay(lab3);setTimeout(function(){map.setViewport([myP1,myP2,myP3]);//调整到最佳视野},1000);});}</script>

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。