Android學習——百度地圖開發定位與顯示Demo
阿新 • • 發佈:2019-01-28
百度地圖給我們提供了非常豐富的API供我們進行二次開發。百度地圖的SDK與定位SDK在今年6月份進行了更新。地圖更新為3.0,定位更新為4.2。百度說:這次更新對介面有了較大部分的調整,與之前版本不相容。本篇博文基於以上最新版本的API提供一個小例子:獲取自己當前的經緯度座標,並且顯示在地圖上。這裡只給出核心程式碼,其他KEY的引入,地圖控制元件的新增,許可權的宣告,定位服務的宣告可在百度地圖API官網(http://developer.baidu.com/map/sdkandev-download.htm)進行檢視,稍候會附上完整例子的下載連結。
程式碼中的註釋已經比較詳細了,這裡就不做說明,參考官網很容易理解。
package org.zsl.android.map; import android.app.Activity; import android.os.Bundle; import android.util.Log; import com.baidu.location.BDLocation; import com.baidu.location.BDLocationListener; import com.baidu.location.LocationClient; import com.baidu.location.LocationClientOption; import com.baidu.mapapi.SDKInitializer; import com.baidu.mapapi.map.BaiduMap; import com.baidu.mapapi.map.BitmapDescriptor; import com.baidu.mapapi.map.MapStatusUpdate; import com.baidu.mapapi.map.MapStatusUpdateFactory; import com.baidu.mapapi.map.MapView; import com.baidu.mapapi.map.MyLocationData; import com.baidu.mapapi.model.LatLng; public class MainActivity extends Activity { public MapView mapView = null; public BaiduMap baiduMap = null; // 定位相關宣告 public LocationClient locationClient = null; //自定義圖示 BitmapDescriptor mCurrentMarker = null; boolean isFirstLoc = true;// 是否首次定位 public BDLocationListener myListener = new BDLocationListener() { @Override public void onReceiveLocation(BDLocation location) { // map view 銷燬後不在處理新接收的位置 if (location == null || mapView == null) return; MyLocationData locData = new MyLocationData.Builder() .accuracy(location.getRadius()) // 此處設定開發者獲取到的方向資訊,順時針0-360 .direction(100).latitude(location.getLatitude()) .longitude(location.getLongitude()).build(); baiduMap.setMyLocationData(locData); //設定定位資料 if (isFirstLoc) { isFirstLoc = false; LatLng ll = new LatLng(location.getLatitude(), location.getLongitude()); MapStatusUpdate u = MapStatusUpdateFactory.newLatLngZoom(ll, 16); //設定地圖中心點以及縮放級別 // MapStatusUpdate u = MapStatusUpdateFactory.newLatLng(ll); baiduMap.animateMapStatus(u); } } }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // 在使用SDK各元件之前初始化context資訊,傳入ApplicationContext // 注意該方法要再setContentView方法之前實現 SDKInitializer.initialize(getApplicationContext()); setContentView(R.layout.main_activity); mapView = (MapView) this.findViewById(R.id.mapView); // 獲取地圖控制元件引用 baiduMap = mapView.getMap(); //開啟定點陣圖層 baiduMap.setMyLocationEnabled(true); locationClient = new LocationClient(getApplicationContext()); // 例項化LocationClient類 locationClient.registerLocationListener(myListener); // 註冊監聽函式 this.setLocationOption(); //設定定位引數 locationClient.start(); // 開始定位 // baiduMap.setMapType(BaiduMap.MAP_TYPE_NORMAL); // 設定為一般地圖 // baiduMap.setMapType(BaiduMap.MAP_TYPE_SATELLITE); //設定為衛星地圖 // baiduMap.setTrafficEnabled(true); //開啟交通圖 } // 三個狀態實現地圖生命週期管理 @Override protected void onDestroy() { //退出時銷燬定位 locationClient.stop(); baiduMap.setMyLocationEnabled(false); // TODO Auto-generated method stub super.onDestroy(); mapView.onDestroy(); mapView = null; } @Override protected void onResume() { // TODO Auto-generated method stub super.onResume(); mapView.onResume(); } @Override protected void onPause() { // TODO Auto-generated method stub super.onPause(); mapView.onPause(); } /** * 設定定位引數 */ private void setLocationOption() { LocationClientOption option = new LocationClientOption(); option.setOpenGps(true); // 開啟GPS option.setLocationMode(LocationClientOption.LocationMode.Hight_Accuracy);// 設定定位模式 option.setCoorType("bd09ll"); // 返回的定位結果是百度經緯度,預設值gcj02 option.setScanSpan(5000); // 設定發起定位請求的間隔時間為5000ms option.setIsNeedAddress(true); // 返回的定位結果包含地址資訊 option.setNeedDeviceDirect(true); // 返回的定位結果包含手機機頭的方向 locationClient.setLocOption(option); } }
(本文地址:http://blog.csdn.net/zhshulin/article/details/37495575)