人走丿茶凉 2019-06-28
在网上搜索过大量集成高德地图的方案,和测试代码,要么就是博主抄来没有测试过的代码,要么就是步骤不连续的,甚至包裹官网给出的解决方案都是欠缺相关步骤的(官网截图都不知道多少年前的了,没更新过),不断碰碰磕磕地试错,结合大量的博客的步骤,自己亲测实现了集成高德地址sdk并使用来获取app的定位地址。
这个自行百度,so easy,绝对不会出错的。
步骤流程:依次进入-》控制台-》应用管理-》创建新应用-》添加新key
key名称随意写,无关要紧
发布版本安全码SHA1请看下一步
如果在新建安卓项目的时候忘记包名,可以通过AndroidManifest.xml文件来查看
但是温馨提醒一下,来到以下截图的步骤时,请记住这些信息(或者跟我一样截图记录):
key store path路径 和 Password密码,以及 Alias 别名和Password密码,
这几个信息在后面需要代码配置时用上的,这个细节甚至在高德官网都没有给出任何提示给步骤,在这我也卡了很久。
keytool -v -list -keystore xxxx.jks(jks的路径)
第三步就是你的安全SHA1码
官网地址:http://lbs.amap.com/api/andro...
下载解压放置lis目录中,在这特别注意需要添加进入环境变量中(很多博客不说明,对于我这小白太坑了)
添加jar包入环境变量:右键jar包-》Add As Library...(详情操作参考:https://blog.csdn.net/s499820...)
这个配置很多博客都没有提到的,很坑爹。之后在后面排查问题才搜索到这个博客说明,可以参考(https://blog.csdn.net/zrf1335...)
这里的四个信息storeFile file/storePassword/keyAlias/keyPassword就对应上面在成功jks时的四个信息了
signingConfigs { //调试版的keystore debug { storeFile file("/Users/dfp/AndroidStudioProjects/demoProj/demoproj.jks") storePassword "123456" keyAlias "demoproj" keyPassword "123456" } //发布版的keystore release { storeFile file("/Users/dfp/AndroidStudioProjects/demoProj/demoproj.jks") storePassword "123456" keyAlias "demoproj" keyPassword "123456" } }
这里代码可以参考博客https://blog.csdn.net/code_be...
官网示例配置:https://lbs.amap.com/api/andr...
官网示例截图,需要注意的是,<meta-data android:name="com.amap.api.v2.apikey" android:value="您的key"></meta-data>,value值里面需要添加你在上面第二步骤生气的key
我的完整配置示例
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.dfp.demoproj"> <uses-permission android:name="android.permission.INTERNET" /> <!--用于进行网络定位--> <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> <!--用于申请获取蓝牙信息进行室内定位--> <uses-permission android:name="android.permission.BLUETOOTH"></uses-permission> <uses-permission android:name="android.permission.BLUETOOTH_ADMIN"></uses-permission> <application android:networkSecurityConfig="@xml/network_security_config" android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:theme="@style/AppTheme"> <meta-data android:name="com.amap.api.v2.apikey" android:value="XXXXXXXXXX"></meta-data> <service android:name="com.amap.api.location.APSService"></service> <activity android:name=".MainActivity"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <service android:name=".LongRunningService"> </service> <receiver android:name=".AlarmReceiver"> </receiver> </application> </manifest>
在MainActivity.java上照搬别人的测试代码即可,官方案例我是在不会用
我抄的代码示例
package com.example.dfp.demoproj; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.util.Log; import com.amap.api.location.AMapLocation; import com.amap.api.location.AMapLocationClient; import com.amap.api.location.AMapLocationClientOption; import com.amap.api.location.AMapLocationListener; public class MainActivity extends AppCompatActivity { //声明AMapLocationClient类对象 public AMapLocationClient mLocationClient = null; //声明定位回调监听器 public AMapLocationListener mLocationListener = new MyAMapLocationListener(); //声明AMapLocationClientOption对象 public AMapLocationClientOption mLocationOption = null; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); init(); } private void init() { //初始化定位 mLocationClient = new AMapLocationClient(getApplicationContext()); //设置定位回调监听 mLocationClient.setLocationListener(mLocationListener); //初始化AMapLocationClientOption对象 mLocationOption = new AMapLocationClientOption(); //设置定位模式为AMapLocationMode.Hight_Accuracy,高精度模式。 mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy); //获取一次定位结果: //该方法默认为false。 mLocationOption.setOnceLocation(false); //获取最近3s内精度最高的一次定位结果: //设置setOnceLocationLatest(boolean b)接口为true,启动定位时SDK会返回最近3s内精度最高的一次定位结果。如果设置其为true,setOnceLocation(boolean b)接口也会被设置为true,反之不会,默认为false。 mLocationOption.setOnceLocationLatest(true); //设置是否返回地址信息(默认返回地址信息) mLocationOption.setNeedAddress(true); //设置是否允许模拟位置,默认为false,不允许模拟位置 mLocationOption.setMockEnable(false); //关闭缓存机制 mLocationOption.setLocationCacheEnable(false); //给定位客户端对象设置定位参数 mLocationClient.setLocationOption(mLocationOption); //启动定位 mLocationClient.startLocation(); } private class MyAMapLocationListener implements AMapLocationListener { @Override public void onLocationChanged(AMapLocation aMapLocation) { if (aMapLocation != null) { if (aMapLocation.getErrorCode() == 0) { Log.e("位置:", aMapLocation.getAddress()); } else { //定位失败时,可通过ErrCode(错误码)信息来确定失败的原因,errInfo是错误信息,详见错误码表。 Log.e("AmapError", "location Error, ErrCode:" + aMapLocation.getErrorCode() + ", errInfo:" + aMapLocation.getErrorInfo()); } } } } }
运行你的代码在虚拟机(最好的真实机,我用得就是真实机测试)
Android Studio打印获取到的定位信息: