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