在网上搜索过大量集成高德地图的方案,和测试代码,要么就是博主抄来没有测试过的代码,要么就是步骤不连续的,甚至包裹官网给出的解决方案都是欠缺相关步骤的(官网截图都不知道多少年前的了,没更新过),不断碰碰磕磕地试错,结合大量的博客的步骤,自己亲测实现了集成高德地址sdk并使用来获取app的定位地址。
一、新建空项目
这个自行百度,so easy,绝对不会出错的。
二、高德地图申请key
1.高德官网:https://lbs.amap.com/
步骤流程:依次进入-》控制台-》应用管理-》创建新应用-》添加新key
2.填写信息
key名称随意写,无关要紧
发布版本安全码SHA1请看下一步
3.查看包名
如果在新建安卓项目的时候忘记包名,可以通过AndroidManifest.xml文件来查看
4.安全码的获取
4.1 首先需要在Android Studio上生成jks密钥,可以参考这个博客https://blog.csdn.net/yy13003...,靠谱亲测无误。
但是温馨提醒一下,来到以下截图的步骤时,请记住这些信息(或者跟我一样截图记录):
key store path路径 和 Password密码,以及 Alias 别名和Password密码,
这几个信息在后面需要代码配置时用上的,这个细节甚至在高德官网都没有给出任何提示给步骤,在这我也卡了很久。
4.2 在确保已经生成了jks密钥后,通过Android Studio打开Treminal终端输入:
keytool -v -list -keystore xxxx.jks(jks的路径)
第三步就是你的安全SHA1码
三、集成高德SDK
1. 下载jar包
官网地址:http://lbs.amap.com/api/andro...
下载解压放置lis目录中,在这特别注意需要添加进入环境变量中(很多博客不说明,对于我这小白太坑了)
添加jar包入环境变量:右键jar包-》Add As Library...(详情操作参考:https://blog.csdn.net/s499820...)
2.配置build.gradle
这个配置很多博客都没有提到的,很坑爹。之后在后面排查问题才搜索到这个博客说明,可以参考(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...
1. 配置
官网示例配置: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>
2.测试代码
在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打印获取到的定位信息:
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。