Android学习笔记之百度地图
步行路线搜索及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学习笔记之百度地图的更多相关文章
- [android学习]__使用百度地图开放api编写地图定位app
前言 在前面我已经记录关于如何使用百度地图api,以及如何配置相关的androidstudio配置了,接下来将记录如何使用百度地图api开发简单的地图定位apk,我将决定不定期持续更新本篇笔记,在每个 ...
- Android学习笔记----ArcGIS在线地图服务(Android API)坐标纠偏
仅限于如下ArcGIS在线地图服务(高德提供数据): //概述:彩色中文含兴趣点版中国基础地图 //投影:WGS 1984 Web-Mercator //切片格式:MIXED90 //服务类型:基础地 ...
- 【转】Pro Android学习笔记(十四):用户界面和控制(2):Text类控制
目录(?)[-] TextView 例子1在XML中设置autoLink属性 例子2在代码中设置autoLink属性 EditText AutoCompleteTextView MultiAutoCo ...
- udacity android 学习笔记: lesson 4 part a
udacity android 学习笔记: lesson 4 part a 作者:干货店打杂的 /titer1 /Archimedes 出处:https://code.csdn.net/titer1 ...
- Android 学习笔记之Volley(七)实现Json数据加载和解析...
学习内容: 1.使用Volley实现异步加载Json数据... Volley的第二大请求就是通过发送请求异步实现Json数据信息的加载,加载Json数据有两种方式,一种是通过获取Json对象,然后 ...
- Android学习笔记进阶之在图片上涂鸦(能清屏)
Android学习笔记进阶之在图片上涂鸦(能清屏) 2013-11-19 10:52 117人阅读 评论(0) 收藏 举报 HandWritingActivity.java package xiaos ...
- android学习笔记36——使用原始XML文件
XML文件 android中使用XML文件,需要开发者手动创建res/xml文件夹. 实例如下: book.xml==> <?xml version="1.0" enc ...
- Android学习笔记之JSON数据解析
转载:Android学习笔记44:JSON数据解析 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,为Web应用开发提供了一种 ...
- Android应用中使用百度地图API并加入标注(一)
网上一些资料这样的的内容已经过时了,这里是最新的内容,假设哪里不正确,请吐槽... 1)下载百度地图移动版API(Android)开发包 要在Android应用中使用百度地图API,就须要 ...
随机推荐
- hadoop2.20.0集群安装教程
一.安装的需要软件及集群描述 1.软件: Vmware9.0:虚拟机 Hadoop2.2.0:Apache官网原版稳定版本 JDK1.7.0_07:Oracle官网版本 Ubuntu12.04LTS: ...
- poj 1505 Copying Books
http://poj.org/problem?id=1505 Copying Books Time Limit: 3000MS Memory Limit: 10000K Total Submiss ...
- IOS AVAUDIOPLAYER 播放器使用
1. 导入 AVFoundation.framework 2.导入头文件 #import <AVFoundation/AVFoundation.h> 3. player = [[AVAu ...
- Rust 中的继承与代码复用
在学习Rust过程中突然想到怎么实现继承,特别是用于代码复用的继承,于是在网上查了查,发现不是那么简单的. C++的继承 首先看看c++中是如何做的. 例如要做一个场景结点的Node类和一个Sprit ...
- 时间,闰秒,及NTP
1.时间 格林尼治时间 GMT,以地球自转为准的时间,也叫世界时UT,但是由于自转速度会变化,所以后来不被作为标准. 世界协调时UTC,以原子钟为准,现在时间校准的标准就是原子钟. 2.闰秒 是指地球 ...
- 单词计数WordCountApp.class
public class WordCountApp { // 可以指定目录,目录下如果有二级目录的话,是不会执行的,只会执行一级目录. private static final String INPU ...
- CORBA
公共对象请求代理体系结构(Common Object Request Broker Architecture)
- Junit。。。
keep the bar green to keep the code clean.
- AHOI2013 Round2 Day2 简要题解
第一题: 第一问可以用划分树或主席树在O(nlog2n)内做出来. 第二问可以用树状数组套主席树在O(nlog2n)内做出来. 我的代码太挫了,空间刚刚卡过...(在bzoj上) 第二题: 分治,将询 ...
- webSocket vnc rfb