onHiddenChanged这个方法可以用来在切换Fragment的时候,进行一些即时的操作(如改变后要刷新、保存等)。拿共享Fragment的数据来说,轻量级的东西可以通过局部变量来设置getter and setter,然后在另一个fragment中通过manager获取另一个fragment的实例(都被add进去了),但比较繁琐的数据可能需要保存到文本或者懒加载的时候,这个方法就派上用场了。
复写这个方法的时候,可以获得一个布尔值参数 isHidden,这个文档说得很清楚了,不加赘述。 需要注意的是,这个方法会先调用被show的fragment的onHiddenChanged,再顺序调用hide起来的fragment的onHiddenChanged。则在上文讲到的保存文本的应用环境中,如果你是在被展示的fragment中复写读取,被隐藏的fragment中复写保存,就会发生先读取后保存的bug。
第二个要注意的是,非第一个显示出来的fragment们,虽然onCreateView没有被调用,但是onHiddenChanged也会被调用,所以如果你尝试去获取活动的话,注意防止出现空指针。
最后要注意,这个方法仅在以FragmentManager中进行hide或者show某个fragment的形式切换时候会被调用。其他方式的切换可以使用setUserVisibleHint来代替。
文档注释:
/**
* Called when the hidden state (as returned by {@link #isHidden()} of
* the fragment has changed. Fragments start out not hidden; this will
* be called whenever the fragment changes state from that.
* @param hidden True if the fragment is now hidden, false if it is not
* visible.
*/