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,就须要 ...
随机推荐
- [HTML Q&A][转]使pre的内容自动换行
<pre> 元素可定义预格式化的文本.被包围在 pre 元素中的文本通常会保留空格和换行符.而文本也会呈现为等宽字体. <pre> 标签的一个常见应用就是用来表示计算机的源代码 ...
- Binary Tree Level Order Traversal java实现
Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, ...
- 在Ubuntu下卸载Apache
卸载Apache 转自:http://blog.csdn.net/chmo2011/article/details/7026384 1. 删除apache 代码: $ sudo apt-get --p ...
- codeforces 696A Lorenzo Von Matterhorn 水题
这题一眼看就是水题,map随便计 然后我之所以发这个题解,是因为我用了log2()这个函数判断在哪一层 我只能说我真是太傻逼了,这个函数以前听人说有精度问题,还慢,为了图快用的,没想到被坑惨了,以后尽 ...
- HDU-4861 Couple doubi
http://acm.hdu.edu.cn/showproblem.php?pid=4861 Couple doubi Time Limit: 2000/1000 MS (Java/Others) ...
- 【原】Storm 入门教程目录
Storm入门教程 1. Storm基础 Storm Storm主要特点 Storm基本概念 Storm调度器 Storm配置 Guaranteeing Message Processing(消息处理 ...
- Camera图片特效处理综述(Bitmap的Pixels处理、Canvas/paint的drawBitmap处理、旋转图片、裁截图片、播放幻灯片浏览图片<线程固定时间显示一张>)
一种是直接对Bitmap的像素进行操作,如:叠加.边框.怀旧.(高斯)模糊.锐化(拉普拉斯变换). Bitmap.getPixels(srcPixels, 0, width, 0, 0, width, ...
- 第二百五十三、四、五天 how can I 坚持
出去玩了几天,好累啊. 周五,坐了半天车.到了西柏坡,下午撕名牌,好疯狂啊,最终还是以有人受伤为代价结束了战斗.晚上吃蛋糕.水饺,还有面条,就是我的奖品没拿到.哎.. 周六,上午滑雪,两年没滑了,都忘 ...
- Hadoop概念学习系列之Hadoop HA进一步深入(二十八)
对于Hadoop里的HA,有hdfs HA和resourcemanger HA之分. 1.hdfs HA 为什么引入federation? 因为,这样能达到允许在一个集群里,有多对namenode.通 ...
- UVALive 7327 Digit Division (模拟)
Digit Division 题目链接: http://acm.hust.edu.cn/vjudge/contest/127407#problem/D Description We are given ...