安卓百度地圖(五)百度地圖路線規劃

其他文章:
安卓百度離線地圖的下載以及使用
安卓百度地圖(一)定位功能的實現、周邊POI的檢索
安卓百度地圖(二)地圖顯示以及離線地圖的下載使用
安卓百度地圖(三)繪制點、線等圖層信息
安卓百度地圖(四)城市,周邊,區域檢索
安卓百度地圖(六)鷹眼軌跡的上傳,歷史軌跡的顯示
安卓百度地圖(七)地理圍欄的建立與使用

本文就百度地圖的路線規劃功能加以收集整理

一 路線規劃簡介

百度地圖路線規劃分為步行線規劃,行車路線規劃,騎行路線規劃,公交路線規劃

二 路線規劃

2.1. 創建線路規劃檢索實例

mSearch = RoutePlanSearch.newInstance();

2.2 設置線路規劃檢索監聽者

mSearch.setOnGetRoutePlanResultListener(listener);

2.3 設置線路規劃起點、終點信息

傳入地名

PlanNode stNode = PlanNode.withCityNameAndPlaceName("北京", "西二旗地鐵站");  
PlanNode enNode = PlanNode.withCityNameAndPlaceName("北京", "百度科技園");

傳入坐標

PlanNode stNode = PlanNode.withLocation(loc_start);
PlanNode enNode = PlanNode.withLocation(loc_end);

2.4 發起線路規劃

2.4.1 發起步行線路規劃

mSearch.walkingSearch((new WalkingRoutePlanOption())  
    .from(stNode)  
    .to(enNode));

2.4.2 騎行路線規劃

通過設置騎行類型ridingType()即可實現電動車和普通自行車切換,默認為0普通騎行模式,舊版用戶使用普通自行車模式不受影響。 電動車騎行路線規劃,規避電動車禁行路段,避免罰款。 電動車騎行路線規劃傾向于走大路,方便尋路,適于快速通行。

//通過設ridingType,可以區分普通自行車,和電動車線路
ridingType(int ridingType) 
mSearch.bikingSearch((new BikingRoutePlanOption())  
    .from(stNode)  
    .to(enNode));

2.4.3 駕車線路規劃

mSearch.drivingSearch((new DrivingRoutePlanOption())  
    .from(stNode)  
    .to(enNode));

2.4.4 公交線路規劃

mSearch.transitSearch(
   new TransitRoutePlanOption()
  .from(stNode)
  .to(enNode));

關于成成公交、換乘等問題,請查看官網解析

2.5 設置線路規劃檢索監聽者;

 OnGetRoutePlanResultListener listener = new OnGetRoutePlanResultListener() {
        //獲取步行線路規劃結果
        @Override
        public void onGetWalkingRouteResult(WalkingRouteResult result) {
        }
       //獲取綜合公共交通線路規劃結果
        @Override
        public void onGetTransitRouteResult(TransitRouteResult transitRouteResult) {
        }
        //獲取**跨城**綜合公共交通線路規劃結果
        @Override
        public void onGetMassTransitRouteResult(MassTransitRouteResult massTransitRouteResult) {
        }
        //獲取駕車線路規劃結果  
        @Override
        public void onGetDrivingRouteResult(DrivingRouteResult drivingRouteResult) {
        }
        //室內路線規劃結果
        @Override
        public void onGetIndoorRouteResult(IndoorRouteResult indoorRouteResult) {
        }
        //獲取普通騎行路規劃結果  
        @Override
        public void onGetBikingRouteResult(BikingRouteResult bikingRouteResult) {
        }
    };

6 顯示線路

先下載官方提供的工具類mapapi,將內部的overlayutil包直接放入自己的java代碼中

示例駕車路線規劃示例
//繪制路線

if (drivingRouteResult == null || drivingRouteResult.error !=   SearchResult.ERRORNO.NO_ERROR) {
        Toast.makeText(MapRoadActivity.this, "抱歉,未找到結果", Toast.LENGTH_SHORT).show();
}
if (drivingRouteResult.error == SearchResult.ERRORNO.AMBIGUOUS_ROURE_ADDR) {
       // 起終點或途經點地址有岐義,通過以下接口獲取建議查詢信息
       drivingRouteResult.getSuggestAddrInfo();
        return;
}
if (drivingRouteResult.error == SearchResult.ERRORNO.NO_ERROR) {
      if (drivingRouteResult.getRouteLines().size() >= 1) {
            MyDrivingRouteOverlay overlay = new MyDrivingRouteOverlay(mBaiduMap);
            mBaiduMap.setOnMarkerClickListener(overlay);
            overlay.setData(drivingRouteResult.getRouteLines().get(0));
            overlay.addToMap();
            overlay.zoomToSpan();
        } else {
             Log.d("route result", "結果數<0");
             return;
        }
}

// 定制RouteOverly,自定義起點終點圖片

boolean useDefaultIcon = false;//使用默認ICON
private class MyDrivingRouteOverlay extends DrivingRouteOverlay {
   public MyDrivingRouteOverlay(BaiduMap baiduMap) {
      super(baiduMap);
   }
   @Override
   public BitmapDescriptor getStartMarker() {
      if (useDefaultIcon) {
          return BitmapDescriptorFactory.fromResource(R.drawable.icon_st);
      }
          return null;
      }
      @Override
      public BitmapDescriptor getTerminalMarker() {
         if (useDefaultIcon) {
             return BitmapDescriptorFactory.fromResource(R.drawable.icon_en);
         }
             return null;
      }
}

7.釋放檢索實例;

mSearch.destory();
注意:具體錯誤碼,請查看百度地圖錯誤碼

本文主要做于收集整理筆記使用,關于文章的源碼,請移步我的GitHub

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。