Joanna.Yan 阅读(137) 评论(0)

最近在项目中遇到一个奇葩问题,花了很长时间,在这里记录下。

问题描述:我的主界面是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的设备运行没有问题,难道是版本问题?但是真不知从何下手。

思路三:在百度地图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);
        }
    };