步行路线搜索及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. [HTML Q&A][转]使pre的内容自动换行

    <pre> 元素可定义预格式化的文本.被包围在 pre 元素中的文本通常会保留空格和换行符.而文本也会呈现为等宽字体. <pre> 标签的一个常见应用就是用来表示计算机的源代码 ...

  2. Binary Tree Level Order Traversal java实现

    Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, ...

  3. 在Ubuntu下卸载Apache

    卸载Apache 转自:http://blog.csdn.net/chmo2011/article/details/7026384 1. 删除apache 代码: $ sudo apt-get --p ...

  4. codeforces 696A Lorenzo Von Matterhorn 水题

    这题一眼看就是水题,map随便计 然后我之所以发这个题解,是因为我用了log2()这个函数判断在哪一层 我只能说我真是太傻逼了,这个函数以前听人说有精度问题,还慢,为了图快用的,没想到被坑惨了,以后尽 ...

  5. HDU-4861 Couple doubi

    http://acm.hdu.edu.cn/showproblem.php?pid=4861 Couple doubi Time Limit: 2000/1000 MS (Java/Others)   ...

  6. 【原】Storm 入门教程目录

    Storm入门教程 1. Storm基础 Storm Storm主要特点 Storm基本概念 Storm调度器 Storm配置 Guaranteeing Message Processing(消息处理 ...

  7. Camera图片特效处理综述(Bitmap的Pixels处理、Canvas/paint的drawBitmap处理、旋转图片、裁截图片、播放幻灯片浏览图片<线程固定时间显示一张>)

    一种是直接对Bitmap的像素进行操作,如:叠加.边框.怀旧.(高斯)模糊.锐化(拉普拉斯变换). Bitmap.getPixels(srcPixels, 0, width, 0, 0, width, ...

  8. 第二百五十三、四、五天 how can I 坚持

    出去玩了几天,好累啊. 周五,坐了半天车.到了西柏坡,下午撕名牌,好疯狂啊,最终还是以有人受伤为代价结束了战斗.晚上吃蛋糕.水饺,还有面条,就是我的奖品没拿到.哎.. 周六,上午滑雪,两年没滑了,都忘 ...

  9. Hadoop概念学习系列之Hadoop HA进一步深入(二十八)

    对于Hadoop里的HA,有hdfs HA和resourcemanger HA之分. 1.hdfs HA 为什么引入federation? 因为,这样能达到允许在一个集群里,有多对namenode.通 ...

  10. UVALive 7327 Digit Division (模拟)

    Digit Division 题目链接: http://acm.hust.edu.cn/vjudge/contest/127407#problem/D Description We are given ...