編輯:關於android開發
這幾天自己研究了關於地手機上面開發安卓地圖的問題,發現百度官方示例demo講解百度持續定位方面還是講解的有些不清楚,本人研究了幾次之後將其弄得更詳細以便於讓各位方便學習,有不足之處請在評論區指出,官方示例的網址是:http://lbsyun.baidu.com/index.php?title=android-locsdk/guide/v5-0
上面的網址已經將安卓簡單配置百度地圖環境講解的很詳細了,再次不做贅述了,此外,可能會有人發現
1 package com.example.andoridloca; 2 3 import java.util.List; 4 import java.util.Timer; 5 import java.util.TimerTask; 6 7 import android.app.Activity; 8 import android.content.ContentValues; 9 import android.content.Intent; 10 import android.database.Cursor; 11 import android.os.Bundle; 12 import android.os.Handler; 13 import android.os.Message; 14 import android.text.method.ScrollingMovementMethod; 15 import android.util.Log; 16 import android.view.Menu; 17 import android.view.MenuItem; 18 import android.view.View; 19 import android.view.View.OnClickListener; 20 import android.widget.Button; 21 import android.widget.TextView; 22 import android.widget.Toast; 23 24 import com.baidu.location.BDLocation; 25 import com.baidu.location.BDLocationListener; 26 import com.baidu.location.LocationClient; 27 import com.baidu.location.LocationClientOption; 28 import com.baidu.location.BDNotifyListener;//假如用到位置提醒功能,需要import該類 29 import com.baidu.location.LocationClientOption.LocationMode; 30 import com.baidu.location.Poi; 31 import com.baidu.mapapi.SDKInitializer; 32 import com.baidu.mapapi.map.MapView; 33 34 public class MainActivity extends Activity implements OnClickListener{ 35 MapView mMapView = null; 36 public static final String TAG="mian"; 37 StringBuffer sb = new StringBuffer(256); 38 public StringBuilder builder=new StringBuilder(); 39 private Button bt1; 40 private TextView tv1; 41 private DBtools DBhelper; 42 boolean isOpenLocation=false; 43 public LocationClient mLocationClient = null; 44 public BDLocationListener myListener = new MyLocationListener(); 45 @Override 46 protected void onCreate(Bundle savedInstanceState) { 47 super.onCreate(savedInstanceState); 48 SDKInitializer.initialize(getApplicationContext()); 49 setContentView(R.layout.activity_main); 50 DBhelper = new DBtools(this); 51 tv1=(TextView) findViewById(R.id.textView1); 52 tv1.setMovementMethod(new ScrollingMovementMethod()); 53 bt1=(Button) findViewById(R.id.button1); 54 bt1.setOnClickListener(this); 55 mMapView = (MapView) findViewById(R.id.bmapView); 56 mLocationClient = new LocationClient(getApplicationContext()); //聲明LocationClient類 57 mLocationClient.registerLocationListener( myListener ); //注冊監聽函數 58 initLocation(); 59 } 60 private void initLocation(){ 61 LocationClientOption option = new LocationClientOption(); 62 option.setLocationMode(LocationMode.Hight_Accuracy 63 );//可選,默認高精度,設置定位模式,高精度,低功耗,僅設備 64 option.setCoorType("bd09ll");//可選,默認gcj02,設置返回的定位結果坐標系 65 int span=0; 66 option.setScanSpan(span);//可選,默認0,即僅定位一次,設置發起定位請求的間隔需要大於等於1000ms才是有效的 67 option.setIsNeedAddress(true);//可選,設置是否需要地址信息,默認不需要 68 option.setOpenGps(true);//可選,默認false,設置是否使用gps 69 option.setLocationNotify(true);//可選,默認false,設置是否當gps有效時按照1S1次頻率輸出GPS結果 70 option.setIsNeedLocationDescribe(true);//可選,默認false,設置是否需要位置語義化結果,可以在BDLocation.getLocationDescribe裡得到,結果類似於“在北京天安門附近” 71 option.setIsNeedLocationPoiList(true);//可選,默認false,設置是否需要POI結果,可以在BDLocation.getPoiList裡得到 72 option.setIgnoreKillProcess(false);//可選,默認true,定位SDK內部是一個SERVICE,並放到了獨立進程,設置是否在stop的時候殺死這個進程,默認不殺死 73 option.SetIgnoreCacheException(false);//可選,默認false,設置是否收集CRASH信息,默認收集 74 option.setEnableSimulateGps(false);//可選,默認false,設置是否需要過濾gps仿真結果,默認需要 75 mLocationClient.setLocOption(option); 76 } 77 @Override 78 protected void onDestroy() { 79 super.onDestroy(); 80 //在activity執行onDestroy時執行mMapView.onDestroy(),實現地圖生命周期管理 81 mMapView.onDestroy(); 82 } 83 @Override 84 protected void onResume() { 85 super.onResume(); 86 //在activity執行onResume時執行mMapView. onResume (),實現地圖生命周期管理 87 mMapView.onResume(); 88 } 89 @Override 90 protected void onPause() { 91 super.onPause(); 92 //在activity執行onPause時執行mMapView. onPause (),實現地圖生命周期管理 93 mMapView.onPause(); 94 } 95 public class MyLocationListener implements BDLocationListener { 96 97 @Override 98 public void onReceiveLocation(BDLocation location) { 99 //Receive Location 100 StringBuffer sb = new StringBuffer(256); 101 sb.append("time : "); 102 sb.append(location.getTime()); 103 sb.append("\nerror code : "); 104 sb.append(location.getLocType()); 105 sb.append("\nlatitude : "); 106 sb.append(location.getLatitude()); 107 sb.append("\nlontitude : "); 108 sb.append(location.getLongitude()); 109 sb.append("\nradius : "); 110 sb.append(location.getRadius()); 111 if (location.getLocType() == BDLocation.TypeGpsLocation){// GPS定位結果 112 sb.append("\nspeed : "); 113 sb.append(location.getSpeed());// 單位:公裡每小時 114 sb.append("\nsatellite : "); 115 sb.append(location.getSatelliteNumber()); 116 sb.append("\nheight : "); 117 sb.append(location.getAltitude());// 單位:米 118 sb.append("\ndirection : "); 119 sb.append(location.getDirection());// 單位度 120 sb.append("\naddr : "); 121 sb.append(location.getAddrStr()); 122 sb.append("\ndescribe : "); 123 sb.append("gps定位成功"); 124 125 } else if (location.getLocType() == BDLocation.TypeNetWorkLocation){// 網絡定位結果 126 sb.append("\naddr : "); 127 sb.append(location.getAddrStr()); 128 //運營商信息 129 sb.append("\noperationers : "); 130 sb.append(location.getOperators()); 131 sb.append("\ndescribe : "); 132 sb.append("網絡定位成功"); 133 } else if (location.getLocType() == BDLocation.TypeOffLineLocation) {// 離線定位結果 134 sb.append("\ndescribe : "); 135 sb.append("離線定位成功,離線定位結果也是有效的"); 136 } else if (location.getLocType() == BDLocation.TypeServerError) { 137 sb.append("\ndescribe : "); 138 sb.append("服務端網絡定位失敗,可以反饋IMEI號和大體定位時間到[email protected],會有人追查原因"); 139 } else if (location.getLocType() == BDLocation.TypeNetWorkException) { 140 sb.append("\ndescribe : "); 141 sb.append("網絡不同導致定位失敗,請檢查網絡是否通暢"); 142 } else if (location.getLocType() == BDLocation.TypeCriteriaException) { 143 sb.append("\ndescribe : "); 144 sb.append("無法獲取有效定位依據導致定位失敗,一般是由於手機的原因,處於飛行模式下一般會造成這種結果,可以試著重啟手機"); 145 } 146 sb.append("\nlocationdescribe : "); 147 sb.append(location.getLocationDescribe());// 位置語義化信息 148 List<Poi> list = location.getPoiList();// POI數據 149 if (list != null) { 150 sb.append("\npoilist size = : "); 151 sb.append(list.size()); 152 for (Poi p : list) { 153 sb.append("\npoi= : "); 154 sb.append(p.getId() + " " + p.getName() + " " + p.getRank()); 155 } 156 } 157 Log.i("BaiduLocationApiDem", sb.toString()); 158 DBtools dbhelper=new DBtools(getApplicationContext()); 159 ContentValues initialValues = new ContentValues(); 160 initialValues.put("shijian",location.getTime()); 161 initialValues.put("didian",location.getLatitude()+"--"+location.getLongitude()); 162 dbhelper.open(); 163 dbhelper.insert("path",initialValues); 164 dbhelper.close(); 165 tv1.setText(sb.toString()); 166 } 167 } 168 169 @Override 170 public void onClick(View arg0) { 171 Thread mytime=new Thread(new ThreadShow()); 172 if(isOpenLocation){ 173 mLocationClient.stop(); 174 isOpenLocation=false; 175 176 } 177 else{ 178 Toast.makeText(getApplicationContext(), "開啟", Toast.LENGTH_SHORT).show(); 179 isOpenLocation=true; 180 //mLocationClient.start(); 181 mytime.start(); 182 } 183 184 } 185 // handler類接收數據 186 Handler handler = new Handler() { 187 public void handleMessage(Message msg) { 188 if (msg.what == 1) { 189 Log.i("BaiduLocationApiDem", "加以"); 190 mLocationClient.start(); 191 mLocationClient.requestLocation(); 192 } 193 }; 194 }; 195 // 線程類 196 class ThreadShow implements Runnable { 197 198 @Override 199 public void run() { 200 // TODO Auto-generated method stub 201 while (isOpenLocation) { 202 try { 203 mLocationClient.stop(); 204 Thread.sleep(2000); 205 Message msg = new Message(); 206 msg.what = 1; 207 handler.sendMessage(msg); 208 // System.out.println("send..."); 209 } catch (Exception e) { 210 // TODO Auto-generated catch block 211 e.printStackTrace(); 212 System.out.println("thread error..."); 213 } 214 } 215 } 216 } 217 218 219 } 220 221 222 223 224 225 226
這裡面關於mLocationClient.stop();mLocationClient.start(); mLocationClient.requestLocation(); 這三個函數我有必要講解一下,因為持續定位時這三個函數的配合使用很重要,官方文檔裡面解釋說mLocationClient.start()函數用於開啟定位,mLocationClient.requestLocation()函數用於主動觸發定位SDK內部定位邏輯,個人感覺差不多,兩個都會執行我的mLocationClient的所屬類裡面的邏輯代碼,可能是我的項目就這樣吧,然後是mLocationClient.stop(),此函數用於停止定位,如果持續定位的話,是需要和mLocationClient.start()函數配合使用的,具體在上面的代碼裡面有展示。
切記不要將mLocationClient.start()和mLocationClient.stop()一起使用,我在網上查詢時好像是說一部原因,具體舉一個例子吧:
1 //某段代碼如果是這樣的話按照邏輯韓式會將mLocationClient所屬類的裡面邏輯代碼執行一遍,具體見MainAvtivity裡面的MyLocationListener類內容,但是實際上是不會執行的 2 mLocationClient.start(); 3 mLocationClient.stop();
所以在我的MainActivity裡面我使用線程來一遍遍的執行start和stop函數,這樣就會消除剛剛說的這種效果,最後就能夠實現持續定位了。
在此給出我的布局文件配合看看
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context="com.example.newloca.MainActivity" > <RelativeLayout android:layout_width="match_parent" android:layout_height="300dp"> <com.baidu.mapapi.map.MapView android:id="@+id/bmapView" android:layout_width="fill_parent" android:layout_height="fill_parent" android:clickable="true" /> </RelativeLayout> <TextView android:id="@+id/textView1" android:layout_width="match_parent" android:layout_height="150dp" android:scrollbars="vertical" android:background="#f00" android:text="位置信息" /> <RelativeLayout android:layout_width="match_parent" android:layout_height="match_parent" > <Button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentRight="true" android:layout_alignParentBottom="true" android:text="獲取位置" /> </RelativeLayout> </LinearLayout>
其他像權限什麼的配置,用最開始給的官方地址裡面的就行了
順便說一下,本人是使用的安卓4.2版本開發的,手機真機調試和虛擬機調試在定位的時間間隔上面會有點誤差,也不知道什麼原因
Android中Dialog對話框,androiddialog布局文件xml: 1 <LinearLayout xmlns:android=http://sc
win通過dos配置注冊列表由於服務器數量眾多,需求是配置環境變量,為了不被累屎,為了減輕壓力所以有了這篇文章!嘿嘿……需求如圖: _<)~~~~ )1、注冊表設置win
Android系統 應用圖標顯示未讀消息數(BadgeNumber) 桌面app圖標的角標顯示 Android系統 小米,三星,索尼手機發送桌面快鍵提醒數字圖標,在
今天我和同學們討論一下Android平台下如何調用系統方法發送短信、接收短信、系統的短信庫相關的問題。進入正題,我們先使用Eclipse工具模擬給自