亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android封裝高德地圖定位工具類Util的方法

發布時間:2022-03-30 10:51:17 來源:億速云 閱讀:416 作者:iii 欄目:移動開發

這篇文章主要介紹了Android封裝高德地圖定位工具類Util的方法的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Android封裝高德地圖定位工具類Util的方法文章都會有所收獲,下面我們一起來看看吧。

第一步、去官網創建高德Key

Android封裝高德地圖定位工具類Util的方法

帶*號的填完后,點擊提交,獲取SHA1值如下(通過代碼獲取的)或者通過命令行獲取,兩者都行。

Android studio代碼獲取SHA1值

調用 Log.e("-->打印sha1 ","${sha1(this)}")
fun sha1(context: Context): String {
        try {
            val info: PackageInfo = context.packageManager.getPackageInfo(
                    context.packageName, PackageManager.GET_SIGNATURES)
            val cert: ByteArray = info.signatures.get(0).toByteArray()
            val md: MessageDigest = MessageDigest.getInstance("SHA1")
            val publicKey: ByteArray = md.digest(cert)
            val hexString = StringBuffer()
            for (i in publicKey.indices) {
                val appendString = Integer.toHexString(0xFF and publicKey[i].toInt())
                        .toUpperCase(Locale.US)
                if (appendString.length == 1) hexString.append("0")
                hexString.append(appendString)
                hexString.append(":")
            }
            val result = hexString.toString()
            return result.substring(0, result.length - 1)
        } catch (e: PackageManager.NameNotFoundException) {
            e.printStackTrace()
        } catch (e: NoSuchAlgorithmException) {
            e.printStackTrace()
        }
        return ""
    }

Android封裝高德地圖定位工具類Util的方法

第二步  通過Gradle集成SDK(方便):

1、在Project的build.gradle文件中配置repositories,添加maven或jcenter倉庫地址:

allprojects { repositories { jcenter() // 或者 mavenCentral() } }

2、在主工程的build.gradle文件配置dependencies

   //定位
   implementation "com.amap.api:location:latest.integration"

第三步    配置參數

第1步,配置AndroidManifest.xml

請在application標簽中聲明service組件,每個app擁有自己單獨的定位service。

 <!-- 定位需要的服務 使用2.0的定位需要加上這個 -->
        <service android:name="com.amap.api.location.APSService" >
        </service>

第2步,聲明權限 如果項目中已有其中的權限,那就不用加了

<!--用于進行網絡定位-->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"></uses-permission> <!--用于訪問GPS定位--> 
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>
<!--用于獲取運營商信息,用于支持提供運營商信息相關的接口--> 
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission>
<!--用于訪問wifi網絡信息,wifi信息會用于進行網絡定位-->
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>
<!--用于獲取wifi的獲取權限,wifi信息會用來進行網絡定位-->
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"></uses-permission>
<!--用于訪問網絡,網絡定位需要上網-->
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<!--用于讀取手機當前的狀態-->
<uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
<!--用于寫入緩存數據到擴展存儲卡-->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission> <!--用于申請調用A-GPS模塊-->
<uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS"></uses-permission>

第3步,設置高德Key:

<meta-data android:name="com.amap.api.v2.apikey" android:value="key">//開發者申請的key           </meta-data>

第四步   獲取定位數據

在需要獲取經緯度的頁面調用如下代碼:

private var amapLocationUtil: AmapLocationUtil? = null
    
    
     fun initLocationOption() {
        if (null == amapLocationUtil) {
            amapLocationUtil = AmapLocationUtil(CommApplication.getApplication())
        }
        amapLocationUtil!!.initLocation()
        amapLocationUtil!!.startLocation()
        amapLocationUtil!!.setOnCallBackListener { longitude, latitude, location, isSucdess, address ->
       //Log.e("--->", "longitude" + longitude + "
" + "latitude" + latitude + "
" + "isSucdess" + isSucdess + "
" + "address" + address);
       //Log.e("--->",location.getProvince()+ "
" +location.getCity()+"
"+location.getDistrict());
        //isSucdess    true  定位成功   false  失敗
            if (isSucdess) {
               
            } else {
            //定位失敗,重試定位
            amapLocationUtil!!.startLocation()
            }
        }
    }

注意:如果是在當前Activity實例化的,不要忘了銷毀

override fun onDestroy() {
        super.onDestroy()
        if (amapLocationUtil != null) {
            amapLocationUtil!!.destroyLocation()
        }
    }

看到了代碼里調用了AmapLocationUtil,這個是我封裝好的一個工具類,方便調用,代碼如下:

/**
 *
 * Created by JasonYin
 * Description:封裝高德地圖Util
 *
 */
class AmapLocationUtil(private val mContext: Context) {
    private var locationClient: AMapLocationClient? = null
    private var locationOption: AMapLocationClientOption? = null
    private var mOnCallBackListener: onCallBackListener? = null
    /**
     * 初始化定位
     */
    fun initLocation() { //初始化client
        if (null == locationClient) {
            locationClient = AMapLocationClient(mContext)
        }
        locationOption = defaultOption
        //設置定位參數
        locationClient!!.setLocationOption(locationOption)
        // 設置定位監聽
        locationClient!!.setLocationListener(locationListener)
    }//可選,設置定位模式,可選的模式有高精度、僅設備、僅網絡。默認為高精度模式
    //可選,設置是否gps優先,只在高精度模式下有效。默認關閉
    //可選,設置網絡請求超時時間。默認為30秒。在僅設備模式下無效
    //可選,設置定位間隔。默認為2秒
    //可選,設置是否返回逆地理地址信息。默認是true
    //可選,設置是否單次定位。默認是false
    //可選,設置是否等待wifi刷新,默認為false.如果設置為true,會自動變為單次定位,持續定位時不要使用
    //可選, 設置網絡請求的協議。可選HTTP或者HTTPS。默認為HTTP
    //可選,設置是否使用傳感器。默認是false
    //可選,設置是否開啟wifi掃描。默認為true,如果設置為false會同時停止主動刷新,停止以后完全依賴于系統刷新,定位位置可能存在誤差
    //可選,設置是否使用緩存定位,默認為true
//可選,設置定位模式,可選的模式有高精度、僅設備、僅網絡。默認為高精度模式
    //可選,設置是否gps優先,只在高精度模式下有效。默認關閉

    //如果網絡可用就選擇高精度
    private val defaultOption: AMapLocationClientOption
        private get() {
            val mOption = AMapLocationClientOption()
            //如果網絡可用就選擇高精度
            if (NetworkUtils.isConnected()) { //可選,設置定位模式,可選的模式有高精度、僅設備、僅網絡。默認為高精度模式
                mOption.locationMode = AMapLocationClientOption.AMapLocationMode.Hight_Accuracy
                mOption.isGpsFirst = true //可選,設置是否gps優先,只在高精度模式下有效。默認關閉
            } else {
                mOption.locationMode = AMapLocationClientOption.AMapLocationMode.Device_Sensors //可選,設置定位模式,可選的模式有高精度、僅設備、僅網絡。默認為高精度模式
                mOption.isGpsFirst = true //可選,設置是否gps優先,只在高精度模式下有效。默認關閉
            }
            mOption.httpTimeOut = 30000 //可選,設置網絡請求超時時間。默認為30秒。在僅設備模式下無效
            mOption.interval = 2000 //可選,設置定位間隔。默認為2秒
            mOption.isNeedAddress = true //可選,設置是否返回逆地理地址信息。默認是true
            mOption.isOnceLocation = false //可選,設置是否單次定位。默認是false
            mOption.isOnceLocationLatest = false //可選,設置是否等待wifi刷新,默認為false.如果設置為true,會自動變為單次定位,持續定位時不要使用
            AMapLocationClientOption.setLocationProtocol(AMapLocationClientOption.AMapLocationProtocol.HTTP) //可選, 設置網絡請求的協議。可選HTTP或者HTTPS。默認為HTTP
            mOption.isSensorEnable = true //可選,設置是否使用傳感器。默認是false
            mOption.isWifiScan = true //可選,設置是否開啟wifi掃描。默認為true,如果設置為false會同時停止主動刷新,停止以后完全依賴于系統刷新,定位位置可能存在誤差
            mOption.isLocationCacheEnable = true //可選,設置是否使用緩存定位,默認為true
            return mOption
        }

    var locationListener = AMapLocationListener { location ->
        val sb = StringBuilder()
        if (null != location) { //errCode等于0代表定位成功,其他的為定位失敗,具體的可以參照官網定位錯誤碼說明
            if (location.errorCode == 0) {
                longitude = location.longitude
                latitude = location.latitude
                val district = location.district
                locationSuccess(longitude, latitude, true, location, district)
                //定位成功,停止定位:如果實時定位,就把stopLocation()關閉
                stopLocation()
            } else { //定位失敗
//                    sb.append("定位失敗" + "
");
//                    sb.append("錯誤碼:" + location.getErrorCode() + "
");
//                    sb.append("錯誤信息:" + location.getErrorInfo() + "
");
//                    sb.append("錯誤描述:" + location.getLocationDetail() + "
");
//                    Log.e("---> 定位失敗", sb.toString());
                LocationFarile(false, location)
            }
        } else {
            LocationFarile(false, location)
        }
    }

    private fun LocationFarile(isSucdess: Boolean, location: AMapLocation) {
        if (mOnCallBackListener != null) {
            mOnCallBackListener!!.onCallBack(0.0, 0.0, location, false, "")
        }
    }

    fun locationSuccess(longitude: Double, latitude: Double, isSucdess: Boolean, location: AMapLocation?, address: String?) {
        if (mOnCallBackListener != null) {
            mOnCallBackListener!!.onCallBack(longitude, latitude, location, true, address)
        }
    }

    fun setOnCallBackListener(listener: onCallBackListener?) {
        mOnCallBackListener = listener
    }

    interface onCallBackListener {
        fun onCallBack(longitude: Double, latitude: Double, location: AMapLocation?, isSucdess: Boolean, address: String?)
    }

    /**
     * 開始定位
     */
    fun startLocation() {
        locationClient!!.startLocation()
    }

    /**
     * 停止定位
     */
    fun stopLocation() {
        locationClient!!.stopLocation()
    }

    /**
     * 銷毀定位
     */
    fun destroyLocation() {
        if (null != locationClient) {
            /**
             * 如果AMapLocationClient是在當前Activity實例化的,
             * 在Activity的onDestroy中一定要執行AMapLocationClient的onDestroy
             */
            locationClient!!.onDestroy()
            locationClient = null
            locationOption = null
        }
    }

    companion object {
        var longitude = 0.0
        var latitude = 0.0
    }

}

關于“Android封裝高德地圖定位工具類Util的方法”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Android封裝高德地圖定位工具類Util的方法”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

永清县| 枣庄市| 万荣县| 谷城县| 越西县| 南乐县| 高唐县| 巩义市| 浑源县| 江孜县| 柘荣县| 太保市| 云梦县| 石台县| 安顺市| 屏东市| 龙南县| 梁河县| 甘肃省| 上杭县| 兴安县| 泸州市| 阜康市| 内丘县| 鹿泉市| 繁峙县| 宿松县| 永康市| 普兰店市| 九寨沟县| 蒲江县| 砀山县| 和田县| 红河县| 罗源县| 伊金霍洛旗| 南汇区| 邯郸市| 增城市| 巴彦淖尔市| 丹巴县|