博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
百度地图API —— 制作多途经点的线路导航
阅读量:5039 次
发布时间:2019-06-12

本文共 2680 字,大约阅读时间需要 8 分钟。

 

摘要:

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

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

 

 

一、创建地图

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

  

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

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技术咨询 请先下载工具 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个标注都有。如下图:

 

代码很简单,先来看看:

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

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

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

另外,marker也是可以有动画的,不要忽略了。详见: 

 

 

 

六、完整代码

   
驾车途经点

  

转载于:https://www.cnblogs.com/itfantasy/p/6705538.html

你可能感兴趣的文章
多变量微积分笔记24——空间线积分
查看>>
Magento CE使用Redis的配置过程
查看>>
poi操作oracle数据库导出excel文件
查看>>
(转)Intent的基本使用方法总结
查看>>
Mac 下的Chrome 按什么快捷键调出页面调试工具
查看>>
Windows Phone开发(24):启动器与选择器之发送短信
查看>>
JS截取字符串常用方法
查看>>
Google非官方的Text To Speech和Speech Recognition的API
查看>>
stdext - A C++ STL Extensions Libary
查看>>
Django 内建 中间件组件
查看>>
bootstrap-Table服务端分页,获取到的数据怎么再页面的表格里显示
查看>>
进程间通信系列 之 socket套接字及其实例
查看>>
天气预报插件
查看>>
Unity 游戏框架搭建 (十三) 无需继承的单例的模板
查看>>
模块与包
查看>>
mysql忘记root密码
查看>>
apache服务器中设置目录不可访问
查看>>
嵌入式Linux驱动学习之路(十)字符设备驱动-my_led
查看>>
【NOIP模拟】密码
查看>>
java容器---------手工实现Linkedlist 链表
查看>>