电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

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

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

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

第一步、去官網(wǎng)創(chuàng)建高德Key

官網(wǎng)地址:lbs.amap.com/product/loc…

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

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

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

Android studio代碼獲取SHA1值

調(diào)用 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’第三步 配置參數(shù)

第1步,配置AndroidManifest.xml

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

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

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

<!--用于進行網(wǎng)絡定位--><uses-permission android:name='android.permission.ACCESS_COARSE_LOCATION'></uses-permission> <!--用于訪問GPS定位--> <uses-permission android:name='android.permission.ACCESS_FINE_LOCATION'></uses-permission><!--用于獲取運營商信息,用于支持提供運營商信息相關(guān)的接口--> <uses-permission android:name='android.permission.ACCESS_NETWORK_STATE'></uses-permission><!--用于訪問wifi網(wǎng)絡信息,wifi信息會用于進行網(wǎng)絡定位--><uses-permission android:name='android.permission.ACCESS_WIFI_STATE'></uses-permission><!--用于獲取wifi的獲取權(quán)限,wifi信息會用來進行網(wǎng)絡定位--><uses-permission android:name='android.permission.CHANGE_WIFI_STATE'></uses-permission><!--用于訪問網(wǎng)絡,網(wǎng)絡定位需要上網(wǎng)--><uses-permission android:name='android.permission.INTERNET'></uses-permission><!--用于讀取手機當前的狀態(tài)--><uses-permission android:name='android.permission.READ_PHONE_STATE'></uses-permission><!--用于寫入緩存數(shù)據(jù)到擴展存儲卡--><uses-permission android:name='android.permission.WRITE_EXTERNAL_STORAGE'></uses-permission> <!--用于申請調(diào)用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'>//開發(fā)者申請的key </meta-data>第四步 獲取定位數(shù)據(jù)

在需要獲取經(jīng)緯度的頁面調(diào)用如下代碼:

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()} }

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

/** * * 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//設置定位參數(shù)locationClient!!.setLocationOption(locationOption)// 設置定位監(jiān)聽locationClient!!.setLocationListener(locationListener) }//可選,設置定位模式,可選的模式有高精度、僅設備、僅網(wǎng)絡。默認為高精度模式 //可選,設置是否gps優(yōu)先,只在高精度模式下有效。默認關(guān)閉 //可選,設置網(wǎng)絡請求超時時間。默認為30秒。在僅設備模式下無效 //可選,設置定位間隔。默認為2秒 //可選,設置是否返回逆地理地址信息。默認是true //可選,設置是否單次定位。默認是false //可選,設置是否等待wifi刷新,默認為false.如果設置為true,會自動變?yōu)閱未味ㄎ唬掷m(xù)定位時不要使用 //可選, 設置網(wǎng)絡請求的協(xié)議。可選HTTP或者HTTPS。默認為HTTP //可選,設置是否使用傳感器。默認是false //可選,設置是否開啟wifi掃描。默認為true,如果設置為false會同時停止主動刷新,停止以后完全依賴于系統(tǒng)刷新,定位位置可能存在誤差 //可選,設置是否使用緩存定位,默認為true//可選,設置定位模式,可選的模式有高精度、僅設備、僅網(wǎng)絡。默認為高精度模式 //可選,設置是否gps優(yōu)先,只在高精度模式下有效。默認關(guān)閉 //如果網(wǎng)絡可用就選擇高精度 private val defaultOption: AMapLocationClientOptionprivate get() { val mOption = AMapLocationClientOption() //如果網(wǎng)絡可用就選擇高精度 if (NetworkUtils.isConnected()) { //可選,設置定位模式,可選的模式有高精度、僅設備、僅網(wǎng)絡。默認為高精度模式mOption.locationMode = AMapLocationClientOption.AMapLocationMode.Hight_AccuracymOption.isGpsFirst = true //可選,設置是否gps優(yōu)先,只在高精度模式下有效。默認關(guān)閉 } else {mOption.locationMode = AMapLocationClientOption.AMapLocationMode.Device_Sensors //可選,設置定位模式,可選的模式有高精度、僅設備、僅網(wǎng)絡。默認為高精度模式mOption.isGpsFirst = true //可選,設置是否gps優(yōu)先,只在高精度模式下有效。默認關(guān)閉 } mOption.httpTimeOut = 30000 //可選,設置網(wǎng)絡請求超時時間。默認為30秒。在僅設備模式下無效 mOption.interval = 2000 //可選,設置定位間隔。默認為2秒 mOption.isNeedAddress = true //可選,設置是否返回逆地理地址信息。默認是true mOption.isOnceLocation = false //可選,設置是否單次定位。默認是false mOption.isOnceLocationLatest = false //可選,設置是否等待wifi刷新,默認為false.如果設置為true,會自動變?yōu)閱未味ㄎ唬掷m(xù)定位時不要使用 AMapLocationClientOption.setLocationProtocol(AMapLocationClientOption.AMapLocationProtocol.HTTP) //可選, 設置網(wǎng)絡請求的協(xié)議。可選HTTP或者HTTPS。默認為HTTP mOption.isSensorEnable = true //可選,設置是否使用傳感器。默認是false mOption.isWifiScan = true //可選,設置是否開啟wifi掃描。默認為true,如果設置為false會同時停止主動刷新,停止以后完全依賴于系統(tǒng)刷新,定位位置可能存在誤差 mOption.isLocationCacheEnable = true //可選,設置是否使用緩存定位,默認為true return mOption} var locationListener = AMapLocationListener { location ->val sb = StringBuilder()if (null != location) { //errCode等于0代表定位成功,其他的為定位失敗,具體的可以參照官網(wǎng)定位錯誤碼說明 if (location.errorCode == 0) {longitude = location.longitudelatitude = location.latitudeval district = location.districtlocationSuccess(longitude, latitude, true, location, district)//定位成功,停止定位:如果實時定位,就把stopLocation()關(guān)閉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中一定要執(zhí)行AMapLocationClient的onDestroy */ locationClient!!.onDestroy() locationClient = null locationOption = null} } companion object {var longitude = 0.0var latitude = 0.0 }}總結(jié)

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

標簽: 高德 地圖
相關(guān)文章:
主站蜘蛛池模板: 铸钢件厂家-铸钢齿轮-减速机厂家-淄博凯振机械有限公司 | 冷油器,取样冷却器,热力除氧器-连云港振辉机械设备有限公司 | 西安中国国际旅行社(西安国旅) | 涿州网站建设_网站设计_网站制作_做网站_固安良言多米网络公司 | 油罐车_加油机_加油卷盘_加油机卷盘_罐车人孔盖_各类球阀_海底阀等车用配件厂家-湖北华特专用设备有限公司 | 浙江寺庙设计-杭州寺院设计-宁波寺庙规划_汉匠 | 上海赞永| 南京租车,南京汽车租赁,南京包车,南京会议租车-南京七熹租车 | 电缆接头_防水接头_电缆防水接头 - 乐清市新豪电气有限公司 | 代理记账_公司起名核名_公司注册_工商注册-睿婕实业有限公司 | 消泡剂_水处理消泡剂_切削液消泡剂_涂料消泡剂_有机硅消泡剂_广州中万新材料生产厂家 | 珠海白蚁防治_珠海灭鼠_珠海杀虫灭鼠_珠海灭蟑螂_珠海酒店消杀_珠海工厂杀虫灭鼠_立净虫控防治服务有限公司 | 模具硅橡胶,人体硅胶,移印硅胶浆厂家-宏图硅胶科技 | 河南中整光饰机械有限公司-抛光机,去毛刺抛光机,精密镜面抛光机,全自动抛光机械设备 | 合肥宠物店装修_合肥宠物美容院装修_合肥宠物医院设计装修公司-安徽盛世和居装饰 | 合肥汽车充电桩_安徽充电桩_电动交流充电桩厂家_安徽科帝新能源科技有限公司 | 护栏打桩机-打桩机厂家-恒新重工| 磁粉制动器|张力控制器|气胀轴|伺服纠偏控制器整套厂家--台灵机电官网 | 黑龙江京科脑康医院-哈尔滨精神病医院哪家好_哈尔滨精神科医院排名_黑龙江精神心理病专科医院 | 免费网站网址收录网_海企优网站推荐平台 | 儿童乐园|游乐场|淘气堡招商加盟|室内儿童游乐园配套设备|生产厂家|开心哈乐儿童乐园 | 土壤墒情监测站_土壤墒情监测仪_土壤墒情监测系统_管式土壤墒情站-山东风途物联网 | 连续密炼机_双转子连续密炼机_连续式密炼机-南京永睿机械制造有限公司 | 高精度电阻回路测试仪-回路直流电阻测试仪-武汉特高压电力科技有限公司 | 实验室pH计|电导率仪|溶解氧测定仪|离子浓度计|多参数水质分析仪|pH电极-上海般特仪器有限公司 | 东莞动力锂电池保护板_BMS智能软件保护板_锂电池主动均衡保护板-东莞市倡芯电子科技有限公司 | 防水套管厂家-柔性防水套管-不锈钢|刚性防水套管-天翔管道 | 校园气象站_超声波气象站_农业气象站_雨量监测站_风途科技 | GEDORE扭力螺丝刀-GORDON防静电刷-CHEMTRONICS吸锡线-上海卓君电子有限公司 | 3d可视化建模_三维展示_产品3d互动数字营销_三维动画制作_3D虚拟商城 【商迪3D】三维展示服务商 广东健伦体育发展有限公司-体育工程配套及销售运动器材的体育用品服务商 | 臻知网大型互动问答社区-你的问题将在这里得到解答!-无锡据风网络科技有限公司 | 数控专用机床,专用机床,自动线,组合机床,动力头,自动化加工生产线,江苏海鑫机床有限公司 | 成都装修公司-成都装修设计公司推荐-成都朗煜装饰公司 | 祝融环境-地源热泵多恒系统高新技术企业,舒适生活环境缔造者! | PCB厂|线路板厂|深圳线路板厂|软硬结合板厂|电路板生产厂家|线路板|深圳电路板厂家|铝基板厂家|深联电路-专业生产PCB研发制造 | 圆形振动筛_圆筛_旋振筛_三次元振动筛-河南新乡德诚生产厂家 | 无硅导热垫片-碳纤维导热垫片-导热相变材料厂家-东莞市盛元新材料科技有限公司 | 臭氧灭菌箱-油桶加热箱-原料桶加热融化烘箱-南京腾阳干燥设备厂 臭氧发生器_臭氧消毒机 - 【同林品牌 实力厂家】 | 电销卡_稳定企业大语音卡-归属地可选-世纪通信| 叉车电池-叉车电瓶-叉车蓄电池-铅酸蓄电池-电动叉车蓄电池生产厂家 | 打孔器,打孔钳厂家【温州新星德牌五金工具】 |