Android 百度地图API 定位 导航 代码

简介: 前几天百度举办了百度世界大会,可惜没去参加,之前参加了百度的开发者大会,在会上也了解了百度的产品,百度现在朝着平台化的方向在发展,感觉很不错,也试用了百度的产品,现在就用着百度的网盘,今天看了下百度地图的开放API,然后做了个Demo,这里分享出来。

前几天百度举办了百度世界大会,可惜没去参加,之前参加了百度的开发者大会,在会上也了解了百度的产品,百度现在朝着平台化的方向在发展,感觉很不错,也试用了百度的产品,现在就用着百度的网盘,今天看了下百度地图的开放API,然后做了个Demo,这里分享出来。如果应用主要针对国内市场的话,用百度地图还是一个比较不错的选择。另外,百度还有一个PCS(Personal cloud storage)个人云存储,我比较感兴趣,之后也会继续研究,然后做个Demo分享给大家。今天就先看看这个利用百度地图定位并实现目的地导航的Demo。首先看实现效果:

         Android百度地图API实现定位与目的地导航                         Android百度地图API实现定位与目的地导航

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

       Android百度地图API实现定位与目的地导航

 

接下来就看如何实现了,首先,注册百度开发者账号,并进入百度地图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();
				}
			}
		}
}

然后是布局文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal" >

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="18sp"
            android:text="Destination:" />

        <EditText
            android:id="@+id/et_destination"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content" />
    </LinearLayout>
    
    <Button 
        android:id="@+id/btn_navi"
        android:layout_width="fill_parent"
           android:layout_height="wrap_content"
           android:text="Start navigate"/>

    <com.baidu.mapapi.MapView
        android:id="@+id/bmapsView"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:clickable="true" />

</LinearLayout>

AndroidMainifest.xml:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.ericssonlabs"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk android:minSdkVersion="8" />

    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission>
	<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>
	<uses-permission android:name="android.permission.INTERNET"></uses-permission>
	<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
	<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>  
	<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"></uses-permission> 
	<uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
	
	<supports-screens android:largeScreens="true"
	    android:normalScreens="true" android:smallScreens="true"
	    android:resizeable="true" android:anyDensity="true"/>
	<uses-sdk android:minSdkVersion="3"></uses-sdk>

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <activity
            android:name=".NavigationDemoActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>


目录
打赏
0
0
0
0
30
分享
相关文章
什么是用于REST API的JWT Bearer令牌以及如何通过代码和工具进行调试
在Web开发中,保护REST API至关重要,而JSON Web令牌(JWT)特别是JWT Bearer令牌,是一种高效方法。它通过紧凑、自包含的结构实现安全信息交换,提升用户体验。本文探讨JWT Bearer的基本概念、结构与实现,包括在Java中的应用步骤,以及使用Apipost和cURL进行测试的方法。JWT优势明显:无状态、互操作性强,适用于分布式系统。掌握JWT Bearer,可助开发者构建更安全、高效的API解决方案。
0代码将存量 API 适配 MCP 协议
本文主要讲述通过 Nacos+Higress 的方案实现0代码改造将 Agent 连接到存量应用,能够显著降低存量应用的改造成本。
200 36
0代码将存量 API 适配 MCP 协议
什么是用于 REST API 的 Bearer Token以及如何通过代码和工具进行调试
Bearer Token 是一种基于 OAuth 2.0 的身份验证机制,广泛应用于 REST API 的授权访问中。它通过在 HTTP 请求头中传递令牌,确保用户凭据安全传输并验证。本文深入解析了 Bearer Token 的概念、实现步骤及调试方法,包括其无状态特性、灵活性与安全性优势。同时,提供了 Java 实现示例和使用 Apipost、cURL 等工具测试的实践指导,帮助开发者掌握这一核心技能,保障 API 系统的安全与高效运行。
JavaScript中通过array.map()实现数据转换、创建派生数组、异步数据流处理、复杂API请求、DOM操作、搜索和过滤等,array.map()的使用详解(附实际应用代码)
array.map()可以用来数据转换、创建派生数组、应用函数、链式调用、异步数据流处理、复杂API请求梳理、提供DOM操作、用来搜索和过滤等,比for好用太多了,主要是写法简单,并且非常直观,并且能提升代码的可读性,也就提升了Long Term代码的可维护性。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
实战指南:通过1688开放平台API获取商品详情数据(附Python代码及避坑指南)
1688作为国内最大的B2B供应链平台,其API为企业提供合法合规的JSON数据源,直接获取批发价、SKU库存等核心数据。相比爬虫方案,官方API避免了反爬严格、数据缺失和法律风险等问题。企业接入1688商品API需完成资质认证、创建应用、签名机制解析及调用接口四步。应用场景包括智能采购系统、供应商评估模型和跨境选品分析。提供高频问题解决方案及安全合规实践,确保数据安全与合法使用。立即访问1688开放平台,解锁B2B数据宝藏!
利用 Java 代码获取淘宝关键字 API 接口
在数字化商业时代,精准把握市场动态与消费者需求是企业成功的关键。淘宝作为中国最大的电商平台之一,其海量数据中蕴含丰富的商业洞察。本文介绍如何通过Java代码高效、合规地获取淘宝关键字API接口数据,帮助商家优化产品布局、制定营销策略。主要内容包括: 1. **淘宝关键字API的价值**:洞察用户需求、优化产品标题与详情、制定营销策略。 2. **获取API接口的步骤**:注册账号、申请权限、搭建Java开发环境、编写调用代码、解析响应数据。 3. **注意事项**:遵守法律法规与平台规则,处理API调用限制。 通过这些步骤,商家可以在激烈的市场竞争中脱颖而出。
【Azure Developer】Python代码调用Graph API将外部用户添加到组,结果无效,也无错误信息
根据Graph API文档,在单个请求中将多个成员添加到组时,Python代码示例中的`members@odata.bind`被错误写为`members@odata_bind`,导致用户未成功添加。
70 10
淘宝评论API接口操作步骤详解,代码示例参考
淘宝评论API接口是淘宝开放平台提供的一项服务,通过该接口,开发者可以访问商品的用户评价和评论。这些评论通常包括评分、文字描述、图片或视频等内容。商家可以利用这些信息更好地了解消费者的需求和偏好,优化产品和服务。同时,消费者也可以从这些评论中获得准确的购买参考,做出更明智的购买决策。
|
4月前
|
【Azure Developer】分享一段Python代码调用Graph API创建用户的示例
分享一段Python代码调用Graph API创建用户的示例
84 11
|
5月前
|
API
全国行政区划代码与经纬度查询免费API接口教程
该接口提供全国各行政区划代码及经纬度查询服务。通过POST或GET请求,输入用户ID、KEY及地点名称,可获取地区代码、省份、市级、区县级名称及经纬度等信息。示例URL:https://cn.apihz.cn/api/other/xzqhdm.php?id=88888888&key=88888888&sheng=北京&place=北京。返回数据包含状态码、信息提示及查询结果。
776 14

热门文章

最新文章