在学习第一行代码过程中,第十一章使用百度定位,在实现实时更新当前位置时,发现在首次定位能够成功获取经纬度,可是接下来出现的经纬度都是4.9E-324,也就是默认值,说明获取位置失败,头痛。下面我们一步一步查找原因。
首先贴上帅气的关键代码:
public void onReceiveLocation(BDLocation location) {
runOnUiThread(new Runnable() {
@Override
public void run() {
StringBuilder currentPosition=new StringBuilder();
currentPosition.append("纬度:").append(location.getLatitude()).append("\n");
currentPosition.append("经度:").append(location.getLongitude()).append("\n");
currentPosition.append("定位方式:");
Log.d("MainActivity", "???"+location.getLocType());
if(location.getLocType()==BDLocation.TypeGpsLocation){
currentPosition.append("GPS");
}else if(location.getLocType()==BDLocation.TypeNetWorkLocation){
currentPosition.append("网络");
}
positionText.setText(currentPosition);
}
});
}
在这个代码中,我增加了那么一个log.d日志:
Log.d("MainActivity", "???"+location.getLocType());
从下面的logcat查看日志,发现
location.getLocType()只有刚启动app时返回一个161,也就是网络定位结果成功,之后就都是505。
下面我贴上百度地图开放平台的定位错误返回码链接,一目了然。
定位错误返回码: 点我.
505 AK不存在或者非法 请按照说明文档重新申请AK ???这是啥情况呢?
一直问度娘,太笨,依旧搜不出结果QAQ
之后,我再看看run中调试运行的结果,发现有这么个东东:
Error errorcode = 230 , msg = {"status":230,"message":"APP Mcode码校验失败","user_permission":0,"ak_permission":0}
Nice!!!
这个一查就查到了。
查看到我自己创建的jks的SHA1值,他是发布版的。
而我正在调试使用的jks打包的apk,他是调试版本,他们两个的SHA1值不一样!!!
下面是调试版本debug-keystore:打开命令行→找到 .android 文件夹→输入如下:
这样我们就能获得调试版的SHA1安全码了。
然后我们将SHA1码复制,进入百度地图开发平台的控制台。
点击设置,把刚才复制的SHA1安全码重新填入,点击提交。
然后重新运行,观察真机上的纬度经度变化和日志变化。
161:代表网络定位成功!!!!!!!!!!!!!!!!!!!!!!!