有个产品集成了百度地图,之前用的好好的,最近发现在某些手机上发生了黑屏现象,通过查看log发现是发生了ANR,而且trace信息里只能找到baidu相关的so信息。这是咋回事呢。但是logcat打印信息可以发现问题所在的activity。
/ActivityManager: ANR in com.test.test(com.test.test/com.test.android.activities.MainTabActivity_)
PID: 7835
Reason: Input dispatching timed out (ActivityRecord{9dae631 u0 com.test.test/com.test.android.activities.MainTabActivity_ t147} does not have a focused window)
Parent: com.test.test/com.test.android.activities.MainTabActivity_
发现肯定是在MainTabActivity_页面中,因为从地图跳转到别的页面后返回就会发生问题。但并不是每次都出现。这也奇怪了。 有时候动一下地图,再点击跳转别的页面就没事。有时候即使动了地图依然有问题。看来是卡在了MainTabActivity_的resume方法了,有些内容没有初始化完,比较耗时。造成点击返回键后无法展示MainTabActivity_页面。系统报ANR了。 因为MainTabActivity_是包含了几个fragment,地图是在其中一个fragment中显示的,先排查是不是其它页面造成的。于是移除了其它fragmet,只加载地图的。发现依然有问题。看来就是map的问题了。 后来发现当时原来为了懒加载fragment,在地图页面增加了懒加载的处理
@Override
public void setUserVisibleHint(boolean isVisibleToUser) {
super.setUserVisibleHint(isVisibleToUser);
if (getUserVisibleHint()) {
onVisible();
} else {
onInvisible();
}
}
地图init的方法放在了onVisible方法中。乍一看挺好的,app打开是显示的是另一个页面,map也并不是第一个显示。当点击切换到地图页面时,才初始化地图。实现懒加载的目的了。但是实际上这个init方法只要fragment可见就会执行一次。这违背了我们的初衷。为什么原来app用的好好的,现在却不行了呢。发现发生问题的都是Android11的手机。应该是Android11对ANR的更严格了。对APP性能要求更高了。 于是增加了相关判断,将initmap方法只执行一次。ANR问题解决了。
这里再说一个别的问题,百度地图SDK7.4.0已经支持gradle引用了,我试用了一下。发现会有个URLEncoder类找不到,虽然map好像能正常使用,但是这个发版的测试能认真点么?换回aar方式。就不报错了。还是先用aar方式吧。
还有个问题,就是添加Marker后,不能自动显示,要拖动下map才能显示。查看api文档也没发现有刷新地图的方法。后来我就用如下方法先解决了。
mBaiduMapStatus = new MapStatus.Builder().target(mBaiduMap.getMapStatus().target).zoom(mBaiduMap.getMapStatus().zoom).build();
mBaiduMap.animateMapStatus(MapStatusUpdateFactory.newMapStatus(mBaiduMapStatus));
设置地图的mapStatus为当前的mapStatus。强制刷新一下就显示了。先这样解决吧。如果你有更好的方法,还请赐教。
|