市内公交线路规划transitroute,支持城市内公交路线规划,根据起终点的关键字和城市名称,来完成市内公交线路规划。规划结果包含路线长度、耗时、途径的每个路段的详细信息等。
效果如下:
市内公交路线规划功能使用的是地图sdk的检索功能,需要在工程中导入检索功能包baidumapapi_search.framework
#import<baidumapapi_base/bmkbasecomponent.h>#import<baidumapapi_search/bmksearchcomponent.h>
bmkroutesearch*routesearch =[[bmkroutesearch alloc] init];
routesearch.delegate= self;
bmkplannode* start =[[bmkplannode alloc] init];start.name= @"天安门";start.cityname= @"北京";bmkplannode* end =[[bmkplannode alloc] init];end.name= @"清华大学";end.cityname= @"北京";bmktransitrouteplanoption*transitrouteplanoption=[[bmktransitrouteplanoption alloc]init];transitrouteplanoption.from= start;transitrouteplanoption.to= end;transitrouteplanoption.city= @"北京";//必须设置
另外,bmktransitrouteplanoption中还可以设置途经点(bmktransitpolicy),具体使用方法可以参考demo中的bmktransitroutesearchpage。
bool flag =[routesearch transitsearch: transitrouteplanoption];if(flag){nslog(@"市内公交规划检索发送成功");}else{nslog(@"市内公交规划检索发送失败");}
/**返回公交路线检索结果@param searcher 检索对象@param result 检索结果,类型为bmktransitrouteresult@param error 错误码,@see bmksearcherrorcode*/-(void)ongettransitrouteresult:(bmkroutesearch*)searcher result:(bmktransitrouteresult*)result errorcode:(bmksearcherrorcode)error {nslog(@"ongettransitrouteresult error:%d",(int)error);if(error ==bmk_search_no_error){//成功获取结果}else{//检索失败}}
1)通过代理返回的error判断检索是否成功,如果检索成功,可通过解析result字段获取具体的规划结果。bmktransitrouteresult类结构如下图:
说明:
bmktransitrouteresult | 市内公交路线规划结果类 | ||
bmksuggestaddinfo | 路线搜索地址结果类 | ||
bmktransitrouteline | 市内公交路线类 | ||
bmktransitstep | 路线中的一个路段 | ||
mkmappoint | 路段所经过的地理坐标 | ||
bmkvehicleinfo | 当路段为公交路段或地铁路段时,可以获取交通工具信息 |
2)如果需要在地图上展示路线规划结果,可以利用bmkpointannotation绘制起终点及线路拐点,利用bmkpolyline来绘制路线,具体使用示例可参照官方demo中的bmktransitroutesearchpage。
上一篇
下一篇
本篇文章对您是否有帮助?