Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> 關於Android編程 >> Android定位功能(二)

Android定位功能(二)

編輯:關於Android編程

在前文Android定位功能(一)中,已經大致介紹了一下在Android平台中,和定位功能相關的類,並舉例獲取了位置信息。但是前文是基於Criteria定制了一個標准,通過getBestProvider()方法由Android系統自動獲取最符合Criteria的LocationProvider,從而實現了定位功能。這樣的做法能最大限度的保證定位功能的可實現性,但是卻無法保證獲取到的位置信息有最大的准確度。因為除了GPS外,其他定位方式都或多或少存在著位置偏移。

  在實現GPS定位前,先了解一下GPS的部分特性:

  1. GPS定位需要依靠3顆或3顆以上的衛星。

  2. GPS定位受環境影響較大,在晴朗的空地上,較容易搜索到衛星,而在室內通常是無法搜索到衛星的。

  3. GPS定位需要使用GPS功能模塊,而GPS功能模塊的耗電量是巨大的。

  在Android系統中,實現GPS定位的思路應該是:

  1. 獲取GPS的Location Provider。

  2. 講此Provider傳入到requestLocationUpdates()方法,讓Android系統獲知搜索位置方式。

  3. 創建實現了GpsStatus.Listener接口的對象,重寫onGpsStatusChanged()方法,向LocationManager添加次監聽器,檢測衛星狀態。(可選步驟)

  根據以上思路,仿照Android定位功能(一)中的例子,可以很容易的得到以下實現代碼:(此代碼的實現前提是GPS功能模塊處於打開狀態) 


  1 public class MainActivity extends Activity { 
2  private LocationManager locationManager; 
3   private GpsStatus gpsstatus; 
4     @Override 
5     public void onCreate(Bundle savedInstanceState) {
  6        super.onCreate(savedInstanceState); 
7        setContentView(R.layout.main); 
8          9        //獲取到LocationManager對象
10        locationManager = (LocationManager) getSystemService(LOCATION_SERVICE);
11       
  12        //根據設置的Criteria對象,獲取最符合此標准的provider對象
13        String currentProvider = locationManager.getProvider(LocationManager.GPS_PROVIDER).getName();
14    
     15        //根據當前provider對象獲取最後一次位置信息
16        Location currentLocation = locationManager.getLastKnownLocation(currentProvider);
17        //如果位置信息為null,則請求更新位置信息
18        if(currentLocation == null){
19            locationManager.requestLocationUpdates(currentProvider, 0, 0, locationListener);
20        } 21        //增加GPS狀態監聽器
22        locationManager.addGpsStatusListener(gpsListener);
23       
  24        //直到獲得最後一次位置信息為止,如果未獲得最後一次位置信息,則顯示默認經緯度
25        //每隔10秒獲取一次位置信息
26        while(true){
27            currentLocation = locationManager.getLastKnownLocation(currentProvider);
28            if(currentLocation != null){
29                Log.d("Location", "Latitude: " + currentLocation.getLatitude());
30                Log.d("Location", "location: " + currentLocation.getLongitude());
31                break;
32            }else{
33                Log.d("Location", "Latitude: " + 0);
34                Log.d("Location", "location: " + 0);
35            }
36            try {
37                Thread.sleep(10000);
38            } catch (InterruptedException e) {
39                 Log.e("Location", e.getMessage());
40            }
41        }
42     }
43     
44     private GpsStatus.Listener gpsListener = new GpsStatus.Listener(){
45         //GPS狀態發生變化時觸發
46         @Override
47         public void onGpsStatusChanged(int event) {
48             //獲取當前狀態
49             gpsstatus=locationManager.getGpsStatus(null);
50             switch(event){
51                 //第一次定位時的事件
52                 case GpsStatus.GPS_EVENT_FIRST_FIX:
53                     break;
54                 //開始定位的事件
55                 case GpsStatus.GPS_EVENT_STARTED:
56                     break;
57                 //發送GPS衛星狀態事件
58                 case GpsStatus.GPS_EVENT_SATELLITE_STATUS:
59                     Toast.makeText(MainActivity.this, "GPS_EVENT_SATELLITE_STATUS", Toast.LENGTH_SHORT).show();
60                     Iterable<GpsSatellite> allSatellites = gpsstatus.getSatellites();   
61                     Iterator<GpsSatellite> it=allSatellites.iterator(); 
62                     int count = 0;
63                     while(it.hasNext()) 
   64                     { 
   65                         count++;
66                     }
67                     Toast.makeText(MainActivity.this, "Satellite Count:" + count, Toast.LENGTH_SHORT).show(); 68                     break;
69                 //停止定位事件
70                 case GpsStatus.GPS_EVENT_STOPPED:
71                     Log.d("Location", "GPS_EVENT_STOPPED");
72                     break;
73             }
74         }
75     };
76     
77     
78     //創建位置監聽器
79     private LocationListener locationListener = new LocationListener(){
80         //位置發生改變時調用 81         @Override
82         public void onLocationChanged(Location location) {
83             Log.d("Location", "onLocationChanged");
84         }
85 
86         //provider失效時調用
87         @Override
88         public void onProviderDisabled(String provider) {
89             Log.d("Location", "onProviderDisabled");
90         }
91 
92         //provider啟用時調用
93         @Override
94         public void onProviderEnabled(String provider) {
95             Log.d("Location", "onProviderEnabled");
96         }
97
  98         //狀態改變時調用
99         @Override100         public void onStatusChanged(String provider, int status, Bundle extras) {
101             Log.d("Location", "onStatusChanged")
102         }
103     };
104 }
  通過以上代碼中的注釋部分,可以清晰的知道Android定位功能裡相關方法的具體含義。希望對大家有用。

  另外,因為GPS的自身特性,此代碼在室內幾乎無法定位,所以建議再真正的實際項目裡,至少使用network和GPS兩種不同的Location Provider實現定位功能。

  本人暫時未找到同時關閉網絡和GPS功能實現定位的方法,本人也未找到通過代碼在沒有ROOT的前提下直接代開網絡和GPS功能的代碼。如果大家在這兩方面有自己的體會,請不吝賜教,留言評論或給出參考地址都可。大家一同探討,一同進步。

 

  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved