Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> Android開發實例 >> Android定位功能(一)

Android定位功能(一)

編輯:Android開發實例

 廢話不多說,直接開始說說與實現Android定位有關的API吧。

  這些API都在android.location包下,一共有三個接口和八個類。它們配合使用即可實現定位功能。

 

  三個接口:

  GpsStatus.Listener: 這是一個當GPS狀態發生改變時,用來接收通知的接口。

  GpsStatus.NmeaListener: 這是一個用來從GPS裡接收Nmea-0183(為海用電子設備制定的標准格式)信息的接口。

  LocationListener: 位置監聽器,用於接收當位置信息發生改變時從LocationManager接收通知的接口。

 

  八個類:

  Address: 描述地址的類,比如:北京天安門

  Criteria: 用於描述Location Provider標准的類,標准包括位置精度水平,電量消耗水平,是否獲取海拔、方位信息,是否允許接收付費服務。

  GeoCoder: 用於處理地理位置的編碼。

  GpsSatellite: 和GpsStatus聯合使用,用於描述當前GPS衛星的狀態。

  GpsStatus: 和GpsStatus.Listener聯合使用,用於描述當前GPS衛星的狀態。

  Location: 用於描述位置信息。

  LocationManager: 通過此類獲取和調用系統位置服務

  LocationProvider: 用於描述Location Provider的抽象超類,一個LocationProvider應該能夠周期性的報告當前設備的位置信息。

 

  這裡通過一個代碼示例,演示一下如何實現定位。

  首先,在AndroidManifest.xml清單文件裡需要加入ACCESS_FINE_LOCATION權限

<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>

  其次,實現代碼如下:

  1 package com.test;
2
3 import java.io.IOException;
4 import java.util.List;
5
6 import android.app.Activity;
7 import android.location.Address;
8 import android.location.Criteria;
9 import android.location.Geocoder;
10 import android.location.Location;
11 import android.location.LocationListener;
12 import android.location.LocationManager;
13 import android.os.Bundle;
14 import android.util.Log;
15 import android.widget.Toast;
16
17 public class MainActivity extends Activity {
18 @Override
19 public void onCreate(Bundle savedInstanceState) {
20 super.onCreate(savedInstanceState);
21 setContentView(R.layout.main);
22
23 //獲取到LocationManager對象
24 LocationManager locationManager = (LocationManager) getSystemService(LOCATION_SERVICE);
25 //創建一個Criteria對象
26 Criteria criteria = new Criteria();
27 //設置粗略精確度
28 criteria.setAccuracy(Criteria.ACCURACY_COARSE);
29 //設置是否需要返回海拔信息
30 criteria.setAltitudeRequired(false);
31 //設置是否需要返回方位信息
32 criteria.setBearingRequired(false);
33 //設置是否允許付費服務
34 criteria.setCostAllowed(true);
35 //設置電量消耗等級
36 criteria.setPowerRequirement(Criteria.POWER_HIGH);
37 //設置是否需要返回速度信息
38 criteria.setSpeedRequired(false);
39
40 //根據設置的Criteria對象,獲取最符合此標准的provider對象
41 String currentProvider = locationManager.getBestProvider(criteria, true);
42 Log.d("Location", "currentProvider: " + currentProvider);
43 //根據當前provider對象獲取最後一次位置信息
44 Location currentLocation = locationManager.getLastKnownLocation(currentProvider);
45 //如果位置信息為null,則請求更新位置信息
46 if(currentLocation == null){
47 locationManager.requestLocationUpdates(currentProvider, 0, 0, locationListener);
48 }
49 //直到獲得最後一次位置信息為止,如果未獲得最後一次位置信息,則顯示默認經緯度
50 //每隔10秒獲取一次位置信息
51 while(true){
52 currentLocation = locationManager.getLastKnownLocation(currentProvider);
53 if(currentLocation != null){
54 Log.d("Location", "Latitude: " + currentLocation.getLatitude());
55 Log.d("Location", "location: " + currentLocation.getLongitude());
56 break;
57 }else{
58 Log.d("Location", "Latitude: " + 0);
59 Log.d("Location", "location: " + 0);
60 }
61 try {
62 Thread.sleep(10000);
63 } catch (InterruptedException e) {
64 Log.e("Location", e.getMessage());
65 }
66 }
67
68 //解析地址並顯示
69 Geocoder geoCoder = new Geocoder(this);
70 try {
71 int latitude = (int) currentLocation.getLatitude();
72 int longitude = (int) currentLocation.getLongitude();
73 List<Address> list = geoCoder.getFromLocation(latitude, longitude, 2);
74 for(int i=0; i<list.size(); i++){
75 Address address = list.get(i);
76 Toast.makeText(MainActivity.this, address.getCountryName() + address.getAdminArea() + address.getFeatureName(), Toast.LENGTH_LONG).show();
77 }
78 } catch (IOException e) {
79 Toast.makeText(MainActivity.this,e.getMessage(), Toast.LENGTH_LONG).show();
80 }
81
82 }
83
84 //創建位置監聽器
85 private LocationListener locationListener = new LocationListener(){
86 //位置發生改變時調用
87 @Override
88 public void onLocationChanged(Location location) {
89 Log.d("Location", "onLocationChanged");
90 Log.d("Location", "onLocationChanged Latitude" + location.getLatitude());
91 Log.d("Location", "onLocationChanged location" + location.getLongitude());
92 }
93
94 //provider失效時調用
95 @Override
96 public void onProviderDisabled(String provider) {
97 Log.d("Location", "onProviderDisabled");
98 }
99
100 //provider啟用時調用
101 @Override
102 public void onProviderEnabled(String provider) {
103 Log.d("Location", "onProviderEnabled");
104 }
105
106 //狀態改變時調用
107 @Override
108 public void onStatusChanged(String provider, int status, Bundle extras) {
109 Log.d("Location", "onStatusChanged");
110 }
111 };
112 }

  由於代碼裡的Criteria對象對位置精度要求並不高,所以一般會返回“network”作為provider,而基於network的定位往往會存在一定的位置偏差,這對於需要精確定位的應用程序來說,顯然不合要求。這時,需要則需要用到基於GPS的定位方法了。具體詳情,請看後下一篇。

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