• android 学习


    今天讲一下在android中使用百度定位

    package com.example.myapplication2;
    
    
    import android.app.Application;
    import android.app.Service;
    import android.os.Vibrator;
    
    import com.baidu.mapapi.CoordType;
    import com.baidu.mapapi.SDKInitializer;
    
    /**
     * 主Application,所有百度定位SDK的接口说明请参考线上文档:http://developer.baidu.com/map/loc_refer/index.html
     *
     * 百度定位SDK官方网站:http://developer.baidu.com/map/index.php?title=android-locsdk
     *
     * 直接拷贝com.baidu.location.service包到自己的工程下,简单配置即可获取定位结果,也可以根据demo内容自行封装
     */
    public class LocationApplication extends Application {
        public LocationService locationService;
        public Vibrator mVibrator;
        @Override
        public void onCreate() {
            super.onCreate();
            /***
             * 初始化定位sdk,建议在Application中创建
             */
            locationService = new LocationService(getApplicationContext());
            mVibrator =(Vibrator)getApplicationContext().getSystemService(Service.VIBRATOR_SERVICE);
            SDKInitializer.initialize(getApplicationContext());
            SDKInitializer.setCoordType(CoordType.BD09LL);
        }
    }
    package com.example.myapplication2;
    
    import android.content.Context;
    import android.webkit.WebView;
    
    import com.baidu.location.BDAbstractLocationListener;
    import com.baidu.location.LocationClient;
    import com.baidu.location.LocationClientOption;
    import com.baidu.location.LocationClientOption.LocationMode;
    
    /**
     * 定位服务LocationClient 相关
     *
     * @author baidu
     */
    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;
        }
    
        /**
         * 开发者应用如果有H5页面使用了百度JS接口,该接口可以辅助百度JS更好的进行定位
         *
         * @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();
        }
    }
  • 相关阅读:
    WebApi接口返回值不困惑:返回值类型详解
    Autofac 依赖注入框架 使用
    ASP.NET Core:使用Dapper和SwaggerUI来丰富你的系统框架
    ASP .Net Core 使用 Dapper 轻型ORM框架
    基于AspNet Core2.0 开发框架,包含简单的个人博客Demo
    Asp.Net MVC及Web API框架配置会碰到的几个问题及解决方案 (精髓)
    精简版自定义 jquery
    vs code 前端如何以服务器模式打开 [安装服务器] server insteall
    RestSharp用法小结
    翻译:WebApi 认证--用户认证Oauth解析
  • 原文地址:https://www.cnblogs.com/Nojava/p/14907541.html
Copyright © 2020-2023  润新知