百度地图实现定位功能

---恢复内容开始---

1.首先先申请一个百度地图密钥

网址: http://lbsyun.baidu.com/apiconsole/key;

利用工具软件获取SHA1值或者在黑窗口获取

http://lbsyun.baidu.com/index.php?title=android-locsdk/guide/key

2.下载对应的SDK并导入

http://lbsyun.baidu.com/sdk/download

3.环境配置

 

(1)在application中添加开发密钥

<application>  
    <meta-data  
        android:name="com.baidu.lbsapi.API_KEY"  
        android:value="开发者 key" />  
</application>

2)添加所需权限

<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="com.android.launcher.permission.READ_SETTINGS" />
<uses-permission android:name="android.permission.WAKE_LOCK"/>
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.GET_TASKS" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.WRITE_SETTINGS" />

第三步,在布局xml文件中添加地图控件;

<com.baidu.mapapi.map.MapView  
    android:id="@+id/bmapView"  
    android:layout_width="fill_parent"  
    android:layout_height="fill_parent"  
    android:clickable="true" />


4.在应用程序创建时初始化 SDK引用的Context 全局变量:
public class MainActivity extends Activity {  
    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);   
        //在使用SDK各组件之前初始化context信息,传入ApplicationContext  
        //注意该方法要再setContentView方法之前实现  
        SDKInitializer.initialize(getApplicationContext());  
        setContentView(R.layout.activity_main);  
    }  
}

5,创建地图Activity,管理地图生命周期;

public class MainActivity extends Activity {  
    MapView mMapView = null;  
    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);   
        //在使用SDK各组件之前初始化context信息,传入ApplicationContext  
        //注意该方法要再setContentView方法之前实现  
        SDKInitializer.initialize(getApplicationContext());  
        setContentView(R.layout.activity_main);  
        //获取地图控件引用  
        mMapView = (MapView) findViewById(R.id.bmapView);  
    }  
    @Override  
    protected void onDestroy() {  
        super.onDestroy();  
        //在activity执行onDestroy时执行mMapView.onDestroy(),实现地图生命周期管理  
        mMapView.onDestroy();  
    }  
    @Override  
    protected void onResume() {  
        super.onResume();  
        //在activity执行onResume时执行mMapView. onResume (),实现地图生命周期管理  
        mMapView.onResume();  
        }  
    @Override  
    protected void onPause() {  
        super.onPause();  
        //在activity执行onPause时执行mMapView. onPause (),实现地图生命周期管理  
        mMapView.onPause();  
        }  
    }
--------------至此形成一个基础地图----------------
定位开始
6.首先要早builde grade中加入下列代码来处理so文件

sourceSets {
        main {
    		jniLibs.srcDirs = ['libs']
        }
}
在  Androidmainfiest中加入
<service android:name="com.baidu.location.f"
android:enabled="true"
android:process=":remote"> </service>
再补点权限
<!-- 这个权限用于进行网络定位-->
<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>

---------------------
重要步骤

初始化LocationClient类

public LocationClient mLocationClient = null;
 
public BDAbstractLocationListener myListener = new MyLocationListener();

public void onCreate() {
    mLocationClient = new LocationClient(getApplicationContext());     
    //声明LocationClient类
    mLocationClient.registerLocationListener( myListener );    
    //注册监听函数
}

LocationClientOption类,该类用来设置定位SDK的定位方式,例如:

private void initLocation(){

LocationClientOption option = new LocationClientOption();
option.setLocationMode(LocationClientOption.LocationMode.Hight_Accuracy);
//可选,默认高精度,设置定位模式,高精度,低功耗,仅设备

option.setCoorType("bd09ll");
//可选,默认gcj02,设置返回的定位结果坐标系

int span=1000;
option.setScanSpan(span);
//可选,默认0,即仅定位一次,设置发起定位请求的间隔需要大于等于1000ms才是有效的

option.setIsNeedAddress(true);
//可选,设置是否需要地址信息,默认不需要

option.setOpenGps(true);
//可选,默认false,设置是否使用gps

option.setLocationNotify(true);
//可选,默认false,设置是否当GPS有效时按照1S/1次频率输出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.setWifiValidTime(5*60*1000);
//可选,7.2版本新增能力,如果您设置了这个接口,首次启动定位时,会先判断当前WiFi是否超出有效期,超出有效期的话,会先重新扫描WiFi,然后再定位

mLocationClient.setLocOption(option);
}
private class MyLocationListener extends BDAbstractLocationListener {
@Override
public void onReceiveLocation(BDLocation location) {

//获取定位结果
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.i("BaiduLocationApiDem", sb.toString());
}

/**
* 回调定位诊断信息,开发者可以根据相关信息解决定位遇到的一些问题
* 自动回调,相同的diagnosticType只会回调一次
*
* @param locType 当前定位类型
* @param diagnosticType 诊断类型(1~9)
* @param diagnosticMessage 具体的诊断信息释义
*/
public void onLocDiagnosticMessage(int locType, int diagnosticType, String diagnosticMessage) {

if (diagnosticType == LocationClient.LOC_DIAGNOSTIC_TYPE_BETTER_OPEN_GPS) {

//建议打开GPS

} else if (diagnosticType == LocationClient.LOC_DIAGNOSTIC_TYPE_BETTER_OPEN_WIFI) {

//建议打开wifi,不必连接,这样有助于提高网络定位精度!

} else if (diagnosticType == LocationClient.LOC_DIAGNOSTIC_TYPE_NEED_CHECK_LOC_PERMISSION) {

//定位权限受限,建议提示用户授予APP定位权限!

} else if (diagnosticType == LocationClient.LOC_DIAGNOSTIC_TYPE_NEED_CHECK_NET) {

//网络异常造成定位失败,建议用户确认网络状态是否异常!

} else if (diagnosticType == LocationClient.LOC_DIAGNOSTIC_TYPE_NEED_CLOSE_FLYMODE) {

//手机飞行模式造成定位失败,建议用户关闭飞行模式后再重试定位!

} else if (diagnosticType == LocationClient.LOC_DIAGNOSTIC_TYPE_NEED_INSERT_SIMCARD_OR_OPEN_WIFI) {

//无法获取任何定位依据,建议用户打开wifi或者插入sim卡重试!

} else if (diagnosticType == LocationClient.LOC_DIAGNOSTIC_TYPE_NEED_OPEN_PHONE_LOC_SWITCH) {

//无法获取有效定位依据,建议用户打开手机设置里的定位开关后重试!

} else if (diagnosticType == LocationClient.LOC_DIAGNOSTIC_TYPE_SERVER_FAIL) {

//百度定位服务端定位失败
//建议反馈location.getLocationID()和大体定位时间到loc-bugs@baidu.com

} else if (diagnosticType == LocationClient.LOC_DIAGNOSTIC_TYPE_FAIL_UNKNOWN) {

//无法获取有效定位依据,但无法确定具体原因
//建议检查是否有安全软件屏蔽相关定位权限
//或调用重新启动后重试!

}
}



}

启动定位,代码如下:

mLocationClient.start();
 

 

ok



















---恢复内容结束---

posted @ 2017-09-05 23:41  都嘛德红  阅读(8200)  评论(1)    收藏  举报