日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Android封裝高德地圖定位工具類Util的詳細步驟

瀏覽:197日期:2022-06-03 14:59:30
目錄前提第一步、去官網創建高德Key第二步 通過Gradle集成SDK(方便):第三步 配置參數第四步 獲取定位數據總結前提

每次做的項目中或者維護公司之前舊項目的時候,都會用到通過定位來獲取經緯度,我們都知道,Android官方也提供了獲取經緯度的方法,但是不太好使,所以就用了高德地圖的API,不能每次用的時候都要寫一堆代碼,效率挺低的,于是就想著,封裝成一個工具類,方便調用,為以后的項目,不管是管理方面還是查找方面都簡潔了不少。

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

官網地址:lbs.amap.com/product/loc…

Android封裝高德地圖定位工具類Util的詳細步驟

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 + 'n' + 'latitude' + latitude + 'n' + 'isSucdess' + isSucdess + 'n' + 'address' + address); //Log.e('--->',location.getProvince()+ 'n' +location.getCity()+'n'+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() { //初始化clientif (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: AMapLocationClientOptionprivate get() { val mOption = AMapLocationClientOption() //如果網絡可用就選擇高精度 if (NetworkUtils.isConnected()) { //可選,設置定位模式,可選的模式有高精度、僅設備、僅網絡。默認為高精度模式mOption.locationMode = AMapLocationClientOption.AMapLocationMode.Hight_AccuracymOption.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.longitudelatitude = location.latitudeval district = location.districtlocationSuccess(longitude, latitude, true, location, district)//定位成功,停止定位:如果實時定位,就把stopLocation()關閉stopLocation() } else { //定位失敗// sb.append('定位失敗' + 'n');// sb.append('錯誤碼:' + location.getErrorCode() + 'n');// sb.append('錯誤信息:' + location.getErrorInfo() + 'n');// sb.append('錯誤描述:' + location.getLocationDetail() + 'n');// 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.0var latitude = 0.0 }}總結

到此這篇關于Android封裝高德地圖定位工具類Util的文章就介紹到這了,更多相關Android封裝高德定位工具類內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: 高德 地圖
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久精品国产99国产精品| 日韩av一区二区三区| 美女毛片一区二区三区四区最新中文字幕亚洲 | 日韩中文字幕无砖| 亚州av日韩av| 欧美精品国产| 精品一区二区三区中文字幕视频 | 色综合视频一区二区三区日韩| 亚洲最大av| 国产精品一区2区3区| 成人午夜网址| 日韩在线欧美| 日韩一区二区久久| 综合视频一区| 国产精品啊v在线| 日韩亚洲一区在线| 免费观看在线综合| 免费在线欧美黄色| 久久久久.com| 免费成人在线观看| 免费一级欧美片在线观看网站| 国产成人精品999在线观看| 欧美/亚洲一区| 亚洲日本在线观看视频| 国产精品jk白丝蜜臀av小说| av在线资源| 亚洲黄色影院| 欧美日韩伊人| 欧美一级精品| 亚洲精品美女| av资源亚洲| 亚洲欧洲专区| 精品日韩在线| 亚洲一区欧美| 日本欧美不卡| 欧美中文高清| 香蕉久久精品| 国产亚洲欧美日韩精品一区二区三区 | 里番精品3d一二三区| 日韩久久精品| 一区二区三区网站| 国产不卡av一区二区| 蜜臀av国产精品久久久久| 久久永久免费| 亚洲深深色噜噜狠狠爱网站 | 日本一区二区三区视频在线看 | 91精品视频一区二区| 久久婷婷激情| 国产精品久久久一区二区| 欧美69视频| 精品视频高潮| 天海翼精品一区二区三区| 天堂av在线| 国产精品久一| 综合激情在线| 性欧美xxxx免费岛国不卡电影| 国产精品久久久久久久免费软件| 日韩欧美自拍| 国产精品4hu.www| 亚洲男人在线| 好吊一区二区三区| 中文在线а√天堂| 国产精品欧美大片| 日韩精品一区二区三区中文在线 | 亚洲激情国产| 国产精品成久久久久| 日韩黄色av| 婷婷成人基地| 韩日一区二区| 国产精品v亚洲精品v日韩精品| 综合激情视频| 国产精品日本欧美一区二区三区| 97精品国产福利一区二区三区| 日韩av中文字幕一区二区三区| 日韩视频一区| 久久国产毛片| 精精国产xxxx视频在线野外| 国产成人1区| 国产一区丝袜| 精品一区视频| 免费在线观看一区| 麻豆精品在线| 国产精品一区免费在线| 日本视频一区二区| 视频国产精品| 亚洲精品一二| 自拍自偷一区二区三区| 亚洲女人av| 视频一区二区三区在线| 久久国产高清| 亚洲免费婷婷| 中文不卡在线| 日本不卡的三区四区五区| 亚洲日产av中文字幕| 亚州av日韩av| 91成人福利| 国产亚洲高清一区| 国产黄色精品| 国产精品久久久久久久久久久久久久久 | 日本欧美大码aⅴ在线播放| 亚洲精品乱码| 7777精品| 国产精品视频首页| 欧美精品不卡| 国产一区二区三区成人欧美日韩在线观看| 久久精品免视看国产成人| 国产在视频一区二区三区吞精| 最新中文字幕在线播放| 91精品国产福利在线观看麻豆| 欧美日韩在线网站| 亚洲一区国产| 深夜日韩欧美| 国产精品**亚洲精品| 最新中文字幕在线播放| 久久精品亚洲欧美日韩精品中文字幕| 久久精品成人| 久久午夜精品| 欧美精品影院| 成人黄色av| 亚洲视频播放| 国产精品丝袜在线播放| 日韩精品dvd| 蜜臀av国产精品久久久久| 国产精品一二| 成人日韩在线| 在线视频亚洲欧美中文| 国产精品蜜月aⅴ在线| 日韩一区自拍| 日韩专区一卡二卡| 国产精品a级| 欧美日韩一区二区综合| 中文字幕日韩欧美精品高清在线| 国产免费播放一区二区| 黑人精品一区| 亚洲香蕉久久| 91青青国产在线观看精品| 尤物在线精品| 国产精品激情| 午夜久久免费观看| 久久国际精品| 免费视频国产一区| 国产精品探花在线观看| 精品欧美激情在线观看| 国产亚洲精品美女久久久久久久久久| 日韩三区免费| 久久精品99国产国产精| 日韩在线短视频| 亚洲精品一级二级三级| 成人在线黄色| 亚洲三区欧美一区国产二区| 精品国产一区二区三区av片| 在线一区视频| 久久久久久夜| 青青草精品视频| 欧美精品激情| 国产66精品| 97久久亚洲| 欧美日韩国产精品一区二区亚洲| 国产精品久久久久久久久久妞妞| 夜久久久久久| 国产一二在线播放| 欧美在线91| 99视频一区| 国产成人精品免费视| 日韩三级一区| 精品欧美激情在线观看| 91欧美日韩| 国产精品视频一区二区三区| 先锋影音久久久| 亚洲成人国产| 国产精品麻豆久久| 国产精品网址| 亚洲毛片在线| 99亚洲视频| 亚洲日本网址| 久久精品国产网站| 69精品国产久热在线观看| 在线亚洲自拍| 久久精品播放| 日韩精品中文字幕第1页| 国产精品乱战久久久| 自拍自偷一区二区三区| 国产一区导航| 91久久中文| japanese国产精品| 中文在线中文资源| 精品久久91| 国产精品99精品一区二区三区∴| 色狠狠一区二区三区| 老牛影视一区二区三区| 欧美在线亚洲综合一区| 99久久夜色精品国产亚洲狼| 国产专区精品| 国产精品tv| 国产精品午夜av| 国产精品久久久久久av公交车| 日本午夜精品久久久| 日韩av不卡在线观看| 欧美精品观看| 国产免费av国片精品草莓男男|