Android学习中使用百度定位出现经度纬度:4.9E-324问题

Source

在学习第一行代码过程中,第十一章使用百度定位,在实现实时更新当前位置时,发现在首次定位能够成功获取经纬度,可是接下来出现的经纬度都是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:代表网络定位成功!!!!!!!!!!!!!!!!!!!!!!!
在这里插入图片描述