浏览器版本低!无法浏览完整内容,建议升级或更换浏览器。
场景定位
下载开发文档
简介

利用定位SDK,不仅可以快速精准的获得经纬度信息,还可以根据开发者的使用场景选择不同的定位方式来获得位置信息, 目前百度Android 定位SDK支持签到场景、出行场景和运动场景定位。
获取位置描述与获取经纬度使用方法一致,只需在配置定位SDK参数时,做相关的设置即可。

具体步骤如下:

1. 第一步,准备工作

在使用定位SDK进行具体开发工作之前,需获取密钥(AK), 并对开发工程进行环境配置工作。详细介绍请参考项目创建部分的说明。 此外, Google在Android 6.0中引入了动态权限获取机制,开发者在使用定位SDK之前, 请详细了解关于Android 6.0系统开发须知。

2. 第二步,初始化LocationClient类

请在主线程中声明LocationClient类对象,该对象初始化需传入Context类型参数。 推荐使用getApplicationConext()方法获取全进程有效的Context。
核心代码段如下:

public LocationClient mLocationClient = null;
private MyLocationListener myListener = new MyLocationListener();
//BDAbstractLocationListener为7.2版本新增的Abstract类型的监听接口
//原有BDLocationListener接口暂时同步保留。具体介绍请参考后文中的说明
public void onCreate() {
mLocationClient = new LocationClient(getApplicationContext());
//声明LocationClient类
mLocationClient.registerLocationListener(myListener);
//注册监听函数
}
3. 第三步,配置场景定位参数

(1)签到场景:只进行一次定位返回最接近真实位置的定位结果
(2)运动场景:高精度连续定位,适用于运动类开发者场景
(3)出行场景:高精度连续定位,适用于出行类开发者场景
设置方法与获取经纬度中第三步类似,核心代码如下:

LocationClientOption locationClientOption = new LocationClientOption();
// 设置定位场景,根据定位场景快速生成对应的定位参数 以出行场景为例
locationClientOption.setLocationPurpose(LocationClientOption.BDLocationPurpose.Sport);

设置定位场景后,定位SDK会自动配置相应参数。具体配置情况如下。
签到场景:

LocationClientOption option = new LocationClientOption();
option.setLocationMode(LocationMode.Hight_Accuracy);
option.setLocationNotify(false);
option.setScanSpan(0);
option.setNeedNewVersionRgc(true);
option.setIsNeedAddress(true);
option.setIsNeedLocationPoiList(true);
option.setIsNeedAltitude(true);
option.setIsNeedLocationDescribe(true);
option.setWifiCacheTimeOut(10000);

运动场景:

LocationClientOption option = new LocationClientOption();
option.setLocationMode(LocationMode.Hight_Accuracy);
option.setLocationNotify(true);
option.setScanSpan(1000);
option.setNeedNewVersionRgc(true);
option.setIsNeedAddress(true);
option.setIsNeedLocationPoiList(false);
option.setIsNeedAltitude(true);
option.setIsNeedLocationDescribe(false);
option.setWifiCacheTimeOut(1000);
4. 第四步,实现BDAbstractLocationListener接口

Android定位SDK自V7.2版本起,对外提供了Abstract类型的监听接口BDAbstractLocationListener, 用于实现定位监听。原有BDLocationListener暂时保留, 推荐开发者升级到Abstract类型的新监听接口使用,该接口会异步获取定位结果, 核心代码如下:

public class MyLocationListener extends BDAbstractLocationListener{
@Override
public void onReceiveLocation(BDLocation location){
//此处的BDLocation为定位结果信息类,通过它的各种get方法可获取定位相关的全部结果
//以下只列举部分获取位置描述信息相关的结果
//更多结果信息获取说明,请参照类参考中BDLocation类中的说明
double latitude = location.getLatitude(); //获取纬度信息
double longitude = location.getLongitude(); //获取经度信息
}
}
5. 第五步,获取定位周边POI信息

调用LocationClient的start()方法,发起请求,在BDAbstractLocationListener接口中,便可获得。 详细信息请参考获取经纬度中第五步的介绍。

上一篇

防定位作弊

下一篇

位置提醒

本篇文章对您是否有帮助?