最近在项目中遇到一个奇葩问题,花了很长时间,在这里记录下。
问题描述:我的主界面是ViewPager+Fragment,并且设置缓存了我的4个ViewPager页面。左侧是一个侧滑菜单,点击相应按钮打开不同的Activity。右边的大片区域用的是FrameLayout将自定义地图和百度地图叠加全屏显示。左下角有一个按钮用于切换自定义地图和百度地图的显示,其实就是MapView的visibility="gone"和visibility="visible"的操作。简单画了下效果图:
问题来了,我进入该主界面,只要我点击btn进行地图显示的切换过,也就是说百度地图曾经显示过(visible),当我再打开其他activity,Back键返回到该Fragment时,百度地图就显示了,下面的按钮btn也被遮盖掉了,无论我之前是否将它隐藏(gone)掉过。在两个真机Android4.4的设备上运行没有这个情况,在其他Android4.0,4.1的设备上有这个问题,但是将gone换成invisible也不会有这个问题,但是这样的话就达不到我想要的效果了。
解决:
思路一:打印从进入到该Fragment,点击按钮,打开activity,back键返回该Fragment这一过程的log:
在onStop()中记住百度地图的显示状态(控件MapView),在onResume()中根据保存的值去控制百度地图的显示,获取到的值是正确的,但是控制MapView隐藏的代码却没有效果。
思路二:前面说过的4.4的设备运行没有问题,难道是版本问题?虽说gone,是让控件不占空间,但是这并不是问题的关键,真不知从何下手。
思路三:在百度地图Android API上找到问题原因,这应该是百度地图自身的一个bug(以后还是得细看文档啊)
但是即使知道了这个问题,还是不能完美的解决我的问题,最后我的onResume()中延迟了较短的时间,再将百度地图(MapView)隐藏或者显示。
@Override
public void onResume() {
mMapView.setVisibility(View.VISIBLE);
// MapView的生命周期与Activity同步,当activity恢复时需调用MapView.onResume()
mMapView.onResume();
super.onResume();
Log.i("yanqiong", "onResume===="+remBaiduMap);
baiduMapHandler.postDelayed(baiduMapRunnable, 900);
}
Handler baiduMapHandler=new Handler();
Runnable baiduMapRunnable=new Runnable() {
@Override
public void run() {
if(isShowBaiduMap){
webView.setVisibility(View.GONE);
mMapView.setVisibility(View.VISIBLE);
}else{
webView.setVisibility(View.VISIBLE);
mMapView.setVisibility(View.GONE);
}
baiduMapHandler.removeCallbacks(this);
}
};