步行路线搜索及RouteOverlay

方式与驾车路线搜索类似,只需将mMKSearch.drivingSearch(null, start, null, end)修改为mMKSearch.walkingSearch(null, start, null, end),实现的方法改为onGetWalkingRouteResult即可,不再赘述。

驾车路线搜索及RouteOverlay

重要代码:

[java] 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)); 
        // 设置驾车路线搜索策略,时间优先、费用最少或距离最短  
        /*
         * ECAR_DIS_FIRST
         * public static final int ECAR_DIS_FIRST
         * 驾乘检索策略常量:最短距离
         * ECAR_FEE_FIRST
         * public static final int ECAR_FEE_FIRST
         * 驾乘检索策略常量:较少费用
         */ 
        //设置驾车路线规划策略.  
        mKSearch.setDrivingPolicy(MKSearch.ECAR_TIME_FIRST); 
        //驾乘路线搜索.  
        mKSearch.drivingSearch("北京", start, "北京", end); 
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));
  // 设置驾车路线搜索策略,时间优先、费用最少或距离最短
  /*
   * ECAR_DIS_FIRST
   * public static final int ECAR_DIS_FIRST
   * 驾乘检索策略常量:最短距离
   * ECAR_FEE_FIRST
   * public static final int ECAR_FEE_FIRST
   * 驾乘检索策略常量:较少费用
   */
  //设置驾车路线规划策略.
  mKSearch.setDrivingPolicy(MKSearch.ECAR_TIME_FIRST);
  //驾乘路线搜索.
  mKSearch.drivingSearch("北京", start, "北京", end);

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

[java] public void onGetDrivingRouteResult(MKDrivingRouteResult arg0, int arg1) 
        { 
            /*
             * 返回驾乘路线搜索结果。 参数: arg0 - 搜索结果 arg1 - 错误号,0表示正确返回
             */ 
            if (arg0 == null) 
            { 
                return; 
            } 
            RouteOverlay routeOverlay = new RouteOverlay(BaiduMapActivity.this, 
                    mapView); 
            // 此处仅展示一个方案作为示例  
            routeOverlay.setData(arg0.getPlan(0).getRoute(0)); 
            mapView.getOverlays().add(routeOverlay); 
        } 
public void onGetDrivingRouteResult(MKDrivingRouteResult arg0, int arg1)
  {
   /*
    * 返回驾乘路线搜索结果。 参数: arg0 - 搜索结果 arg1 - 错误号,0表示正确返回
    */
   if (arg0 == null)
   {
    return;
   }
   RouteOverlay routeOverlay = new RouteOverlay(BaiduMapActivity.this,
     mapView);
   // 此处仅展示一个方案作为示例
   routeOverlay.setData(arg0.getPlan(0).getRoute(0));
   mapView.getOverlays().add(routeOverlay);
  }

API:

drivingSearch

public int drivingSearch(java.lang.String startCity, MKPlanNode start, java.lang.String endCity, MKPlanNode end)

驾乘路线搜索.

异步函数,返回结果在MKSearchListener里的onGetDrivingRouteResult方法通知
参数:
startCity - 起点所在城市,起点为坐标时可不填
start - 搜索的起点,可以为坐标,名称任一种
endCity - 终点所在城市,终点为坐标可不填
end - 搜索的终点,可以为坐标,名称任一种
返回:
成功返回0,否则返回-1

setDrivingPolicy

public int setDrivingPolicy(int policy)

设置驾车路线规划策略. 参数为策略常量。对下次搜索有效
参数:
policy - ECAR_TIME_FIRST:时间优先;ECAR_DIS_FIRST:距离最短;ECAR_FEE_FIRST:费用最少
返回:
成功返回0,否则返回-1

具体实现:

注意:在模拟器上模拟不能显示乘车线路,不知道是我的问题,还是模拟器的问题。但在真机上能体现出路线。www.2cto.com

[java] 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; 
 
public class BaiduMapActivity extends MapActivity 

    /** Called when the activity is first created. */ 
    private BMapManager mapManager = null; 
    private String key = "1B79478DA01F7800AEA8602517A6D89B38151105"; 
    private MapView mapView = null; 
    private 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)); 
        // 设置驾车路线搜索策略,时间优先、费用最少或距离最短  
        /*
         * ECAR_DIS_FIRST
         * public static final int ECAR_DIS_FIRST
         * 驾乘检索策略常量:最短距离
         * ECAR_FEE_FIRST
         * public static final int ECAR_FEE_FIRST
         * 驾乘检索策略常量:较少费用
         */ 
        //设置驾车路线规划策略.  
        mKSearch.setDrivingPolicy(MKSearch.ECAR_TIME_FIRST); 
        //驾乘路线搜索.  
        mKSearch.drivingSearch("北京", 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表示正确返回
             */ 
            if (arg0 == null) 
            { 
                return; 
            } 
            RouteOverlay routeOverlay = new RouteOverlay(BaiduMapActivity.this, 
                    mapView); 
            // 此处仅展示一个方案作为示例  
            routeOverlay.setData(arg0.getPlan(0).getRoute(0)); 
            mapView.getOverlays().add(routeOverlay); 
        } 
 
        public void onGetPoiResult(MKPoiResult arg0, int arg1, int arg2) 
        { 
            String result = ""; 
            /*
             * 返回poi搜索结果。 参数: arg0 - 搜索结果 arg1 - 返回结果类型: MKSearch.TYPE_POI_LIST MKSearch.TYPE_AREA_POI_LIST MKSearch.TYPE_CITY_LIST arg2 - 错误号,0表示正确返回
             */ 
            if (arg0 == null) 
            { 
                return; 
            } 
            // 清除地图上已有的所有覆盖物  
            // mapView.getOverlays().clear();  
            // PoiOverlay是baidu map api提供的用于显示POI的Overlay  
            PoiOverlay poioverlay = new PoiOverlay(BaiduMapActivity.this, 
                    mapView); 
            // 在地图上显示PoiOverlay(将搜索到的兴趣点标注在地图上)  
            poioverlay.setData(arg0.getAllPoi()); 
            // 为地图添加覆盖物  
            mapView.getOverlays().add(poioverlay); 
            // 刚开始忘记加这几句代码,地图一直没改变,纠结了很长时间  
            if (arg0.getNumPois() > 0) 
            { 
                // 设置其中一个搜索结果所在地理坐标为地图的中心  
                MKPoiInfo poiInfo = arg0.getPoi(0); 
                mapController.setCenter(poiInfo.pt); 
            } 
            // 遍历当前页返回的搜索结果(默认只返回10个)  
            for (MKPoiInfo poiInfo : arg0.getAllPoi()) 
            { 
                result = result + "\n" + "名称:" + poiInfo.name + "\n" + "地址:" 
                        + poiInfo.address + "\n" + "城市:" + poiInfo.city; 
            } 
            // 用AlertDialog来显示搜索到的内容  
            AlertDialog.Builder builder = new AlertDialog.Builder( 
                    BaiduMapActivity.this); 
            builder.setTitle("搜索结果"); 
            builder.setMessage(result); 
            builder.setPositiveButton("关闭", 
                    new android.content.DialogInterface.OnClickListener() { 
                        public void onClick(DialogInterface dialog, int which) 
                        { 
                            dialog.dismiss(); 
                        } 
                    }); 
            builder.show(); 
        } 
 
        public void onGetTransitRouteResult(MKTransitRouteResult arg0, int arg1) 
        { 
            /*
             * 返回公交搜索结果。 参数: arg0 - 搜索结果 arg1 - 错误号,0表示正确返回, 当返回MKEvent.ERROR_ROUTE_ADDR时,表示起点或终点有歧义, 调用MKTransitRouteResult的getAddrResult方法获取推荐的起点或终点信息
             */ 
        } 
 
        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(); 
    } 
}

Android学习笔记之百度地图的更多相关文章

  1. [android学习]__使用百度地图开放api编写地图定位app

    前言 在前面我已经记录关于如何使用百度地图api,以及如何配置相关的androidstudio配置了,接下来将记录如何使用百度地图api开发简单的地图定位apk,我将决定不定期持续更新本篇笔记,在每个 ...

  2. Android学习笔记----ArcGIS在线地图服务(Android API)坐标纠偏

    仅限于如下ArcGIS在线地图服务(高德提供数据): //概述:彩色中文含兴趣点版中国基础地图 //投影:WGS 1984 Web-Mercator //切片格式:MIXED90 //服务类型:基础地 ...

  3. 【转】Pro Android学习笔记(十四):用户界面和控制(2):Text类控制

    目录(?)[-] TextView 例子1在XML中设置autoLink属性 例子2在代码中设置autoLink属性 EditText AutoCompleteTextView MultiAutoCo ...

  4. udacity android 学习笔记: lesson 4 part a

    udacity android 学习笔记: lesson 4 part a 作者:干货店打杂的 /titer1 /Archimedes 出处:https://code.csdn.net/titer1 ...

  5. Android 学习笔记之Volley(七)实现Json数据加载和解析...

    学习内容: 1.使用Volley实现异步加载Json数据...   Volley的第二大请求就是通过发送请求异步实现Json数据信息的加载,加载Json数据有两种方式,一种是通过获取Json对象,然后 ...

  6. Android学习笔记进阶之在图片上涂鸦(能清屏)

    Android学习笔记进阶之在图片上涂鸦(能清屏) 2013-11-19 10:52 117人阅读 评论(0) 收藏 举报 HandWritingActivity.java package xiaos ...

  7. android学习笔记36——使用原始XML文件

    XML文件 android中使用XML文件,需要开发者手动创建res/xml文件夹. 实例如下: book.xml==> <?xml version="1.0" enc ...

  8. Android学习笔记之JSON数据解析

    转载:Android学习笔记44:JSON数据解析 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,为Web应用开发提供了一种 ...

  9. Android应用中使用百度地图API并加入标注(一)

    网上一些资料这样的的内容已经过时了,这里是最新的内容,假设哪里不正确,请吐槽... 1)下载百度地图移动版API(Android)开发包       要在Android应用中使用百度地图API,就须要 ...

随机推荐

  1. 基于Spring AOP实现对外接口的耗时监控

    AOP是Spring的核心,Spring不但自身对多种框架的集成是基于AOP,并且以非常方便的形式暴露给普通使用者.以前用AOP不多,主要是因为它以横截面的方式插入到主流程中,担心导致主流程代码不够清 ...

  2. Android之APK文件签名——keytool和jarsigner

    一.生成密钥库将位置定位在jdk的bin文件中,输入以下命名行:keytool -genkey -alias ChangeBackgroundWidget.keystore -keyalg RSA - ...

  3. 分布式发布订阅消息系统 Kafka 架构设计

    我们为什么要搭建该系统 Kafka是一个分布式.分区的.多副本的.多订阅者的“提交”日志系统. 我们构建这个系统是因为我们认为,一个实现完好的操作日志系统是一个最基本的基础设施,它可以替代一些系统来作 ...

  4. 《Python CookBook2》 第一章 文本 - 替换字符串中的子串

    替换字符串中的子串 任务: 给定一个字符串,通过查询一个字符串替换字典,将字符串中被标记的子字符串替换掉. 解决方案: >>> import string >>> ...

  5. 带宽计算-大B与小b的区别

    原文来自:http://blog.sina.com.cn/s/blog_4b9c0e3601008yf9.html 在计算机网络.IDC机房中,其宽带速率的单位用bps(或b/s)表示:换算关系为:1 ...

  6. Asmack离线消息时间获取

    DelayInformation info = (DelayInformation)message.getExtension("x","jabber:x:delay&qu ...

  7. MingW编译virt-viewer

    在http://www.spice-space.org/download.html可以下载到windows版本的virt viewer virt-viewer-x86-0.5.7.msi和virt-v ...

  8. vector 之 find 重载

    众所周知,map有find,但vector的find只能调用algorithm中的find通用方法. 参考<How to find an item in a std::vector?> 对 ...

  9. (转)UML用例图总结

    用例图主要用来描述“用户.需求.系统功能单元”之间的关系.它展示了一个外部用户能够观察到的系统功能模型图. [用途]:帮助开发团队以一种可视化的方式理解系统的功能需求. 用例图所包含的元素如下: 1. ...

  10. UVaLive 7371 Triangle (水题,判矩形)

    题意:给定两个三角形,问你能不能拼成矩形. 析:很明显,要想是矩形,必须是四个角是直角,那么三角形必须是直角三角形,然后就是只能斜边相对,然后呢?就没了. 代码如下: #pragma comment( ...