百度地图总结第三篇之定位(我的位置)
前言:
使用百度定位SDK获取对应的位置信息,然后利用地图SDK中的接口。您能够在地
在这里提示一下,假设是在一个project中同一时候使用定位的SDK和百度地图SDK。能够共同使用一个key。假设新创建project,那么就要去又一次申请key了。申请方式一样。如有疑问能够看看百度地图总结第一篇–环境集成和Hello Baidu_Map实现
集成定位SDK:
- 然后我们看下集成文档,下载对应的定位SDK,解压出来,我们把须要的jar包加入到libs文件夹下(BaiduLBS_Android.jar)。然后我们把.so库文件放到我们之前的jniLibs文件夹下(注意文件名称一定要对应才行)
- 最后来看看我们的AndroidMainfest.xml文件里的逻辑吧。
- 在application标签中声明service组件,每一个app拥有自己单独的定位service
<service android:name="com.baidu.location.f" android:enabled="true" android:process=":remote">
</service>
- 【重要提醒】
定位SDKv3.1版本号之后。以下权限已不须要。请取消声明,否则将因为Android 5.0多帐户系统加强权限管理而导致应用安装失败。
android:name="android.permission.BAIDU_LOCATION_SERVICE"></uses-permission>
- 使用相关权限(假设使用的有百度地图的,那么权限有可能反复。删除就可以):
<!-- 这个权限用于进行网络定位-->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"></uses-permission>
<!-- 这个权限用于訪问GPS定位-->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>
<!-- 用于訪问wifi网络信息。wifi信息会用于进行网络定位-->
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>
<!-- 获取运营商信息,用于支持提供运营商信息相关的接口-->
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission>
<!-- 这个权限用于获取wifi的获取权限。wifi信息会用来进行网络定位-->
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"></uses-permission>
<!-- 用于读取手机当前的状态-->
<uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
<!-- 写入扩展存储,向扩展卡写入数据。用于写入离线定位数据-->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<!-- 訪问网络。网络定位须要上网-->
<uses-permission android:name="android.permission.INTERNET" />
<!-- SD卡读取权限,用户写入离线定位数据-->
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"></uses-permission>
- 设置AcessKey(假设之前有百度地图的key,那么这一步就能够省略了):
SDK4.2及之后版本号须要在Mainfest.xml设置Accesskey。设置有误会引起定位和地理围栏服务不能正常使用,必须进行Accesskey的正确设置。
设置AccessKey。在application标签中加入
<meta-data
android:name="com.baidu.lbsapi.API_KEY"
android:value="key" /> //key:开发人员申请的key
使用综合定位功能,開始定位功能的实现
- 综合定位功能指的根据用户实际需求,返回用户当前位置的基础定位服务。
包括GPS和网络定位(Wi-Fi和基站定位)功能。
基本定位功能同一时候还支持结合定位结果的反地理编码功能,离线定位,位置提醒功能和位置语义化功能。
第一步。初始化LocationClient类:
- 此处须要注意:LocationClient类必须在主线程中声明。须要Context类型的參数。Context须要时全进程有效的context,推荐用getApplicationConext获取全进程有效的context
public LocationClient mLocationClient = null;
public BDLocationListener myListener = new MyLocationListener();
public void onCreate() {
mLocationClient = new LocationClient(getApplicationContext()); //声明LocationClient类
mLocationClient.registerLocationListener( myListener ); //注冊监听函数
}
第二步,配置定位SDK參数:
- 设置定位參数包括:定位模式(高精度定位模式。低功耗定位模式和仅用设备定位模式)。返回坐标类型,是否打开GPS,是否返回地址信息、位置语义化信息、POI信息等等。
LocationClientOption option = new LocationClientOption();
option.setLocationMode(LocationClientOption.LocationMode.Hight_Accuracy
);//可选,默认高精度。设置定位模式,高精度,低功耗,仅设备
option.setCoorType("bd09ll");//可选,默认gcj02。设置返回的定位结果坐标系
int span = 5000; //5秒发送一次
option.setScanSpan(span);//可选,默认0,即仅定位一次,设置发起定位请求的间隔须要大于等于1000ms才是有效的
option.setIsNeedAddress(true);//可选。设置是否须要地址信息,默认不须要
option.setOpenGps(true);//可选。默认false,设置是否使用gps
option.setLocationNotify(true);//可选,默认false。设置是否当gps有效时依照1S1次频率输出GPS结果
option.setIsNeedLocationDescribe(true);//可选,默认false。设置是否须要位置语义化结果。能够在BDLocation.getLocationDescribe里得到,结果相似于“在北京天安门附近”
option.setIsNeedLocationPoiList(true);//可选,默认false,设置是否须要POI结果。能够在BDLocation.getPoiList里得到
option.setIgnoreKillProcess(false);//可选,默认true。定位SDK内部是一个SERVICE,并放到了独立进程,设置是否在stop的时候杀死这个进程。默认不杀死
option.SetIgnoreCacheException(false);//可选,默认false,设置是否收集CRASH信息,默认收集
option.setEnableSimulateGps(false);//可选,默认false,设置是否须要过滤gps仿真结果,默认须要
option.setNeedDeviceDirect(true); //返回的定位结果包括手机机头方向
mLocationClient.setLocOption(option);
mLocationClient.start(); //启动位置请求
mLocationClient.requestLocation();//发送请求
- 高精度定位模式:这样的定位模式下,会同一时候使用网络定位和GPS定位。优先返回最高精度的定位结果。
- 低功耗定位模式:这样的定位模式下,不会使用GPS。仅仅会使用网络定位(Wi-Fi和基站定位)。
- 仅用设备定位模式:这样的定位模式下,不须要连接网络。仅仅使用GPS进行定位,这样的模式下不支持室内环境的定位。
第三步,实现BDLocationListener接口:
/**
* 位置监听器
* <p/>
* BDLocationListener接口有1个方法须要实现: 1.接收异步返回的定位结果,參数是BDLocation类型參数。
*/
class MyLocationListener implements BDLocationListener {
/**
* 接收位置的信息回调方法
*
* @param location
*/
@Override
public void onReceiveLocation(BDLocation location) {
if (location == null) {
return;
}
StringBuffer sb = new StringBuffer(256);
sb.append("time : ");
sb.append(location.getTime());
sb.append("\nerror code : ");
sb.append(location.getLocType());
sb.append("\nlatitude : ");
sb.append(location.getLatitude());
sb.append("\nlontitude : ");
sb.append(location.getLongitude());
sb.append("\nradius : ");
sb.append(location.getRadius());
if (location.getLocType() == BDLocation.TypeGpsLocation) {// GPS定位结果
sb.append("\nspeed : ");
sb.append(location.getSpeed());// 单位:公里每小时
sb.append("\nsatellite : ");
sb.append(location.getSatelliteNumber());
sb.append("\nheight : ");
sb.append(location.getAltitude());// 单位:米
sb.append("\ndirection : ");
sb.append(location.getDirection());// 单位度
sb.append("\naddr : ");
sb.append(location.getAddrStr());
sb.append("\ndescribe : ");
sb.append("gps定位成功");
} else if (location.getLocType() == BDLocation.TypeNetWorkLocation) {// 网络定位结果
sb.append("\naddr : ");
sb.append(location.getAddrStr());
//运营商信息
sb.append("\noperationers : ");
sb.append(location.getOperators());
sb.append("\ndescribe : ");
sb.append("网络定位成功");
} else if (location.getLocType() == BDLocation.TypeOffLineLocation) {// 离线定位结果
sb.append("\ndescribe : ");
sb.append("离线定位成功,离线定位结果也是有效的");
} else if (location.getLocType() == BDLocation.TypeServerError) {
sb.append("\ndescribe : ");
sb.append("服务端网络定位失败,能够反馈IMEI号和大体定位时间到loc-bugs@baidu.com,会有人追查原因");
} else if (location.getLocType() == BDLocation.TypeNetWorkException) {
sb.append("\ndescribe : ");
sb.append("网络不同导致定位失败,请检查网络是否通畅");
} else if (location.getLocType() == BDLocation.TypeCriteriaException) {
sb.append("\ndescribe : ");
sb.append("无法获取有效定位根据导致定位失败,通常是因为手机的原因,处于飞行模式下通常会造成这样的结果。能够试着重新启动手机");
}
sb.append("\nlocationdescribe : ");
sb.append(location.getLocationDescribe());// 位置语义化信息
List<Poi> list = location.getPoiList();// POI数据
if (list != null) {
sb.append("\npoilist size = : ");
sb.append(list.size());
for (Poi p : list) {
sb.append("\npoi= : ");
sb.append(p.getId() + " " + p.getName() + " " + p.getRank());
}
}
Log.d("BaiduLocationApiDem", sb.toString());
BitmapDescriptor bitmapDescriptor = BitmapDescriptorFactory.fromResource(R.mipmap.icon_gcoding);
//创建一个图层选项
LatLng latlng = new LatLng(location.getLatitude(), location.getLongitude());
OverlayOptions options = new MarkerOptions().position(latlng).icon(bitmapDescriptor);
mBaiduMap.addOverlay(options);
MapStatus mMapStatus = new MapStatus.Builder()
.target(latlng)
.zoom(12)
.build();
//定义MapStatusUpdate对象。以便描写叙述地图状态将要发生的变化
MapStatusUpdate mMapStatusUpdate = MapStatusUpdateFactory.newMapStatus(mMapStatus);
//改变地图状态
mBaiduMap.setMapStatus(mMapStatusUpdate);
}
}
善后工作之获取error code:
public int getLocType ( )
这里基本上就能够了,以下我们来看下定位效果吧(不小心暴漏了。。
。):
以下我们看下完整的代码吧。
package com.example.mylocation;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import com.baidu.mapapi.map.BaiduMap;
import com.baidu.mapapi.map.BitmapDescriptor;
import com.baidu.mapapi.map.BitmapDescriptorFactory;
import com.baidu.mapapi.map.MapStatus;
import com.baidu.mapapi.map.MapStatusUpdate;
import com.baidu.mapapi.map.MapStatusUpdateFactory;
import com.baidu.mapapi.map.MapView;
import com.baidu.location.BDLocation;
import com.baidu.location.BDLocationListener;
import com.baidu.location.LocationClient;
import com.baidu.location.LocationClientOption;
import com.baidu.location.BDNotifyListener;//假如用到位置提醒功能。须要import该类
import com.baidu.location.Poi;
import com.baidu.mapapi.map.MarkerOptions;
import com.baidu.mapapi.map.OverlayOptions;
import com.baidu.mapapi.model.LatLng;
import java.util.List;
public class MyLocation extends AppCompatActivity implements View.OnClickListener {
//第一步,初始化LocationClient类
private LocationClient mLocationClient = null;
private Button startLocation;
private MapView mapView;
private BaiduMap mBaiduMap;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_my_location);
startLocation = (Button) findViewById(R.id.startLocation);
startLocation.setOnClickListener(this);
mapView = (MapView) findViewById(R.id.mapView);
mBaiduMap = mapView.getMap();
//普通地图
mBaiduMap.setMapType(BaiduMap.MAP_TYPE_NORMAL);
BDLocationListener listener = new MyLocationListener();
//此处须要注意:LocationClient类必须在主线程中声明。须要Context类型的參数。
//Context须要时全进程有效的context,推荐用getApplicationConext获取全进程有效的context
mLocationClient = new LocationClient(getApplicationContext());
//注冊位置监听器
mLocationClient.registerLocationListener(listener);
}
/**
* 位置监听器
* <p/>
* BDLocationListener接口有1个方法须要实现: 1.接收异步返回的定位结果,參数是BDLocation类型參数。
*/
class MyLocationListener implements BDLocationListener {
/**
* 接收位置的信息回调方法
*
* @param location
*/
@Override
public void onReceiveLocation(BDLocation location) {
if (location == null) {
return;
}
StringBuffer sb = new StringBuffer(256);
sb.append("time : ");
sb.append(location.getTime());
sb.append("\nerror code : ");
sb.append(location.getLocType());
sb.append("\nlatitude : ");
sb.append(location.getLatitude());
sb.append("\nlontitude : ");
sb.append(location.getLongitude());
sb.append("\nradius : ");
sb.append(location.getRadius());
if (location.getLocType() == BDLocation.TypeGpsLocation) {// GPS定位结果
sb.append("\nspeed : ");
sb.append(location.getSpeed());// 单位:公里每小时
sb.append("\nsatellite : ");
sb.append(location.getSatelliteNumber());
sb.append("\nheight : ");
sb.append(location.getAltitude());// 单位:米
sb.append("\ndirection : ");
sb.append(location.getDirection());// 单位度
sb.append("\naddr : ");
sb.append(location.getAddrStr());
sb.append("\ndescribe : ");
sb.append("gps定位成功");
} else if (location.getLocType() == BDLocation.TypeNetWorkLocation) {// 网络定位结果
sb.append("\naddr : ");
sb.append(location.getAddrStr());
//运营商信息
sb.append("\noperationers : ");
sb.append(location.getOperators());
sb.append("\ndescribe : ");
sb.append("网络定位成功");
} else if (location.getLocType() == BDLocation.TypeOffLineLocation) {// 离线定位结果
sb.append("\ndescribe : ");
sb.append("离线定位成功。离线定位结果也是有效的");
} else if (location.getLocType() == BDLocation.TypeServerError) {
sb.append("\ndescribe : ");
sb.append("服务端网络定位失败,能够反馈IMEI号和大体定位时间到loc-bugs@baidu.com,会有人追查原因");
} else if (location.getLocType() == BDLocation.TypeNetWorkException) {
sb.append("\ndescribe : ");
sb.append("网络不同导致定位失败。请检查网络是否通畅");
} else if (location.getLocType() == BDLocation.TypeCriteriaException) {
sb.append("\ndescribe : ");
sb.append("无法获取有效定位根据导致定位失败,通常是因为手机的原因,处于飞行模式下通常会造成这样的结果,能够试着重新启动手机");
}
sb.append("\nlocationdescribe : ");
sb.append(location.getLocationDescribe());// 位置语义化信息
List<Poi> list = location.getPoiList();// POI数据
if (list != null) {
sb.append("\npoilist size = : ");
sb.append(list.size());
for (Poi p : list) {
sb.append("\npoi= : ");
sb.append(p.getId() + " " + p.getName() + " " + p.getRank());
}
}
Log.d("BaiduLocationApiDem", sb.toString());
BitmapDescriptor bitmapDescriptor = BitmapDescriptorFactory.fromResource(R.mipmap.icon_gcoding);
//创建一个图层选项
LatLng latlng = new LatLng(location.getLatitude(), location.getLongitude());
OverlayOptions options = new MarkerOptions().position(latlng).icon(bitmapDescriptor);
mBaiduMap.addOverlay(options);
MapStatus mMapStatus = new MapStatus.Builder()
.target(latlng)
.zoom(12)
.build();
//定义MapStatusUpdate对象。以便描写叙述地图状态将要发生的变化
MapStatusUpdate mMapStatusUpdate = MapStatusUpdateFactory.newMapStatus(mMapStatus);
//改变地图状态
mBaiduMap.setMapStatus(mMapStatusUpdate);
}
}
protected void onDestroy() {
super.onDestroy();
//在activity运行onDestroy时运行mMapView.onDestroy(),实现地图生命周期管理
mapView.onDestroy();
}
@Override
protected void onResume() {
super.onResume();
//在activity运行onResume时运行mMapView. onResume (),实现地图生命周期管理
mapView.onResume();
}
@Override
protected void onPause() {
super.onPause();
//在activity运行onPause时运行mMapView. onPause (),实现地图生命周期管理
mapView.onPause();
}
/**
* 请求我的位置信息
*
* @param v
*/
@Override
public void onClick(View v) {
LocationClientOption option = new LocationClientOption();
option.setLocationMode(LocationClientOption.LocationMode.Hight_Accuracy
);//可选,默认高精度,设置定位模式,高精度。低功耗,仅设备
option.setCoorType("bd09ll");//可选,默认gcj02,设置返回的定位结果坐标系
int span = 5000; //5秒发送一次
option.setScanSpan(span);//可选,默认0,即仅定位一次,设置发起定位请求的间隔须要大于等于1000ms才是有效的
option.setIsNeedAddress(true);//可选,设置是否须要地址信息,默认不须要
option.setOpenGps(true);//可选。默认false,设置是否使用gps
option.setLocationNotify(true);//可选,默认false。设置是否当gps有效时依照1S1次频率输出GPS结果
option.setIsNeedLocationDescribe(true);//可选,默认false,设置是否须要位置语义化结果,能够在BDLocation.getLocationDescribe里得到。结果相似于“在北京天安门附近”
option.setIsNeedLocationPoiList(true);//可选,默认false,设置是否须要POI结果。能够在BDLocation.getPoiList里得到
option.setIgnoreKillProcess(false);//可选,默认true。定位SDK内部是一个SERVICE,并放到了独立进程,设置是否在stop的时候杀死这个进程。默认不杀死
option.SetIgnoreCacheException(false);//可选,默认false。设置是否收集CRASH信息,默认收集
option.setEnableSimulateGps(false);//可选,默认false,设置是否须要过滤gps仿真结果,默认须要
option.setNeedDeviceDirect(true); //返回的定位结果包括手机机头方向
mLocationClient.setLocOption(option);
mLocationClient.start(); //启动位置请求
mLocationClient.requestLocation();//发送请求
}
}
小弟也是刚学习,如有什么错误之处,还请大神手下留情,指出错误之处,共同学习。