百度地图总结第三篇之定位(我的位置)

前言:

使用百度定位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();//发送请求
    }
}

小弟也是刚学习,如有什么错误之处,还请大神手下留情,指出错误之处,共同学习。

posted @ 2017-07-29 12:20  mfmdaoyou  阅读(653)  评论(0编辑  收藏  举报