1. 程式人生 > >百度地圖 sdk 簡單封裝使用 獲取當前位置

百度地圖 sdk 簡單封裝使用 獲取當前位置

因為專案中有幾處用到了定位功能,所以簡單封裝了一下百度地圖SDK,不用每次初始化,記錄於此.

使用前提是專案app已經匯入了百度地圖的SDK,專案比較陳舊,v7.2之前的版本,非最新版sdk.

一共兩個類,還是很簡單的,第一個MyLocationListener:

public abstract class MyLocationListener implements BDLocationListener {

    
    private BDLocation bdLocation;

    public MyLocationListener() {
       
    }

    @Override
    public void onReceiveLocation(BDLocation bdLocation) {
        this.bdLocation = bdLocation;
       
        handleLocationData(bdLocation);
    }

    public abstract void handleLocationData(BDLocation bdLocation);

    @Override
    public void onConnectHotSpotMessage(String s, int i) {
        
    }
}
第二個LocationHelper:
public abstract class LocationHelper {

    private LocationClient mLocClient;
    private BDLocation bdLocation;

    public LocationHelper(Context context) {
        initLocation(context);
    }

    private void initLocation(Context context) {
        LocationClientOption option = new LocationClientOption();
        option.setLocationMode(LocationClientOption.LocationMode.Hight_Accuracy);//可選,預設高精度,設定定位模式,高精度,低功耗,僅裝置
        option.setCoorType("bd09ll"); // 設定座標型別  可選,預設gcj02,設定返回的定位結果座標系
        option.setScanSpan(1000 * 10);// 可選,預設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.setEnableSimulateGps(false);//可選,預設false,設定是否需要過濾GPS模擬結果,預設需要

        MyLocationListener myListener = new MyLocationListener() {
            @Override
            public void handleLocationData(BDLocation bdLocation) {
                handleLocData(bdLocation);
            }
        };
        this.bdLocation = myListener.getBdLocation();
        mLocClient = new LocationClient(context);
        mLocClient.registerLocationListener(myListener);
        //可選,設定是否需要地址資訊,預設不需要
        mLocClient.setLocOption(option);
    }

    public abstract void handleLocData(BDLocation bdLocation);

    public BDLocation getBdLocation(){
        return bdLocation;
    }

    public LocationClient getLocationClient(){
        return mLocClient;
    }

    public void startClient(){
        mLocClient.start();
    }

    //退出時銷燬定位
    public void stopClient(){
        if (null != mLocClient) {
            mLocClient.stop();
        }
    }
}

使用:
LocationHelper helper = new LocationHelper(getActivity()) {
 @Override public void handleLocData(BDLocation bdLocation) {
		//此處新增自己的操作,比如直接設定當前城市
                String city = bdLocation.getCity();
                mLocation.setText(city);
            }
        };
helper.startClient();