在下載頁面下載最新的庫文件。將liblocSDK2.4.so文件拷貝到libs/armeabi目錄下。將locSDK2.4.jar文件拷貝到工程根目錄下,并在工程屬性-Java Build Path-Libraries中選擇“Add JARs”,選定locSDK2.4.jar,確定后返回。這樣您就可以在程序中使用百度定位API了。
成都創新互聯公司是專業的上思網站建設公司,上思接單;提供成都網站建設、做網站,網頁設計,網站設計,建網站,PHP網站建設等專業做網站服務;采用PHP框架,可快速的進行上思網站開發網頁制作和功能擴展;專業做搜索引擎喜愛的網站,專業的做網站團隊,希望更多企業前來合作!
設置AndroidManifest.xml
為區分2.3版本service,需要將manifest file中的 intent filter聲明為com.baidu.location.service_v2.4 在application標簽中聲明service組件
service android:name="com.baidu.location.f" android:enabled="true" android:process=":remote" android:permission="android.permission.BAIDU_LOCATION_SERVICE" intent-filter action android:name="com.baidu.location.service_v2.4"/action /intent-filter/service聲明使用權限
permission android:name="android.permission.BAIDU_LOCATION_SERVICE"/permissionuses-permission android:name="android.permission.BAIDU_LOCATION_SERVICE"/uses-permissionuses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/uses-permissionuses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/uses-permissionuses-permission android:name="android.permission.ACCESS_WIFI_STATE"/uses-permissionuses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/uses-permissionuses-permission android:name="android.permission.CHANGE_WIFI_STATE"/uses-permissionuses-permission android:name="android.permission.READ_PHONE_STATE"/uses-permissionuses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/uses-permissionuses-permission android:name="android.permission.INTERNET" /uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/uses-permissionuses-permission android:name="android.permission.READ_LOGS"/uses-permissionimport相關類
import com.baidu.location.BDLocation;import com.baidu.location.BDLocationListener;import com.baidu.location.LocationClient;import com.baidu.location.LocationClientOption;import com.baidu.location.BDNotifyListener;//假如用到位置提醒功能,需要import該類功能類的使用
初始化LocationClient類
此處需要注意:LocationClient類必須在主線程中聲明。需要Context類型的參數。
public LocationClient mLocationClient = null;public BDLocationListener myListener = new MyLocationListener(); public void onCreate() { mLocationClient = new LocationClient(this); //聲明LocationClient類 mLocationClient.registerLocationListener( myListener ); //注冊監聽函數}實現BDLocationListener接口
BDLocationListener接口有2個方法需要實現:
1.接收異步返回的定位結果,參數是BDLocation類型參數。
2.接收異步返回的POI查詢結果,參數是BDLocation類型參數。
public class MyLocationListenner implements BDLocationListener { @Override public void onReceiveLocation(BDLocation location) { if (location == null) return ; StringBuffer sb = new StringBuffer(256); sb.append("time : "); sb.append(location.getTime()); sb.append("\nerror code : "); sb.append(location.getLocType()); sb.append("\nlatitude : "); sb.append(location.getLatitude()); sb.append("\nlontitude : "); sb.append(location.getLongitude()); sb.append("\nradius : "); sb.append(location.getRadius()); if (location.getLocType() == BDLocation.TypeGpsLocation){ sb.append("\nspeed : "); sb.append(location.getSpeed()); sb.append("\nsatellite : "); sb.append(location.getSatelliteNumber()); } else if (location.getLocType() == BDLocation.TypeNetWorkLocation){ sb.append("\naddr : "); sb.append(location.getAddrStr()); } logMsg(sb.toString()); }public void onReceivePoi(BDLocation poiLocation) { if (poiLocation == null){ return ; } StringBuffer sb = new StringBuffer(256); sb.append("Poi time : "); sb.append(poiLocation.getTime()); sb.append("\nerror code : "); sb.append(poiLocation.getLocType()); sb.append("\nlatitude : "); sb.append(poiLocation.getLatitude()); sb.append("\nlontitude : "); sb.append(poiLocation.getLongitude()); sb.append("\nradius : "); sb.append(poiLocation.getRadius()); if (poiLocation.getLocType() == BDLocation.TypeNetWorkLocation){ sb.append("\naddr : "); sb.append(poiLocation.getAddrStr()); } if(poiLocation.hasPoi()){ sb.append("\nPoi:"); sb.append(poiLocation.getPoi()); }else{ sb.append("noPoi information"); } logMsg(sb.toString()); }}設置參數
設置定位參數包括:定位模式(單次定位,定時定位),返回坐標類型,是否打開GPS等等。eg:
LocationClientOption option = new LocationClientOption();option.setOpenGps(true);option.setAddrType("detail");option.setCoorType("gcj02");option.setScanSpan(5000);option.disableCache(true);//禁止啟用緩存定位option.setPoiNumber(5); //最多返回POI個數 option.setPoiDistance(1000); //poi查詢距離 option.setPoiExtraInfo(true); //是否需要POI的電話和地址等詳細信息 mLocClient.setLocOption(option);發起定位請求
發起定位請求。請求過程是異步的,定位結果在上面的監聽函數onReceiveLocation中獲取。
if (mLocClient != null mLocClient.isStarted()) mLocClient.requestLocation();else Log.d("LocSDK_2.0_Demo1", "locClient is null or not started");發起POI查詢請求
發起POI查詢請求。請求過程是異步的,定位結果在上面的監聽函數onReceivePoi中獲取。
if (mLocClient != null mLocClient.isStarted()) mLocClient.requestPoi();位置提醒使用
位置提醒最多提醒3次,3次過后將不再提醒。 假如需要再次提醒,或者要修改提醒點坐標,都可通過函數SetNotifyLocation()來實現。
//位置提醒相關代碼mNotifyer = new NotifyLister();mNotifyer.SetNotifyLocation(42.03249652949337,113.3129895882556,3000,"gps");//4個參數代表要位置提醒的點的坐標,具體含義依次為:緯度,經度,距離范圍,坐標系類型(gcj02,gps,bd09,bd09ll)mLocationClient.registerNotify(mNotifyer);//注冊位置提醒監聽事件后,可以通過SetNotifyLocation 來修改位置提醒設置,修改后立刻生效。
//BDNotifyListner實現public class NotifyLister extends BDNotifyListener{ public void onNotify(BDLocation mlocation, float distance){ mVibrator01.vibrate(1000);//振動提醒已到設定位置附近 }}
//取消位置提醒mLocationClient.removeNotifyEvent(mNotifyer);
可以參考如下內容:
使用Android自帶的LocationManager和Location獲取位置的時候,經常會有獲取的location為null的情況,并且操作起來也不是很方便,在這個Demo里我使用了百度地圖API中的定位SDK,可以一次性獲取當前位置經緯度以及詳細地址信息,還可以獲取周邊POI信息,同時可以設定位置通知點,當到達某一位置時,發出通知信息等方式來告知用戶。jar包下載以及官方文檔請參照:百度定位SDK,前提是需要注冊百度開發者賬號。
下面來看看定位的基本原理,目前,定位SDK可以通過GPS、基站、Wifi信號進行定位。基本定位流程如下圖所示,當應用程序向定位SDK發起定位請求時,定位SDK會根據當前的GPS、基站、Wifi信息生成相對應的定位依據。然后定位SDK會根據定位依據來進行定位。如果需要,定位SDK會向定位服務器發送網絡請求。定位服務器會根據請求的定位依據推算出對應的坐標位置,然后根據用戶的定制信息,生成定位結果返回給定位SDK。
手機版百度地圖定位有多種方式,有衛星定位(包括GPS)、IP定位(接入數據網絡)、WIFI小區定位(接入WLAN熱點),等等。上述各種定位方式只要有一種具備條件,就可以實現定位,并非必須開啟GPS。
百度地圖的WIFI小區定位還有個特點,就是連接WIFI時,并不需要必須接通網絡,有時只要搜索到信號就可以定位。
百度地圖是通過移動通信基站定位來確定當前位置所在的城市。其原理就是通過測算周圍基站與手機的距離來交會估算手機的空間位置。
手機定位是指通過特定的定位技術來獲取移動手機或終端用戶的位置信息(經緯度坐標),在電子地圖上標出被定位對象的位置的技術或服務。定位技術有兩種,一種是基于GPS的定位,一種是基于移動運營網的基站的定位。基于GPS的定位方式是利用手機上的GPS定位模塊將自己的位置信號發送到定位后臺來實現手機定位的。基站定位則是利用基站對手機的距離的測算距離來確定手機位置的。后者不需要手機具有GPS定位能力,但是精度很大程度依賴于基站的分布及覆蓋范圍的大小,有時誤差會超過一公里。前者定位精度較高。此外還有利用Wifi在小范圍內定位的方式。
都會有誤差的情況,參考如下內容解釋:
基站精度為平均200米左右,視運營商基站覆蓋范圍而定。WIFI精度為20米左右。GPS精度最高,為10米左右(取決于芯片)。在戶外,先開啟GPS再進行定位,結果較準。但GPS比較費電,且在室內不可用。
另外,addr=detail 想要獲取完整地址(詳細到門牌號),或者addr=rough 想要獲得到城市一個級別的地址(比如返回中國北京北京);
上面這段是百度官方文檔里面的解釋: 這個我 在做的時候基本是這種情況, 文檔里面提到的 精度取決于芯片的問題,其實就是不同手機設備的差異。這個我專門做過測試,我用了5臺手機測試: htc one ,三星I9118,htc t328w,紅米1s,聯想a820 。 這5臺手機在室外同一個位置百度地圖定位獲取 經緯度坐標,測試結果是:
htc one 誤差2-3米 有時候是0-1米 非常精確了相對來說,htc t328w 紅米1s,聯想 都是 15-30米左右,三星那個機型稍微差點 定位速度不僅慢,而且誤差也較大 誤差有時候是200多米,穩定后也是80米左右。這個穩定的意思是 ,gps初始化需要時間的,一般要2-3分鐘以后,誤差范圍的數字會越來越小。
獲取誤差范圍的方法是:BDLocation類下的方法 location.getRadius();//獲取定位精度
網頁標題:百度android定位,百度云手機定位app
標題來源:http://vcdvsql.cn/article0/dsdjoio.html
成都網站建設公司_創新互聯,為您提供網站排名、App設計、手機網站建設、品牌網站設計、定制網站、外貿網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯