一直不愿意在这里写博客,一个重要的原因就是csdn的博客系统做的不是一般的烂,各种文章提交后丢失、提交不成功的问题搞得人心烦。
上周接到获取客户端经纬度的需求。附带条件就是这个获取的时间不能太长,也就是几秒之内。
基于以上考虑,直接考虑调用:
locationManager.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 0, 0, new LocationListener())
经过反复测试,这个方法在网络状况良好并且GPS打开的情况下,1秒之内足以获取经纬度数据。
但是在引入项目使用的时候,遇到过下面几个问题:
1、开始为了不阻塞主线程,将这个方法放到了子线程,调试的时候发现怎么都获取不到经纬度,并且也不走LocationListener里面的回调。原因就是这个方法只能在主线程调用;
2、考虑到网络不好的时候获取经纬度数据可能会慢一些,准备设定一个获取的时间上限,逻辑是这样的:获取经纬度后立即上报,如果超过3秒还未获取,则停止获取,默认经纬度数值为空。调试的时候才发现计划很美好,现实很残酷,因为数据是系统回调函数传过来的,你根本不知道它什么时候被调用,也就无法判断是不是超过3秒;而如果采用直接在回调的时候运行后面的逻辑,会有造成主线程阻塞的风险。最后采取了一个折中的方法,在获取经纬度之后执行后面的逻辑之前,让线程睡3秒,3秒后回调函数有数据就取没数据就置为空。
上面第一个问题,其实折腾了不少时间,百度也查不到原因,最后是反复对比了项目代码和demo代码后发现的。也许现在的开发同学大部分都不自己获取经纬度而是直接调用百度高德API了。包括后面根据经纬度来获取位置信息,也遇到了坑,开始是用Geocoder类去获取,在安卓6.0上没问题,在安卓7.0上就不行了,后来改调用谷歌地图的服务去解析出来地名,感觉也不是很可靠,因为它这个jsonarray的大小不是固定的,目前已经有2种,总共有多少种还不得而知。