高德地图开发Android 地图SDK开发指南出行路线规划—公交出行路线规划

高德地图开发Android 地图SDK开发指南出行路线规划—公交出行路线规划

公交出行路线规划 最后更新时间: 2021年01月22日

公交路径规划可以根据起终点和公交换乘的数据,使用 BusRouteOverlay 画出公交路线图层,包括起终点和换乘点。另外也可以自定义起终点和换乘点的图标。

目前支持跨城公交路线规划,提供不同城市之间的火车换成方案。

注意:地图SDK V4.1.3版本开始,SDK不再提供 com.amap.api.maps.overlay 包下的 overlay,已在官方demo中开源。

第 1 步,初始化 RouteSearch 对象

Java

routeSearch = new RouteSearch(this);

第 2 步,设置数据回调监听器

Java

routeSearch.setRouteSearchListener(this);

第 3 步,设置搜索参数

通过 BusRouteQuery(RouteSearch.FromAndTo fromAndTo, int mode, java.lang.String city, int nightflag) 设置搜索条件。方法中的参数说明如下:

  • fromAndTo,路径的起终点;
  • mode,计算路径的模式,可选,默认为最快捷;
  • city,城市名称/城市区号/电话区号,此项不能为空;当进行跨城查询时,该参数对应起点的城市;
  • nightflag,是否计算夜班车,默认为不计算,0:不计算,1:计算,可选。

如果选择计算夜班车(nightflag=1),返回的夜班车数据将会排列在结果的前边。

如果存在地铁换乘出行,返回结果中还包括地铁的入站口和出站口信息。

如果是跨城公交出行,返回结果中包含火车信息。进行跨城公交查询时,还需调用 BusRouteQuery 的 setCityd(java.lang.String city) 方法设置终点城市。

Java

// fromAndTo包含路径规划的起点和终点,RouteSearch.BusLeaseWalk表示公交查询模式
// 第三个参数表示公交查询城市区号,第四个参数表示是否计算夜班车,0表示不计算,1表示计算
BusRouteQuery query = new BusRouteQuery(fromAndTo, RouteSearch.BusLeaseWalk, "010",0);
//query.setCityd("027");//终点城市区号

第 4 步,发送请求

使用类 RouteSearch 的 calculateBusRouteAsyn(BusRouteQuery query) 方法进行公交规划路径计算。

Java

RouteSearch.calculateBusRouteAsyn(query);//开始规划路径

第 5 步,接收数据

在 RouteSearch.OnRouteSearchListener 接口回调方法 void onBusRouteSearched(BusRouteResult busRouteResult,int rCode) 处理公交路径规划结果。

说明:

1)可以在回调中解析 result,获取驾车的路径。

2)result.getPaths()可以获取到 BusPath 列表,公交路径的详细信息可参考 BusPath 类。公交路径规划的一个路段(类 BusStep),必存在一段公交导航信息,最多包含一段步行信息。返回结果构成如下图所示:

3)返回结果成功或者失败的响应码。1000为成功,其他为失败(详细信息参见网站开发指南-实用工具-错误码对照表)

Java

public void onBusRouteSearched(BusRouteResult result, int rCode) {
  //解析result获取算路结果,可参考官方demo
}

显示效果如下:

注意事项

1、使用上述功能需要下载地图SDK,导入搜索功能的jar包。

2、地图SDK V4.1.3版本开始,SDK不再提供 com.amap.api.maps.overlay 包下的 overlay,已在官方demo中开源。