今天无意中看到技术大神利用百度地图定位并实现目的地导航的Demo。觉得很不错,就转载过来一起分享,下面我们看实现效果:

进入后首先会得到当前位置,在地图上显示出来,在输入框中输入目的地后,就会在地图上出现最佳线路,我这里设置的是距离最小的驾车线路,另外还有公交线路、步行线路,在代码中都有详细注释。另外,在控制台还输出了线路上每一个节点的信息以及起始位置和目的地的距离,信息显示的是在当前节点的导航信息。如下图:

接下来就看如何实现了,首先,注册百度开发者账号,并进入百度地图API查看相关资料百度地图API,然后就是为需要加入地图的应用注册APP KEY,注册完后,下载百度地图jar文件,新建工程,并导入即可,下面看实现具体代码,在代码中有详细注释:

public class NavigationDemoActivity extends MapActivity {

private String mMapKey = "注册自己的key";

private EditText destinationEditText = null;

private Button startNaviButton = null;

private MapView mapView = null;

private BMapManager mMapManager = null;

private MyLocationOverlay myLocationOverlay = null;

//onResume时注册此listener,onPause时需要Remove,注意此listener不是Android自带的,是百度API中的

private LocationListener locationListener;

private MKSearch searchModel;

GeoPoint pt;

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

requestWindowFeature(Window.FEATURE_NO_TITLE);

setContentView(R.layout.main);

destinationEditText = (EditText) this.findViewById(R.id.et_destination);

startNaviButton = (Button) this.findViewById(R.id.btn_navi);

mMapManager = new BMapManager(getApplication());

mMapManager.init(mMapKey, new MyGeneralListener());

super.initMapActivity(mMapManager);

mapView = (MapView) this.findViewById(R.id.bmapsView);

//设置启用内置的缩放控件

mapView.setBuiltInZoomControls(true);

//设置在缩放动画过程中也显示overlay,默认为不绘制

// mapView.setDrawOverlayWhenZooming(true);

//获取当前位置层

myLocationOverlay = new MyLocationOverlay(this, mapView);

//将当前位置的层添加到地图底层中

mapView.getOverlays().add(myLocationOverlay);

// 注册定位事件

locationListener = new LocationListener(){

@Override

public void onLocationChanged(Location location) {

if (location != null){

//生成GEO类型坐标并在地图上定位到该坐标标示的地点

pt = new GeoPoint((int)(location.getLatitude()*1e6),

(int)(location.getLongitude()*1e6));

// System.out.println("---"+location.getLatitude() +":"+location.getLongitude());

mapView.getController().animateTo(pt);

}

}

};

//初始化搜索模块

searchModel = new MKSearch();

//设置路线策略为最短距离

searchModel.setDrivingPolicy(MKSearch.ECAR_DIS_FIRST);

searchModel.init(mMapManager, new MKSearchListener() {

//获取驾车路线回调方法

@Override

public void onGetDrivingRouteResult(MKDrivingRouteResult res, int error) {

// 错误号可参考MKEvent中的定义

if (error != 0 || res == null) {

Toast.makeText(NavigationDemoActivity.this, "抱歉,未找到结果", Toast.LENGTH_SHORT).show();

return;

}

RouteOverlay routeOverlay = new RouteOverlay(NavigationDemoActivity.this, mapView);

// 此处仅展示一个方案作为示例

MKRoute route = res.getPlan(0).getRoute(0);

int distanceM = route.getDistance();

String distanceKm = String.valueOf(distanceM / 1000) +"."+String.valueOf(distanceM % 1000);

System.out.println("距离:"+distanceKm+"公里---节点数量:"+route.getNumSteps());

for (int i = 0; i < route.getNumSteps(); i++) {

MKStep step = route.getStep(i);

System.out.println("节点信息:"+step.getContent());

}

routeOverlay.setData(route);

mapView.getOverlays().clear();

mapView.getOverlays().add(routeOverlay);

mapView.invalidate();

mapView.getController().animateTo(res.getStart().pt);

}

//以下两种方式和上面的驾车方案实现方法一样

@Override

public void onGetWalkingRouteResult(MKWalkingRouteResult res, int error) {

//获取步行路线

}

@Override

public void onGetTransitRouteResult(MKTransitRouteResult arg0, int arg1) {

//获取公交线路

}

@Override

public void onGetBusDetailResult(MKBusLineResult arg0, int arg1) {

}

@Override

public void onGetAddrResult(MKAddrInfo arg0, int arg1) {

}

@Override

public void onGetSuggestionResult(MKSuggestionResult arg0, int arg1) {

}

@Override

public void onGetPoiResult(MKPoiResult arg0, int arg1, int arg2) {

}

});

startNaviButton.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

String destination = destinationEditText.getText().toString();

//设置起始地(当前位置)

MKPlanNode startNode = new MKPlanNode();

startNode.pt = pt;

//设置目的地

MKPlanNode endNode = new MKPlanNode();

endNode.name = destination;

//展开搜索的城市

String city = getResources().getString(R.string.beijing);

// System.out.println("----"+city+"---"+destination+"---"+pt);

searchModel.drivingSearch(city, startNode, city, endNode);

//步行路线

// searchModel.walkingSearch(city, startNode, city, endNode);

//公交路线

// searchModel.transitSearch(city, startNode, endNode);

}

});

}

@Override

protected void onResume() {

mMapManager.getLocationManager().requestLocationUpdates(locationListener);

myLocationOverlay.enableMyLocation();

myLocationOverlay.enableCompass(); // 打开指南针

mMapManager.start();

super.onResume();

}

@Override

protected void onPause() {

mMapManager.getLocationManager().removeUpdates(locationListener);

myLocationOverlay.disableMyLocation();//显示当前位置

myLocationOverlay.disableCompass(); // 关闭指南针

mMapManager.stop();

super.onPause();

}

@Override

protected boolean isRouteDisplayed() {

// TODO Auto-generated method stub

return false;

}

// 常用事件监听,用来处理通常的网络错误,授权验证错误等

class MyGeneralListener implements MKGeneralListener {

@Override

public void onGetNetworkState(int iError) {

Log.d("MyGeneralListener", "onGetNetworkState error is "+ iError);

Toast.makeText(NavigationDemoActivity.this, "您的网络出错啦!",

Toast.LENGTH_LONG).show();

}

@Override

public void onGetPermissionState(int iError) {

Log.d("MyGeneralListener", "onGetPermissionState error is "+ iError);

if (iError == MKEvent.ERROR_PERMISSION_DENIED) {

// 授权Key错误:

Toast.makeText(NavigationDemoActivity.this,

"请在BMapApiDemoApp.java文件输入正确的授权Key!",

Toast.LENGTH_LONG).show();

}

}

}

}

然后是布局文件:

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:orientation="vertical" >

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:orientation="horizontal" >

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:textSize="18sp"

android:text="Destination:" />

android:id="@+id/et_destination"

android:layout_width="fill_parent"

android:layout_height="wrap_content" />

android:id="@+id/btn_navi"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="Start navigate"/>

android:id="@+id/bmapsView"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:clickable="true" />

AndroidMainifest.xml

package="com.ericssonlabs"

android:versionCode="1"

android:versionName="1.0" >

android:normalScreens="true" android:smallScreens="true"

android:resizeable="true" android:anyDensity="true"/>

android:icon="@drawable/ic_launcher"

android:label="@string/app_name" >

android:name=".NavigationDemoActivity"

android:label="@string/app_name" >

上面就是实现百度地图定位和目的地的导航的所有代码啦,不知道是不是你们想要的呢?

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

android 谷歌定位demo,android实现定位与目的地的导航示例代码相关推荐

  1. android 代码 卸载app,Android在一个app中安装并卸载另一个app的示例代码

    Android在一个app中安装并卸载另一个app 1.在app→src→main下新建文件夹asserts,将准备安装的apk文件放在asserts内 2.在app→src→main→res下新建文 ...

  2. android bitmap 饱和度 demo,Android GPUImage实现多种图像滤镜效果

    前言 GPUImage 是iOS下一个开源的基于GPU的图像处理库,提供各种各样的图像处理滤镜,并且支持照相机和摄像机的实时滤镜.GPUImage for Android是它在Android下的实现, ...

  3. android 自定义progressbar demo,Android 自定义进度条ColorfulProgressbar,原理简单、效果还行...

    效果图: demo效果演示 演示Demo 特性 与原生Progress相比,感觉更漂亮一点,可以显示进度值,背景凹凸感明显,进度条效果更加立体. 原理说明 额,挺简单的.不过感觉我的做法有点复杂了,我 ...

  4. android mvvm官方demo,Android MVVM实战Demo完全解析

    最新 [重大更新说明] 感谢各位读者的阅读,这篇文章由于年代久远,存在一些错误的观点,再次向大家道歉,也做一个技术上的解释说明. 受限于当时的技术水平和网络论调,在那个时代,网上绝大多数人 都认为加了 ...

  5. android自动更新demo,Android程序自动更新功能模块的实现方法【附完整demo源码下载】...

    本文实例讲述了Android程序自动更新功能模块的实现方法.分享给大家供大家参考,具体如下: 在程序启动的时候检测服务器上有没有对应版本更新,如果有更新,提示用户是否更新. 在程序启动的时候首先调用更 ...

  6. android xml解析demo,Android解析自定义xml文件--Sax解析xml文件,测试demo(方案二)...

    转载请注明出处:http://blog.csdn.net/droyon/article/details/9346657 Sax解析xml 以下是测试Demo 运行程序类 public class Te ...

  7. android 键盘开发demo,Android自定义键盘之中文键盘demo

    [实例简介] Android自定义键盘之中文键盘demo,演示了汉字键盘的实现方法.更详细描述见相关博客. [实例截图] [核心代码] keydemo └── keydemo ├── AndroidM ...

  8. android收藏功能demo,Android使用Realm数据库实现App中的收藏功能(代码详解)

    前 言 App数据持久化功能是每个App必不可少的功能,而Android最常用的数据持久化方式主要有以下的五种方式: 使用SharedPreferences存储数据: 文件存储数据: SQLite数据 ...

  9. android 人脸识别demo,Android Camera 内置人脸识别的Demo

    CameraFace Android Camera 内置人脸识别的Demo 通过Android源生API支持的人脸识别FaceDetection,获取到脸部矩形坐标,左右眼坐标,嘴坐标通过View动态 ...

最新文章

  1. 2016 CVPR 德州仪器 ADAS Tutorial
  2. Automatic Exploit Generation:漏洞利用自动化
  3. svn错误提示: svn is scheduled for addition, but is miss
  4. element走马灯自动_详细element-ui的走马灯carousel轻松实现自适应全屏banner详细过程...
  5. 设计一个具有大纯时延时间的一阶惯性环节的计算机控制系统,具有一阶纯滞后环节设计.doc...
  6. 第三章:学生管理模块
  7. win8 附件数据库失败解决方案《1》
  8. isjavaidentifierpart和isjavaidentifierstart有区别么?
  9. 504.七进制数(力扣leetcode) 博主可答疑该问题
  10. storm中分组策略Field Grouping简单总结笔记
  11. 整数规划---指派问题
  12. 固高控制卡学习(vs2010,c++)(之一)
  13. c语言程序设计在未来前景,转型背景下C程序设计课程的实施方案
  14. 计算机综述论文能发期刊吗,计算机核心期刊哪些好发
  15. keras求两向量间的余弦值
  16. 算法-并查集-加边无向图
  17. 线程wait、join用法
  18. 培训班出来的人后来都怎么样了?(八)
  19. VSM模型与TF-IDF权重
  20. Java web文件的上传和下载、注解

热门文章

  1. 机器学习 | 特征重要性判断
  2. java long型数据做余数运算_Java数据类型与运算符
  3. 冲激函数与冲激函数相乘与冲激函数对冲激函数卷积之间的区别
  4. vue在一个方法执行完后执行另一个方法
  5. Android手机如何修改DPI触发平板模式
  6. ONVIF学习笔记11:搜索设备不匹配问题排查
  7. Excel快速填充空白单元格内容为上一行的内容
  8. UC浏览器极速版V22.3.26-艳云脚本云控系统
  9. 高效清除电脑中的灰尘。。。。社会工程学真的很管用
  10. 分库分表和 NewSQL 到底怎么选?