编写:penkzhou - 原文:http://developer.android.com/training/location/retrieve-current.html
使用Google Play services location APIs,我们的应用可以请求获得用户设备的最后可知位置。大多数情况下,我们会对用户的当前位置比较感兴趣。而通常用户的当前位置相当于设备的最后可知位置。
特别地,使用fused location provider来获取设备的最后可知位置。fused location provider是Google Play services location APIs中的一个。它处理基本定位技术并提供一个简单的API,使得我们可以指定高水平的需求,如高精度或者低功耗。同时它优化了设备的耗电情况。
这节课介绍如何通过使用fused location provider的getLastLocation()方法为设备的位置构造一个单一请求。
为了访问fused location provider,我们的应用开发工程必须包括Google Play services。通过SDK Manager下载和安装Google Play services组件,添加相关的库到我们的工程。更详细的介绍,请看Setting Up Google Play Services。
使用位置服务的应用必须请求用户位置权限。Android拥有两种位置权限:ACCESS_COARSE_LOCATION 和 ACCESS_FINE_LOCATION。我们选择的权限决定API返回的位置信息的精度。如果我们选择了ACCESS_COARSE_LOCATION,API返回的位置信息的精确度大体相当于一个城市街区。
这节课只要求粗略的定位。在我们应用的manifest文件中,用uses-permission节点请求这个权限,如下所示:
uses-permission
<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.google.android.gms.location.sample.basiclocationsample" > <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/> </manifest>
为了连接到API,我们需要创建一个Google Play services API客户端实例。关于使用这个客户端的更详细的介绍,请看Accessing Google APIs。
在我们的activity的onCreate()方法中,用GoogleApiClient.Builder创建一个Google API Client实例。使用这个builder添加LocationServices API。
实例应用定义了一个buildGoogleApiClient()方法,这个方法在activity的onCreate()方法中被调用。buildGoogleApiClient()方法包括下面的代码。
buildGoogleApiClient()
protected synchronized void buildGoogleApiClient() { mGoogleApiClient = new GoogleApiClient.Builder(this) .addConnectionCallbacks(this) .addOnConnectionFailedListener(this) .addApi(LocationServices.API) .build(); }
一旦我们将Google Play services和location services API连接完成后,我们就可以获取用户设备的最后可知位置。当我们的应用连接到这些服务之后,我们可以用fused location provider的getLastLocation()方法来获取设备的位置。调用这个方法返回的定位精确度是由我们在应用的manifest文件里添加的权限决定的,如本文的[确定应用的权限]()部分描述的内容一样。
为了请求最后可知位置,调用getLastLocation()方法,并将我们创建的GoogleApiClient对象的实例传给该方法。在Google API Client提供的onConnected()回调函数里调用getLastLocation()方法,这个回调函数在client准备好的时候被调用。下面的示例代码说明了请求和一个对响应简单的处理:
public class MainActivity extends ActionBarActivity implements ConnectionCallbacks, OnConnectionFailedListener { ... @Override public void onConnected(Bundle connectionHint) { mLastLocation = LocationServices.FusedLocationApi.getLastLocation( mGoogleApiClient); if (mLastLocation != null) { mLatitudeText.setText(String.valueOf(mLastLocation.getLatitude())); mLongitudeText.setText(String.valueOf(mLastLocation.getLongitude())); } } }
getLastLocation()方法返回一个Location对象。通过Location对象,我们可以取得地理位置的经度和纬度坐标。在少数情况下,当位置不可用时,这个Location对象会返回null。
下一课,获取位置更新,教你如何周期性地获取位置信息更新。
Copyright© 2013-2020
All Rights Reserved 京ICP备2023019179号-8