使用高德地圖SDK獲取定位信息

使用高德地圖SDK獲取定位信息

第一步:

  在高德官網下載SDK,如我這裏須要獲取定位信息,故僅下載「定位功能」android

第二步:

  註冊成爲開發者,並建立應用獲取相應的key。其中,在使用Android Studio在獲取SHA1時,可能出現win10的Terminal 工具沒法輸入(或輸入有問題)時,解決方法git

第三步:

  將以前下載的SDK的jar包放入相應項目的libs中;api

  在 build.gradle 文件的 dependencies 中配置 compile fileTree(include: ['*.jar'], dir: 'libs')。 緩存

dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
}

  若是仍是找不到jar包,可加入下列語句,進行編譯便可(編譯完成後也可刪除,不會出問題)。網絡

compile files('libs/umeng_social_sdk.jar')

第四步

  在application標籤中加入app

  (1)ide

<meta-data
   android:name="com.amap.api.v2.apikey"    <!--注意此處不能變,對應jar包中相應的內容-->
   android:value="**********"/>   <!--此處爲本身第二步中申請的key值-->

  (2)聲明Service組件。在application標籤中聲明service組件,每一個app擁有本身單獨的定位service工具

<service android:name="com.amap.api.location.APSService"></service>

第五步

  聲明權限gradle

<!--用於進行網絡定位-->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"></uses-permission>
<!--用於訪問GPS定位-->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>
<!--用於獲取運營商信息,用於支持提供運營商信息相關的接口-->
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission>
<!--用於訪問wifi網絡信息,wifi信息會用於進行網絡定位-->
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>
<!--用於獲取wifi的獲取權限,wifi信息會用來進行網絡定位-->
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"></uses-permission>
<!--用於訪問網絡,網絡定位須要上網-->
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<!--用於讀取手機當前的狀態-->
<uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
<!--用於寫入緩存數據到擴展存儲卡-->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<!--用於申請調用A-GPS模塊-->
<uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS"></uses-permission>
<!--用於申請獲取藍牙信息進行室內定位-->
<uses-permission android:name="android.permission.BLUETOOTH"></uses-permission>
<uses-permission android:name="android.permission.BLUETOOTH_ADMIN"></uses-permission>

第六步

  初始化定位,配置參數,參考ui

/初始化定位參數
private void initLoc()
{
    //初始化定位
    mLocationClient = new AMapLocationClient(getApplicationContext());
    //初始化定位監聽
    mLocationListener = new AMapLocationListener(){
        @Override
        //實現監聽器,在監聽器的回調方法內解析AMapLocation對象
        public void onLocationChanged(AMapLocation amapLocation) {

            if (amapLocation != null) {
                if (amapLocation.getErrorCode() == 0)
                {//解析amapLocation獲取相應內容
                    amapLocation.getLocationType();//獲取當前定位結果來源,如網絡定位結果,詳見定位類型表
                    String address = amapLocation.getAddress();//地址,若是option中設置isNeedAddress爲false,則沒有此結果,網絡定位結果中會有地址信息,GPS定位不返回地址信息
                    amapLocation.getLocationType();//獲取當前定位結果來源,如網絡定位結果,詳見定位類型表
                    amapLocation.getLatitude();//獲取緯度
                    amapLocation.getLongitude();//獲取經度
                    amapLocation.getAccuracy();//獲取精度信息
                    amapLocation.getAddress();//地址,若是option中設置isNeedAddress爲false,則沒有此結果,網絡定位結果中會有地址信息,GPS定位不返回地址信息。

                    String address1 =
                    amapLocation.getCountry()              //國家信息
                    + amapLocation.getProvince()           //省信息
                    + amapLocation.getCity()               //城市信息
                    + amapLocation.getDistrict()           //城區信息
                    + amapLocation.getStreet()             //街道信息
                    + amapLocation.getStreetNum()          //街道門牌號信息
                    + amapLocation.getPoiName();           //獲取當前定位點的POI信息(Point Of Interest)
                    amapLocation.getGpsAccuracyStatus();//獲取GPS的當前狀態
                    //獲取定位時間
                    SimpleDateFormat df = new SimpleDateFormat("yyyyMMdd_HHmmss");
                    Date date = new Date(amapLocation.getTime());
                    String time = df.format(date);
                 
                }else {
                    //定位失敗時,可經過ErrCode(錯誤碼)信息來肯定失敗的緣由,errInfo是錯誤信息,詳見錯誤碼錶。
                    Log.e("AmapError","location Error, ErrCode:"
                            + amapLocation.getErrorCode() + ", errInfo:"
                            + amapLocation.getErrorInfo());
                    Toast.makeText(getApplicationContext(), "定位失敗", Toast.LENGTH_LONG);
                }
            }
        }
    };
    //設置定位回調監聽
    mLocationClient.setLocationListener(mLocationListener);
    //初始化AMapLocationClientOption對象
    mLocationOption = new AMapLocationClientOption();

    //設置定位模式
    mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy);
    //設置是否返回地址信息(默認返回地址信息)
    mLocationOption.setNeedAddress(true);
    //獲取最近3s內精度最高的一次定位結果:
    //設置setOnceLocationLatest(boolean b)接口爲true,啓動定位時SDK會返回最近3s內精度最高的一次定位結果。
    // 若是設置其爲true,setOnceLocation(boolean b)接口也會被設置爲true,反之不會,默認爲false。
    mLocationOption.setOnceLocationLatest(true);
    //設置是否強制刷新WIFI,默認爲true,強制刷新,會增長電量損耗,但精度高
    mLocationOption.setWifiActiveScan(true);
    //單位是毫秒,默認30000毫秒,建議超時時間不要低於8000毫秒。
    mLocationOption.setHttpTimeOut(20000);
    //給定位客戶端對象設置定位參數
    mLocationClient.setLocationOption(mLocationOption);

}

第七步

  啓動定位

mLocationClient.startLocation();

  中止定位

mLocationClient.stopLocation();//中止定位後,本地定位服務並不會被銷燬

  銷燬定位客戶端。銷燬定位客戶端以後,若要從新開啓定位請從新New一個AMapLocationClient對象

mLocationClient.onDestroy();//銷燬定位客戶端,同時銷燬本地定位服務
相關文章
相關標籤/搜索