Fragment的真正显示

Fragment的真正显示_第1张图片
依旧是经典的ViewPager+Fragment的应用场景!
轮播图我是依靠Handler发消息实现的,现在,我的需求是,当用户滑动到Pager_02或者Pager_03的时候,Handler停止发消息,当用户回来的时候,继续发消息。
两个重点:
1.什么时候用户已经离开了
2.什么时候用户又回来了
如果要准确的把我上述两个点,要结合ViewPager的缓存机制进行理解。
左边+当前页+右边,如果在最左边,则只缓存右边,在最右边,同理。
a.从Pager_01跳到Pager_02
Pager_01的onStop()方法不会执行,我们拿不到任何的回调方法什么的,完全不能知道用户进行了该操作,这是非常可怕的。
试试这个方法吧setUserVisibleHint(boolean isVisibleToUser).经过鄙人的实验证明,该方法执行了,此时,isVisibleToUser为false。
b. 从Pager_02跳到Pager_03
Pager_01的onStop(),onDestoryView()方法执行(这也表明,当我们再回到Pager_01的时候,必须执行onCreateView()方法了)。
c. 从Page_03跳到Pager_02
Pager_01整个生命周期方法都执行了,但是他并没有显示给用户,注意-上面我们提到的setUserVisibleHint()也执行了,且该方法在onCreateView()执行之前.加入我们在Pager_01的onResume()方法中开启轮播,是不明智的,因为,用户看不到嘛?
d.从Pager_02跳到Pager_01
Pager_01仅仅执行了setUserVisibleHint()方法。所以,我们可以在该方法中开启轮播。

这里需要注意的一个问题是,setUserVisibleHint()方法在onCreateView()方法之前。
场景:
从Pager_01跳到Pager_03,然后直接跳回Pager_01,如果我们直接在setUserVisibleHint()中开始轮播,此时视图还没有创建出来,有些操作是我们不能进行的,还得在onResume()中执行,只需要加上判断getUserVisibleHint()即可。
打完收工!

你可能感兴趣的:(Fragment的真正显示)