【百度地图API】制作多途经点的线路导航——路线坐标规划
一、创建地图
大家跟我一起来创建一张简单的地图:
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); //终点-北京
二、创建一个驾车导航和两个驾车搜索
好啦,现在来创建一个驾车导航吧~
这句话是不是很简单?用这句话就可以创建驾车导航啦。
var driving = new BMap.DrivingRoute(map); //创建驾车实例
然后写两个搜索方法:
第一个是搜索从重庆到西安的,第二个是从西安到北京的。
driving.search(myP1, myP2); //第一个驾车搜索 driving.search(myP2, myP3); //第二个驾车搜索
三、自己绘制折线
接下来,我们在回调函数setSearchCompleteCallback中,把搜索完毕的路线绘制出来。
注意哦,这里是两个搜索的路线都绘制出来了哦~~
就这么简单的三句话,很简单吧。
第一句、获取数组
第二句、创建折线
第三句、添加折线覆盖物
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的。
但是呢,我还是喜欢红色的标注啦,我还可以加上文字标注。
所以,我简单地用红色marker加label来表示了。如下图。
添加marker和label的代码如下:
var m1 = new BMap.Marker(myP1); //创建3个markervar 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个labelvar 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个标注都有。如下图:
代码很简单,先来看看类参考:
就是说,只要有点对象数组传进去,系统就会帮你完成最佳视野的展示!!
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】制作多途经点的线路导航——路线坐标规划
面试:你懂什么是分布式系统吗?Redis分布式锁都不会?>>> 最近百度地图转腾讯地图以前用过百度地图实现路线坐标规划,不过搜索了一些没有搜索到腾讯地图的路线坐标规划,于是参数 ...
- 【百度地图】制作多途经点的线路导航,模拟运动 (vue,typescript)
网上有从起点到终点的模拟线路和运动,途经点的比较少. 结合网上demo,再进行了一下修改. VUE (Typescript),先在index.html里引用 <!DOCTYPE html> ...
- 百度地图API制作类似 百度地图的路线导航界面并实现简单的路线规划功能
之前我们讲了怎么在百度地图上设置Marker(如A点..) 和弹出框(跟随Marker的,Marker移动的时候也是会跟着移动的),接着又觉得百度地图自带的放大缩小不(fei)是(chang)很(de ...
- 使用百度地图API制作线路轨迹播放
1.使用百度地图API制作轨迹播放: 可应用于车辆跟踪.行驶线路回放.跑步行程的记录等地图应用场景, 1.1绘制静态轨迹图 获取多个轨迹点point(必须包含经度.纬度) 使用polyline对象依次 ...
- 地图上制作线路的动画_使用百度地图API制作线路轨迹播放
1.使用百度地图API制作轨迹播放: 可应用于车辆跟踪.行驶线路回放.跑步行程的记录等地图应用场景, 1.1绘制静态轨迹图 获取多个轨迹点point(必须包含经度.纬度) 使用polyline对象依次 ...
- IOS开发百度地图API入门到精通-用点生成路线,导航,气泡响应
(转)IOS开发百度地图API入门到精通-用点生成路线,导航,气泡响应 IOS百度地图API开发自定义气泡,点击气泡自动生成路线,以及拖拽 IOS百度地图开发POISearch搜索附近停车场,附近加油 ...
- 【百度地图API】如何制作多途经点的线路导航——驾车篇
摘要: 休假结束,酸奶×××要从重庆驾车去北京.可是途中要去西安奶奶家拿牛奶饼干呢!用百度地图API,能不能帮我实现这个愿望呢? ----------------------------------- ...
- 【百度地图API】制作多途经点的线路导航
先创建一张地图的容器: <div class="pos-a" id="allmap"style="width: 100%; height: 95 ...
- 利用百度地图API制作房产酒店地图
摘要: 想亲手制作一张酷讯.去哪儿.安居客.链接地产那样的房产.酒店地图麼?那赶快来学习吧.(以酷讯为例,如下图) 更多成功案例请点击:http://dev.baidu.com/wiki/map/in ...
最新文章
- quadTree 论文Real-Time Generation of Continuous吃透了
- 小米max2 原生 android,小米Max 2用户类原生系统福利:第三方开发者为其适配LineageOS...
- php军事网站源码,军事网站的设计与实现(PHP+MYSQL)(含录像)
- express中connect-flash中间件的使用
- 怎么判断前轮左右的位置_新手开车技巧,确定前轮位置,准确判断与障碍物距离...
- html css网页布局实例简单,Div+CSS网页布局项目实战一(含设计图、HTML和CSS源文件)...
- 【数据库】使用PLSQL工具时,ORACLE客户端连接串的配置
- 30而立--男人必须明白的事
- 进制转换 pdf_浏览器中的二进制以及相关转换
- 基于Django+链家+Bootstrap真实数据的房源推荐/可视化系统
- VC++ 设置桌面壁纸
- 如何提高电路工作频率
- Golang使用 阿里云OSS存储
- 如何实现文字逐个出现的打字机效果
- 杰理-手表-AC701-watch-添加表盘
- 怎么在短时间内快速提高网站排名
- [渝粤教育] 南昌大学 现场生命急救知识与技能 参考 资料
- SVN E170001:unable to connect to a repository at url
- xcode swift 单元测试 test
- java计算机毕业设计BS架构考研交流学习平台设计与实现MyBatis+系统+LW文档+源码+调试部署
热门文章
- Android中替换头像图标和背景图片
- 从全栈到全维,青云QingCloud的思与行
- 【方向盘】升级到IDEA 2022.1版本后,我把Maven Helper卸载了
- 2020 PostgreSQL亚洲大会-PostgreSQL授权培训机构公益专场精彩回顾
- 有趣的闲话:2019年总结
- 程序员应知——破窗与童子军军规
- Cryptography I 斯坦福大学 Dan Boneh——学习笔记1
- 常见颜色(color)与RGB 的调色
- matlab计算栅格数据逐像元趋势,基于Matlab的栅格数据一元线性回归及显著性检验(slope趋势分析)...
- 如何将实时网页添加到PowerPoint演示文稿