Android学习笔记之百度地图(公交换乘路线搜索及TransitOverlay)

               


公交换乘路线搜索及TransitOverlay

       这里只提供java代码,xml代码参照: Android学习笔记之初步学百度地图

重要代码:

MKPlanNode start = new MKPlanNode();  // 起点:天安门  start.pt = new GeoPoint((int) (40.003834809598516 * 1E6),    (int) (116.3263213634491 * 1E6));   // 设置地图的中心   mapController.setCenter(start.pt);  MKPlanNode end = new MKPlanNode();  // 终点:鸟巢  end.pt = new GeoPoint((int)(39.99142 * 1E6),(int)(116.39026999999998* 1E6));  // 设置驾车路线搜索策略,时间优先、费用最少或距离最短  /*   * EBUS_TIME_FIRST   * public static final int EBUS_TIME_FIRST   * 公交检索策略常量:时间优先   * EBUS_TRANSFER_FIRST   * public static final int EBUS_TRANSFER_FIRST   * 公交检索策略常量:最少换乘   * EBUS_WALK_FIRST   * public static final int EBUS_WALK_FIRST   * 公交检索策略常量:最少步行距离   * EBUS_NO_SUBWAY   * public static final int EBUS_NO_SUBWAY   * 公交检索策略常量:不含地铁   */  // 设置乘车路线搜索策略,时间优先、最少换乘、最少步行距离或不含地铁  mKSearch.setTransitPolicy(MKSearch.EBUS_TRANSFER_FIRST);  mKSearch.transitSearch("北京", start, end); // 必须设置城市名


实现MySearchListener的onGetTransitRouteResult(MKTransitRouteResult, int),并展示检索结果:

@Overridepublic void onGetTransitRouteResult(MKTransitRouteResult result, int iError) {    if (result == null) {        return;    }    TransitOverlay transitOverlay = new TransitOverlay(MyMapActivity.this, mMapView);    // 此处仅展示一个方案作为示例    transitOverlay.setData(result.getPlan(0));    mMapView.getOverlays().add(transitOverlay);}


API:

transitSearch

public int transitSearch(java.lang.String city, MKPlanNode start, MKPlanNode end)

公交路线搜索. 

异步函数,返回结果在MKSearchListener里的onGetTransitRouteResult方法通知
参数:
city - 城市名,用于在哪个城市内进行检索
start - 检索的起点,可通过关键字,坐标两种方式指定
end - 检索的终点,可通过关键字,坐标两种方式指定
返回:
成功返回0,否则返回-1

setTransitPolicy

public int setTransitPolicy(int policy)

设置路线规划策略. 

参数为策略常量。对下次搜索有效
参数:
policy - EBUS_TIME_FIRST:时间优先;EBUS_TRANSFER_FIRST:少换乘;EBUS_WALK_FIRST:少步行;EBUS_NO_SUBWAY: 非地铁
返回:
成功返回0,否则返回-1

具体实现:

package xiaosi.baiduMap;import android.app.AlertDialog;import android.content.DialogInterface;import android.os.Bundle;import com.baidu.mapapi.BMapManager;import com.baidu.mapapi.GeoPoint;import com.baidu.mapapi.MKAddrInfo;import com.baidu.mapapi.MKDrivingRouteResult;import com.baidu.mapapi.MKPlanNode;import com.baidu.mapapi.MKPoiInfo;import com.baidu.mapapi.MKPoiResult;import com.baidu.mapapi.MKSearch;import com.baidu.mapapi.MKSearchListener;import com.baidu.mapapi.MKTransitRouteResult;import com.baidu.mapapi.MKWalkingRouteResult;import com.baidu.mapapi.MapActivity;import com.baidu.mapapi.MapController;import com.baidu.mapapi.MapView;import com.baidu.mapapi.PoiOverlay;import com.baidu.mapapi.RouteOverlay;import com.baidu.mapapi.TransitOverlay;public class BaiduMapActivity extends MapActivity/** Called when the activity is first created. */ private BMapManager mapManager = nullprivate String key = "1B79478DA01F7800AEA8602517A6D89B38151105"private MapView mapView = nullprivate MKSearch mKSearch; private MapController mapController = null@Override public void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.main);  mapManager = new BMapManager(getApplication());  mapManager.init(key, null);  super.initMapActivity(mapManager);  mapView = (MapView) findViewById(R.id.mapView);  // 设置启用内置的缩放控件  mapView.setBuiltInZoomControls(true);  // 得到mMapView的控制权,可以用它控制和驱动平移和缩放  mapController = mapView.getController();  // 设置地图zoom级别  mapController.setZoom(12);  mKSearch = new MKSearch();  // 注意,MKSearchListener只支持一个,以最后一次设置为准  mKSearch.init(mapManager, new MySearchListener());    MKPlanNode start = new MKPlanNode();  // 起点:天安门  start.pt = new GeoPoint((int) (40.003834809598516 * 1E6),    (int) (116.3263213634491 * 1E6));   // 设置地图的中心   mapController.setCenter(start.pt);  MKPlanNode end = new MKPlanNode();  // 终点:鸟巢  end.pt = new GeoPoint((int)(39.99142 * 1E6),(int)(116.39026999999998* 1E6));  // 设置驾车路线搜索策略,时间优先、费用最少或距离最短  /*   * EBUS_TIME_FIRST   * public static final int EBUS_TIME_FIRST   * 公交检索策略常量:时间优先   * EBUS_TRANSFER_FIRST   * public static final int EBUS_TRANSFER_FIRST   * 公交检索策略常量:最少换乘   * EBUS_WALK_FIRST   * public static final int EBUS_WALK_FIRST   * 公交检索策略常量:最少步行距离   * EBUS_NO_SUBWAY   * public static final int EBUS_NO_SUBWAY   * 公交检索策略常量:不含地铁   */  // 设置乘车路线搜索策略,时间优先、最少换乘、最少步行距离或不含地铁  mKSearch.setTransitPolicy(MKSearch.EBUS_TRANSFER_FIRST);  mKSearch.transitSearch("北京", start, end); // 必须设置城市名 } public class MySearchListener implements MKSearchListener {  public void onGetAddrResult(MKAddrInfo arg0, int arg1)  {   /*    * 返回地址信息搜索结果。 参数: arg0 - 搜索结果 arg1 - 错误号,0表示结果正确,result中有相关结果信息;100表示结果正确,无相关地址信息    */  }  public void onGetDrivingRouteResult(MKDrivingRouteResult arg0, int arg1)  {   /*    * 返回驾乘路线搜索结果。 参数: arg0 - 搜索结果 arg1 - 错误号,0表示正确返回    */  }  public void onGetPoiResult(MKPoiResult arg0, int arg1, int arg2)  {   /*    * 返回poi搜索结果。 参数: arg0 - 搜索结果 arg1 - 返回结果类型: MKSearch.TYPE_POI_LIST MKSearch.TYPE_AREA_POI_LIST MKSearch.TYPE_CITY_LIST arg2 - 错误号,0表示正确返回    */     }  public void onGetTransitRouteResult(MKTransitRouteResult arg0, int arg1)  {   /*    * 返回公交搜索结果。 参数: arg0 - 搜索结果 arg1 - 错误号,0表示正确返回, 当返回MKEvent.ERROR_ROUTE_ADDR时,表示起点或终点有歧义, 调用MKTransitRouteResult的getAddrResult方法获取推荐的起点或终点信息    */    if (arg0 == null) {           return;       }       TransitOverlay transitOverlay = new TransitOverlay(BaiduMapActivity.this, mapView);       // 此处仅展示一个方案作为示例       transitOverlay.setData(arg0.getPlan(0));       mapView.getOverlays().add(transitOverlay);  }  public void onGetWalkingRouteResult(MKWalkingRouteResult arg0, int arg1)  {   /*    * 返回步行路线搜索结果。 参数: arg0 - 搜索结果 arg1 - 错误号,0表示正确返回    */  } } @Override protected boolean isRouteDisplayed() {  return false; } @Override protected void onDestroy() {  if (mapManager != null)  {   mapManager.destroy();   mapManager = null;  }  super.onDestroy(); } @Override protected void onPause() {  if (mapManager != null)  {   mapManager.stop();  }  super.onPause(); } @Override protected void onResume() {  if (mapManager != null)  {   mapManager.start();  }  super.onResume(); }}



           

再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值