越寫悅快樂之Android應用如何使用百度地圖進行定位

今天的越寫悅快樂之系列文章爲大家帶來Android應用如何使用百度地圖進行定位。有過Android開發經驗的小夥伴可能知道,定位簽到功能經常出現在你的App應用中,如何使用百度地圖進行定位,將成爲我們這篇文章的主旨,當然你也可以其他地圖API構建你的定位簽到功能,下面我爲大家 分享一下如何使用百度地圖進行簡單的定位功能。

開發環境

  • Window 10.0.17763
  • Java 8.0.191
  • Android Studio 3.3.2

Gradle 版本

distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-4.10.1-all.zip

Build 版本

dependencies {
    classpath "com.android.tools.build:gradle:3.2.1"
}

構建步驟

註冊百度賬號並申請成爲百度地圖開發者

沒什麼可叨叨的,我相信你肯定能搞定

獲取服務祕鑰

1 未認證的開發者有調用頻次的限制;
2 若是獲得更穩定和可靠的開放服務,請根據具體的業務需求選擇合適的商用授權;

還記得上一篇文章中我們獲取的證書指紋嗎?我們要在測試環境或者生成環境驗證定位功能則需要證書的相關信息才能使用定位服務(請看上圖中的發佈版SHA1和開發版SHA1)。

包名填寫你的應用的AndroidManifest.xml文件中package的值。

使用定位服務

添加百度地圖定位SDK

  • 下載並解壓定位SDK
  • 複製文件.jar + .so文件到app模塊的libs目錄下
  • 更新配置文件(app/build.gradle
android {
    sourceSets {
        main {
            jniLibs.srcDir 'libs'
        }
    }
}
  • 添加AK(AndroidManifest.xml文件中的application標籤裏)
<meta-data
    android:name="com.baidu.lbsapi.API_KEY"
    android:value="AK" >
</meta-data>
  • 添加訪問權限(AndroidManifest.xml文件中的uses-permission標籤)

書寫定位代碼

參考官方的示例代碼和官方文檔,我們可以梳理一下使用定位服務的步驟:

  • 添加地圖佈局
  • 獲取地圖對象
  • 獲取定位客戶端對象
  • 設置定位選項
  • 註冊定位監聽器
  • 爲定位客戶端設置監聽

下面給出示例代碼,僅供參考。

 private void initMap() {
        mBaiDuMap = mMapView.getMap();
        // 設置地圖類型
        mBaiDuMap.setMapType(BaiduMap.MAP_TYPE_NORMAL);
        // 獲取定位客戶端
        mLocationClient = new LocationClient(this);
        initLocationOption();
        // 註冊LocationListener監聽器
        myListener = new MyLocationListener();
        mLocationClient.registerLocationListener(myListener);
    }

    private void initLocationOption() {
        LocationClientOption option = new LocationClientOption();
        // 設置定位模式
        option.setLocationMode(LocationClientOption.LocationMode.Hight_Accuracy
        );
        // 定位結果座標系
        option.setCoorType("bd09ll");
        int span = 1000;
        // 設置發起連續定位請求的時間間隔
        option.setScanSpan(span);
        // 設置是否需要地址信息
        option.setIsNeedAddress(true);
        // 設置是否開啓Gps定位
        option.setOpenGps(true);
        // 設置是否收集CRASH信息
        option.SetIgnoreCacheException(true);
        // 設置是否需要位置語義化結果
        option.setIsNeedLocationDescribe(true);
        // 設置是否需要POI結果
        option.setIsNeedLocationPoiList(true);
        mLocationClient.setLocOption(option);
    }

    public class MyLocationListener extends BDAbstractLocationListener {

        @Override
        public void onReceiveLocation(BDLocation location) {
            if (location == null || mMapView == null) {
                return;
            }
            LatLng latLng;
            // 構造定位數據
            MyLocationData locData = new MyLocationData.Builder()
                    .accuracy(location.getRadius())
                    .direction(100).latitude(location.getLatitude())
                    .longitude(location.getLongitude()).build();
            // 設置定位數據
            mBaiDuMap.setMyLocationData(locData);
            if (isFirstLoc) {
                isFirstLoc = false;
                latLng = new LatLng(location.getLatitude(),
                        location.getLongitude());
                MapStatus.Builder builder = new MapStatus.Builder();
                builder.target(latLng).zoom(15.0f);
                mBaiDuMap.animateMapStatus(MapStatusUpdateFactory.newMapStatus(builder.build()));
                viewModel.longitude.set(String.valueOf(location.getLongitude()));
                viewModel.latitude.set(String.valueOf(location.getLatitude()));
                viewModel.address.set(location.getAddrStr());
                switch (location.getLocType()) {
                    case BDLocation.TypeGpsLocation:
                        // GPS 定位結果
                        ToastUtils.showShort(location.getAddrStr());
                        break;
                    case BDLocation.TypeNetWorkLocation:
                        // 網絡定位結果
                        ToastUtils.showShort(location.getAddrStr());
                        break;
                    case BDLocation.TypeOffLineLocation:
                        // 離線定位結果
                        ToastUtils.showShort(location.getAddrStr());
                        break;
                    case BDLocation.TypeServerError:
                        ToastUtils.showShort("服務器錯誤,請檢查");
                        break;
                    case BDLocation.TypeNetWorkException:
                        ToastUtils.showShort("網絡錯誤,請檢查網絡");
                        break;
                    case BDLocation.TypeCriteriaException:
                        ToastUtils.showShort("手機模式錯誤,請檢查是否飛行");
                        break;
                }
            }
        }
    }

    @Override
    public void onStart() {
        super.onStart();
        mBaiDuMap.setMyLocationEnabled(true);
        if (!mLocationClient.isStarted()) {
            mLocationClient.start();
        }
    }

    @Override
    public void onStop() {
        super.onStop();
        mBaiDuMap.setMyLocationEnabled(false);
        mLocationClient.stop();
    }

    @Override
    public void onResume() {
        super.onResume();
        mMapView.onResume();
    }

    @Override
    public void onPause() {
        super.onPause();
        mMapView.onPause();
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
        mMapView.onDestroy();
    }

驗證定位功能

我們從百度地圖控制檯設置我們的開發版SHA1,保存完成後即可啓動應用,在模擬器或者Android設備驗證我們的定位功能,若是在定位過程中出現錯誤信息,可以參考官方文檔中關於服務錯誤的描述,進一步定位錯誤並修復問題。

參考

個人收穫

定位功能算是一個應用的基礎功能,也是利用位置數據提供更多的服務給客戶,當然這裏也要注意不同Android版本對定位權限的不同處理機制,有時候需要動態申請權限,在用戶同意獲取定位權限後獲取用戶的定位數據,涉及到用戶隱私問題我們需要從多方面保護用戶的個人數據,避免這些敏感數據被用於非法用途,給用戶帶來不可挽回的損失,因此從Android應用的安全角度和用戶的隱私進去考量一個應用的質量,才能更好地服務於用戶,讓我們的應用助力用戶,成就用戶,爲用戶創造價值,希望我的文章對你有所啓發,接下來我繼續大家分享Android開發的那些事兒。若是我的文章對你有所啓發,那將是我莫大的榮幸。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章