骑行路径规划可以根据起终点的关键字和城市名称,获取起终点之间的骑行路线规划结果,包含路线长度、耗时、途径的每个路段的详细信息等。
效果如下:
骑行路线规划功能使用的是地图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= @"北京";bmkridingrouteplanoption*ridingrouteplanoption=[[bmkridingrouteplanoption alloc]init];ridingrouteplanoption.from= start;ridingrouteplanoption.to= end;
bool flag =[routesearch ridingsearch: ridingrouteplanoption];if(flag){nslog(@"骑行规划检索发送成功");}else{nslog(@"骑行规划检索发送失败");}
/***返回骑行搜索结果*@param searcher 搜索对象*@param result 搜索结果,类型为bmkridingrouteresult*@param error 错误号,@see bmksearcherrorcode*/-(void)ongetridingrouteresult:(bmkroutesearch*)searcher result:(bmkridingrouteresult*)result errorcode:(bmksearcherrorcode)error{nslog(@"ongetridingrouteresult error:%d",(int)error);if(error ==bmk_search_no_error){//成功获取结果}else{//检索失败}}
1)通过代理返回的error判断检索是否成功,如果检索成功,可通过解析result字段获取具体的规划结果。bmkridingrouteresult类结构如下图:
说明:
bmkridingrouteresult | 骑行路线规划结果类 | ||
bmksuggestaddinfo | 路线搜索地址结果类 | ||
bmkridingrouteline | 骑行路线类 | ||
bmkridingstep | 路线中的一个路段 |
2)如果需要在地图上展示路线规划结果,可以利用bmkpointannotation绘制起终点及线路拐点,利用bmkpolyline来绘制路线,具体使用示例可参照官方demo中的bmkridingroutesearchpage。
上一篇
下一篇
本篇文章对您是否有帮助?