驾车路径规划可以根据起终点的关键字和城市名称,获取起终点之间的驾车路线规划结果,支持返回多条不同策略的路线,每段路线包含路线长度、耗时、途径的每个路段的详细信息等。驾车路线规划还支持最多添加20个途经点。
驾车路线规划功能使用的是地图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= @"天津";bmkdrivingrouteplanoption*drivingroutesearchoption =[[bmkdrivingrouteplanoption alloc]init];drivingroutesearchoption.from= start;drivingroutesearchoption.to= end;
bool flag =[routesearch drivingsearch: drivingroutesearchoption];if(flag){nslog(@"驾车规划检索发送成功");}else{nslog(@"驾车规划检索发送失败");}
/***返回驾车搜索结果*@param searcher 搜索对象*@param result 搜索结果,类型为bmkdrivingrouteresult*@param error 错误号,@see bmksearcherrorcode*/-(void)ongetdrivingrouteresult:(bmkroutesearch*)searcher result:(bmkdrivingrouteresult*)result errorcode:(bmksearcherrorcode)error {nslog(@"ongetdrivingrouteresult error:%d",(int)error);if(error ==bmk_search_no_error){//成功获取结果}else{//检索失败}}
1.)通过代理返回的error判断检索是否成功,如果检索成功,可通过解析result字段获取具体的规划结果。bmkdrivingrouteresult类结构如下图:
说明:
bmkdrivingrouteresult | 驾车路线规划结果类 | ||
bmktaxiinfo | 打车信息类 | ||
bmksuggestaddinfo | 路线搜索地址结果类 | ||
bmkdrivingrouteline | 驾车路线类 | ||
bmkdrivingstep | 路线中的一个路段 | ||
bmkmappoint | 路段所经过的地理坐标 |
2.)如果需要在地图上展示路线规划结果,可以利用bmkpointannotation绘制起终点及线路拐点,利用bmkpolyline来绘制路线,具体使用示例可参照官方demo中的bmkdrivingroutesearchpage。
上一篇
下一篇
本篇文章对您是否有帮助?