編輯:關於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號和大體定位時間到loc-bugs@baidu.com,會有人追查原因");
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
Android中Dialog對話框,androiddialog布局文件xml: 1 <LinearLayout xmlns:android=http://sc
win通過dos配置注冊列表
win通過dos配置注冊列表由於服務器數量眾多,需求是配置環境變量,為了不被累屎,為了減輕壓力所以有了這篇文章!嘿嘿……需求如圖: _<)~~~~ )1、注冊表設置win
Android系統 應用圖標顯示未讀消息數(BadgeNumber) 桌面app圖標的角標顯示
Android系統 應用圖標顯示未讀消息數(BadgeNumber) 桌面app圖標的角標顯示 Android系統 小米,三星,索尼手機發送桌面快鍵提醒數字圖標,在
Android應用開發教程之十三:短信庫解析
今天我和同學們討論一下Android平台下如何調用系統方法發送短信、接收短信、系統的短信庫相關的問題。進入正題,我們先使用Eclipse工具模擬給自