• 毕业设计-进度-安卓端的手机定位2.1


    Android定位SDK使用

    手机的基础定位

    打开应用发起定位请求返回国家、省、市、街道、周边兴趣点、经度、纬度

    1. 获取密钥(AK)
    2. 初始一个LocationClient类
    public class LocationService {
        private static LocationClient client = null;
        private static LocationClientOption mOption;
        private static LocationClientOption  DIYoption;
        private Object objLock;
    
        /***
         * 初始化 LocationClient
         *
         * @param locationContext
         */
        public LocationService(Context locationContext) {
            objLock = new Object();
            synchronized (objLock) {
                if (client == null) {
                    client = new LocationClient(locationContext);
                    client.setLocOption(getDefaultLocationClientOption());
                }
            }
        }
    
        /***
         * 注册定位监听
         *
         * @param listener
         * @return
         */
    
        public boolean registerListener(BDAbstractLocationListener listener) {
            boolean isSuccess = false;
            if (listener != null) {
                client.registerLocationListener(listener);
                isSuccess = true;
            }
            return isSuccess;
        }
    
        public void unregisterListener(BDAbstractLocationListener listener) {
            if (listener != null) {
                client.unRegisterLocationListener(listener);
            }
        }
    
        /**
         * @return 获取sdk版本
         */
        public String getSDKVersion() {
            if (client != null) {
                String version = client.getVersion();
                return version;
            }
            return null;
        }
    
        /***
         * 设置定位参数
         *
         * @param option
         * @return isSuccessSetOption
         */
        public static boolean setLocationOption(LocationClientOption option) {
            boolean isSuccess = false;
            if (option != null) {
                if (client.isStarted()) {
                    client.stop();
                }
                DIYoption = option;
                client.setLocOption(option);
            }
            return isSuccess;
        }
    
        /**
         *
         * @param webView 传入webView控件
         */
        public void enableAssistanLocation(WebView webView) {
            if (client != null) {
                client.enableAssistantLocation(webView);
            }
        }
    
        /**
         * 停止H5辅助定位
         */
        public void disableAssistantLocation() {
            if (client != null) {
                client.disableAssistantLocation();
            }
        }
    
        /***
         *
         * @return DefaultLocationClientOption  默认O设置
         */
        public LocationClientOption getDefaultLocationClientOption() {
            if (mOption == null) {
                mOption = new LocationClientOption();
                mOption.setLocationMode(LocationMode.Hight_Accuracy); // 可选,默认高精度,设置定位模式,高精度,低功耗,仅设备
                mOption.setCoorType( "bd09ll" ); // 可选,默认gcj02,设置返回的定位结果坐标系,如果配合百度地图使用,建议设置为bd09ll;
                mOption.setScanSpan(3000); // 可选,默认0,即仅定位一次,设置发起连续定位请求的间隔需要大于等于1000ms才是有效的
                mOption.setIsNeedAddress(true); // 可选,设置是否需要地址信息,默认不需要
                mOption.setIsNeedLocationDescribe(true); // 可选,设置是否需要地址描述
                mOption.setNeedDeviceDirect(false); // 可选,设置是否需要设备方向结果
                mOption.setLocationNotify(false); // 可选,默认false,设置是否当gps有效时按照1S1次频率输出GPS结果
                mOption.setIgnoreKillProcess(true); // 可选,默认true,定位SDK内部是一个SERVICE,并放到了独立进程,设置是否在stop
                mOption.setIsNeedLocationDescribe(true); // 可选,默认false,设置是否需要位置语义化结果,可以在BDLocation
                mOption.setIsNeedLocationPoiList(true); // 可选,默认false,设置是否需要POI结果,可以在BDLocation
                mOption.SetIgnoreCacheException(false); // 可选,默认false,设置是否收集CRASH信息,默认收集
                mOption.setOpenGps(true); // 可选,默认false,设置是否开启Gps定位
                mOption.setIsNeedAltitude(false); // 可选,默认false,设置定位时是否需要海拔信息,默认不需要,除基础定位版本都可用
            }
            return mOption;
        }
    
    
        /**
         * @return DIYOption 自定义Option设置
         */
        public LocationClientOption getOption() {
            if (DIYoption == null) {
                DIYoption = new LocationClientOption();
            }
            return DIYoption;
        }
    
        public void start() {
            synchronized (objLock) {
                if (client != null && !client.isStarted()) {
                    client.start();
                }
            }
        }
    
        public void requestLocation() {
            if (client != null) {
                client.requestLocation();
            }
        }
    
        public void stop() {
            synchronized (objLock) {
                if (client != null && client.isStarted()) {
                    client.stop();
                }
            }
        }
    
        public boolean isStart() {
            return client.isStarted();
        }
    
        public boolean requestHotSpotState() {
            return client.requestHotSpotState();
        }
    }
    1. start()启动定位
      protected void onStart() {
          // TODO Auto-generated method stub
          super.onStart();
          // -----------location config ------------
          locationService = ((LocationApplication) getApplication()).locationService;
          //获取locationservice实例,建议应用中只初始化1个location实例,然后使用,可以参考其他示例的activity,都是通过此种方式获取locationservice实例的
          locationService.registerListener(mListener);
          //注册监听
          int type = getIntent().getIntExtra("from", 0);
          if (type == 0) {
              locationService.setLocationOption(locationService.getDefaultLocationClientOption());
          } else if (type == 1) {
              locationService.start();
          }
    2. 获取返回的定位信息
  • 相关阅读:
    简便的将DataSet导入到数据库中
    数据类型的小小研究:Access与SQL Server的数据类型
    【jxust acm 20120708】
    【D ECJTU_ACM 11级队员2012年暑假训练赛(2)】
    【hdu 2101 A + B Problem Too】
    【hdu 1014】
    【hdu 1164 Eddy's research I】
    【开始,安全编程】
    【hdu 1285 确定比赛名次】
    【hdu 1163 Eddy's digital Roots 】
  • 原文地址:https://www.cnblogs.com/1605-3QYL/p/12256921.html
Copyright © 2020-2023  润新知