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

本文主要是介绍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

这篇关于Android学习笔记之百度地图(公交换乘路线搜索及TransitOverlay)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/364913

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超

C# ComboBox下拉框实现搜索方式

《C#ComboBox下拉框实现搜索方式》文章介绍了如何在加载窗口时实现一个功能,并在ComboBox下拉框中添加键盘事件以实现搜索功能,由于数据不方便公开,作者表示理解并希望得到大家的指教... 目录C# ComboBox下拉框实现搜索步骤一步骤二步骤三总结C# ComboBox下拉框实现搜索步骤一这

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。