摘要:

  休假结束,酸奶×××要从重庆驾车去北京。可是途中要去西安奶奶家拿牛奶饼干呢!用百度地图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);    //终点-北京

  

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

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

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

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的。

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

  

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

所以,我简单地用红色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='开始' οnclick='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个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);setTimeout(function(){map.setViewport([myP1,myP2,myP3]);          //调整到最佳视野},1000);});
}
</script>

转载于:https://blog.51cto.com/8920932/1537191

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

  1. 【百度地图API】制作多途经点的线路导航

    先创建一张地图的容器: <div class="pos-a" id="allmap"style="width: 100%; height: 95 ...

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

    一.创建地图 大家跟我一起来创建一张简单的地图: var map = new BMap.Map("container"); map.centerAndZoom(new BMap.P ...

  3. 【腾讯地图API】制作多途经点的线路导航——路线坐标规划

    面试:你懂什么是分布式系统吗?Redis分布式锁都不会?>>>    最近百度地图转腾讯地图以前用过百度地图实现路线坐标规划,不过搜索了一些没有搜索到腾讯地图的路线坐标规划,于是参数 ...

  4. 如何制作多途经点的线路导航——驾车篇

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  5. 百度地图多途经点的线路导航——驾车篇

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

  6. 调用百度地图API接口制作热力图

    调用百度地图API接口制作热力图 Python学了很久,也做了一些机器学习的demo,利用matolotlib库做过一些可视化.今天呢想尝试做一下热力图.先PO一张我最终效果图. 因为数据原因,效果一 ...

  7. 【百度地图API】圣诞节里不会迷路的麋鹿——驾车导航

    原文:[百度地图API]圣诞节里不会迷路的麋鹿--驾车导航 任务描述: 可能大家还不知道,圣诞老人是爱迷路的老爷爷! 今年圣诞节又要到了,圣诞老人又要出来送礼物了.可是,他灰常的迷路呢! 还好,他有一 ...

  8. ArcGIS+百度地图API:制作杭州市边界shp文件

    参考文章:百度地图API+ArcGIS软件-城市出行时空数据可视化_WenWu_Both的博客-CSDN博客 这篇博客在介绍的时候遗漏了很多关键步骤,我对此进行了必要的补充. 一.获取轮廓线的代码(g ...

  9. 【百度地图】制作多途经点的线路导航,模拟运动 (vue,typescript)

    网上有从起点到终点的模拟线路和运动,途经点的比较少. 结合网上demo,再进行了一下修改. VUE (Typescript),先在index.html里引用 <!DOCTYPE html> ...

最新文章

  1. AEM:众里寻他千百度,用了SIP不迷路-识别污水处理单元中砷氧化细菌的多样性及代谢潜力...
  2. java jdbc效率_Java JDBC效率:连接需要多长时间?
  3. 【PHP 每日函数】第 03 周期
  4. 关于python的一些好的书籍推荐-如果只能推荐3本关于python的书,你会推荐哪3本?...
  5. 深度学习笔记8 数据预处理
  6. 织梦DEDECMS网站批量删除未审核稿件的方法
  7. 【GamePlay】入门篇
  8. 不来看看这些 VUE 的生命周期钩子函数? | 原力计划
  9. mysql 字段存文件_使用数据库(mysql)字段保存文件
  10. python3: failed with error code 1 in /tmp/pip-build-qp5puacl/Pillow/
  11. 淘淘商城第34讲——内容管理
  12. 详谈AI芯片架构、分类和关键技术
  13. CRNN中英文字识别
  14. 谈谈对陀螺仪和加速度传感器的感性认识
  15. mysql大小写转换函数_MySQL字母大小写转换函数UPPER(s)、UCASE(s)、LOWER(s)和LCASE(s)
  16. 开水果店的风险,开水果店有什么风险
  17. 英文面试:自我介绍篇
  18. 从“触点”到“旅程”——浅谈数字时代的客户体验提升
  19. Unity引擎制作仿《文明》游戏
  20. 初见“Linux——通配符,命令ls,别名alias,命令du”

热门文章

  1. php删除文件指令,php – Symfony cache:清除命令更改文件夹所有者
  2. 第一次上计算机课日记500,第一次上网课作文500字
  3. java按钮位置_java窗口按钮位置设置
  4. iptable 命令
  5. python之cookies
  6. Centos 配置mailx使用外部smtp发送邮件
  7. 关于oracle中table函数的使用
  8. Linux段式管理与页式管理
  9. SpringBoot日记——ElasticSearch全文检索
  10. Apache solr(二).