在高德官網下載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();//銷燬定位客戶端,同時銷燬本地定位服務