【百度地图API】如何制作自定义样式的公交导航结果面板?
原文:【百度地图API】如何制作自定义样式的公交导航结果面板?
摘要:
百度地图API有默认的公交导航结果面板,但样式比较单一;而百度地图上的结果面板就比较美观。如何利用百度地图API来制作一个比较美观的公交导航结果面板呢?一起来学习一下吧。
----------------------------------------------------------------------------------------------
首先,看一下百度地图上的结果面板,如下图:

再来看看百度地图API默认的结果面板:

大家发现有什么不一样的了麽?
对啦,API默认的结果面板上,没有那些好看的图标哦~~
接下来,我们要一起制作如下图一样的自定义API结果面板!

-------------------------------------------------------------------------
一、创建一个公交导航

(如何创建地图,我这里就不写了。大家记得用1.2版本就好。)
注意写上回调函数onSearchComplete,当查询成功后,调用该函数milkSearchFun。
var tansit = new BMap.TransitRoute(map, {renderOptions:{map: map, autoViewport: true}, onSearchComplete: milkSearchFun});
tansit.search("中央民族大学", "北京邮电大学");
二、判断有无换乘
判断有无换乘,可以使用判断步行路段的方法。如果步行路段为2,表示没有换乘。代码如下:
var milkRouteNum = milkPlan.getNumRoutes(); //提前判断一下,如果为2,即表示无换乘.
API逻辑分析:
以最简单的“不换乘”为例,任意公交导航包含以下三个部分:
1、步行:从起点到公交站上车车站;
2、公交:从上车车站到下车车站;
3、步行:从下车车站到终点。
粉色表示步行路段,蓝色表示公交路段。红色为起点,绿色为终点。
示意图如下:

三、使用数据接口获取公交导航数据
全部注释,我都写得很清楚了,大家可以对应类参考,仔细查看一下。
var milkStartTitle = tansit.getResults().getStart().title; //公交导航起点的名字
var milkEndTitle = tansit.getResults().getEnd().title; //公交导航终点的名字
var milkPlan = tansit.getResults().getPlan(0); //获取第一条公交导航
var milkDescription = milkPlan.getDescription(); //获取第一条公交导航的全部描述(带html)
var milkLine = milkPlan.getLine(0).title; //获取公交线路(比如331路)的名称
var milkLineGeton = milkPlan.getLine(0).getGetOnStop().title; //获取上车点站名
var milkLineGetoff = milkPlan.getLine(0).getGetOffStop().title; //获取下车点站名
var milkRouteStart = milkPlan.getRoute(0).getDistance(); //从起点到上车车站的距离
var milkRouteEnd = milkPlan.getRoute(1).getDistance(); //从下车车站到终点的距离
四、打印出自定义的结果面板
获取到全部数据后,就可以自己随意定制结果面板了。
首先,打印起点milkStartTitle 和终点milkEndTitle 。
然后,按照步骤打印步行-公交-步行,这三个结果。(因为无换乘,所以有3段路。)
注意:如果有步行距离为0的,可以做个判断,不打印该路段。
最后,加上一些css样式。
document.getElementById("milkResult").innerHTML =
"<p style='background:url(start.jpg) no-repeat 0 center;padding:0 0 0 30px'><b style='color:#fff;background:#ff55cc;padding:2px;'>" + milkStartTitle + "</b></p>" +
"<p style='background:url(walk.jpg) no-repeat 0 center;padding:0 0 0 30px'>步行<b>" + milkRouteStart + "</b>,至" + milkStartTitle + "</p>" +
"<p style='background:url(bus.jpg) no-repeat 0 center;padding:0 0 0 30px'>在<b>" + milkLineGeton + "</b>上车,乘坐<b>" + milkLine + "</b>,在<b>" + milkLineGetoff + "</b>下车</p>" +
"<p style='background:url(walk.jpg) no-repeat 0 center;padding:0 0 0 30px'>步行<b>" + milkRouteEnd + "</b>,至终点</p>" +
"<p style='background:url(end.jpg) no-repeat 0 center;padding:0 0 0 30px'><b style='color:#fff;background:#ff55cc;padding:2px;'>" + milkEndTitle + "</b></p>";
-------------------------------------------------------------------------
TIPS:
误区一、有直接的结果面板样式接口使用。
解释:只能通过数据接口来实现修改结果面板样式的目的哦~
误区二、通过控制API默认结果面板自动生成的html标签来修改样式。
解释:描述里只有<b>这样的html标签,并没有用<p>来区分公交和步行的描述,所以无法直接用css来控制哦。如下图:

------------------------------------------------------------------------
全部源代码:
<!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>
<style>
body {font-size:14px;line-height:20px;}
</style>
</head>
<body>
<div style="width:500px;height:340px;border:1px solid gray;float:left;" id="container"></div>
<div style="width:400px;height:340px;border:1px solid gray;float:left;border-left:none;"id="milkResult"></div>
</body>
</html>
<script type="text/javascript">
var map = new BMap.Map("container");
map.centerAndZoom(new BMap.Point(116.404, 39.915), 14);
function milkSearchFun(){
var milkStartTitle = tansit.getResults().getStart().title; //公交导航起点的名字
var milkEndTitle = tansit.getResults().getEnd().title; //公交导航终点的名字
var milkPlan = tansit.getResults().getPlan(0); //获取第一条公交导航
var milkDescription = milkPlan.getDescription(); //获取第一条公交导航的全部描述(带html)
var milkLine = milkPlan.getLine(0).title; //获取公交线路(比如331路)的名称
var milkLineGeton = milkPlan.getLine(0).getGetOnStop().title; //获取上车点站名
var milkLineGetoff = milkPlan.getLine(0).getGetOffStop().title; //获取下车点站名
var milkRouteNum = milkPlan.getNumRoutes(); //提前判断一下,如果为2,即表示无换乘.
var milkRouteStart = milkPlan.getRoute(0).getDistance(); //从起点到上车车站的距离
var milkRouteEnd = milkPlan.getRoute(1).getDistance(); //从下车车站到终点的距离
document.getElementById("milkResult").innerHTML =
"<p style='background:url(start.jpg) no-repeat 0 center;padding:0 0 0 30px'><b style='color:#fff;background:#ff55cc;padding:2px;'>" + milkStartTitle + "</b></p>" +
"<p style='background:url(walk.jpg) no-repeat 0 center;padding:0 0 0 30px'>步行<b>" + milkRouteStart + "</b>,至" + milkStartTitle + "</p>" +
"<p style='background:url(bus.jpg) no-repeat 0 center;padding:0 0 0 30px'>在<b>" + milkLineGeton + "</b>上车,乘坐<b>" + milkLine + "</b>,在<b>" + milkLineGetoff + "</b>下车</p>" +
"<p style='background:url(walk.jpg) no-repeat 0 center;padding:0 0 0 30px'>步行<b>" + milkRouteEnd + "</b>,至终点</p>" +
"<p style='background:url(end.jpg) no-repeat 0 center;padding:0 0 0 30px'><b style='color:#fff;background:#ff55cc;padding:2px;'>" + milkEndTitle + "</b></p>";
}
var tansit = new BMap.TransitRoute(map, {renderOptions:{map: map, autoViewport: true}, onSearchComplete: milkSearchFun});
tansit.search("故宫", "颐和园");
</script>
-------------------------------------------------------------------------
备注:
如果有“换乘”怎么办?(包含2个步行和1个公交以上的情况)
比如结果描述为:“乘坐地铁1号线,经过1站,到达东单,乘坐地铁5号线,经过1站,到达灯市口,步行约200米,到达灯市东口,乘坐110,经过5站,到达神路街,步行约240米,到达终点”
得到步行的段数是4,那么有“有3个公交段,4个步行段”。如下所示:
起点
步行:0米(起点到1号线)
公交:乘坐地铁1号线,经过1站,到达东单
步行:0米(地铁换乘,距离为0)
公交:乘坐地铁5号线,经过1站,到达灯市口
步行:200米
公交:乘坐110,经过5站,到达神路街
步行:240米
终点
【百度地图API】如何制作自定义样式的公交导航结果面板?的更多相关文章
- 【百度地图API】如何自定义地图图层?实例:制作麻点图(自定义图层+热区)
原文:[百度地图API]如何自定义地图图层?实例:制作麻点图(自定义图层+热区) 摘要:自定义地图图层的用途十分广泛.常见的应用,比如制作魔兽地图和清华校园地图(使用切图工具即可轻松实现).今天我们来 ...
- 百度地图API如何给自定义覆盖物添加事件
摘要: 给marker.lable.circle等Overlay添加事件很简单,直接addEventListener即可.那么,自定义覆盖物的事件应该如何添加呢?我们一起来看一看~ --------- ...
- 百度地图api之如何自定义标注图标
在百度地图api中,默认的地图图标是一个红色的椭圆形.但是在项目中常常要求我们建立自己的图标,类似于我的这个 操作很简单,分如下几步进行 步骤一:先ps一个图标,大小要合适,如果要背景透明的,记得保存 ...
- 百度地图api窗口信息自定义
百度地图加载完后,完全可以用dom方法操作,比较常用的就是点击mark的弹窗,利用jQuery可以很快的创建弹窗,需要注意的就是地图都是异步加载,所以绑定时间要用 jQuery 事件 - delega ...
- 百度地图API 海量点 自定义添加信息
<!--添加百度地图--> <script type="text/javascript" src="http://api.map.baidu.com/a ...
- 【百度地图API】制作多途经点的线路导航——路线坐标规划
一.创建地图 首先要告诉大家的是,API1.2版本取消密钥,取消服务设置,大家可以采用更加简短的方式引用API的JS啦~ <script type="text/javascript&q ...
- 百度地图API和高德地图API资料集锦
[高德地图API]从零开始学高德JS API(五)路线规划——驾车|公交|步行 [高德地图API]从零开始学高德JS API(四)搜索服务——POI搜索|自动完成|输入提示|行政区域|交叉路口|自 ...
- [工具向]__申请,下载,使用百度地图api
前言 api即应用程序接口,在我们的日常开发中,我们不仅可以在开源代码仓库(,github,码云)中获得很大的帮助,在日常开发中占重要地位的另一个东西就是api,我们可以使用众多的第三方编写的优秀的a ...
- 【百度地图API】——如何用label制作简易的房产标签
原文:[百度地图API]--如何用label制作简易的房产标签 摘要: 最近,API爱好者们纷纷说,自定义marker太复杂了!不仅定义复杂,连所有的dom事件都要自己重新定义.有没有快速简易创建房产 ...
随机推荐
- OpenStack路: OpenStack建筑设计指南 - 概要(摘录和翻译)
OpenStack它是在云技术领先的黄金工艺,作为一个组织,使各类企业,具有较大的灵活性和速度被发现,向市场推出自助服务云计算和基础架构即服务(IaaS)积.然,为了能够真正享受到这些好处,云计算必须 ...
- WINDOWS7,8和os x yosemite 10.10.1懒人版双系统安装教程
安装过程 磁盘划分 懒人版如果不是整盘单系统或者双硬盘双系统安装我们需要在当前系统磁盘划分两块磁盘空间,一个用来做安装盘,一个作为系统盘. 我这里是单硬盘,想从最后一个盘符压缩出80GB的空来安装黑苹 ...
- [原创].NET 分布式架构开发实战之四 构建从理想和实现之间的桥梁(前篇)
原文:[原创].NET 分布式架构开发实战之四 构建从理想和实现之间的桥梁(前篇) .NET 分布式架构开发实战之四 构建从理想和实现之间的桥梁(前篇) 前言:上一篇文章讲述了一些实现DAL的理论,本 ...
- C/C++数据对齐汇总
C/C++数据对齐汇总 这里用两句话总结数据对齐的原则: (1)对于n字节的元素(n=2,4,8,...),它的首地址能被n整除,才干获得最好的性能: (2)如果len为结构体中长度最长的变量,s ...
- App如何选择移动广告平台,开发者2 - 移动变现模式分析
开发人员社区的上述分析.它可能无法覆盖全部,但是,每一个开发者都需要根据自己的特点变现模式选择.继App流动性模式做了全面的分析. 游戏.广告.电商是互联网的三种变现模式,移植到移动互联网也相同适用. ...
- java使用Base64编码和解码的图像文件
1.编码和解码下面的代码示例看: import java.awt.image.BufferedImage; import java.io.ByteArrayOutputStream; import j ...
- MEF初体验之五:Lazy Exports
在一个部件组合中,导入将触发一个部件或者多个部件的实例化,这些部件暴露了所需原请求部件的必要的导入.对于一些应用程序来说,延迟实例化-防止图结构下的递归组合-可能对于将创建一个长久复杂的开销很大而不必 ...
- JNDI-j2ee
Database Connection Pool (DBCP) Configurations The default database connection pool implementation i ...
- 国外流行的共享网站实现:facebook,twitter,google+1,tumblr等待
近期需要做相关的国外几个站点共享,本来我以为它会和weibo.在同样的烦恼空间,什么appkey啦,apptoken啦.api啦.结果非常意外的发现并非如此恼火. Twitter分享: https:/ ...
- ubuntu安装jdk eclipse mysql等
linux ubuntu下安装java web开发环境,需要安装包: jdk7 eclipse(选择java EE developer) apche-tomcat mysql(workbench可视化 ...