Fragment懒加载——最简方案(LazyBread)

GIF镇楼

效果图

框架引入

在项目根目录的build.gradle文件中添加

    allprojects {
        repositories {
            maven { url 'https://jitpack.io' }
        }
    }

app目录下的build.gradle文件中添加

dependencies {
        implementation 'com.github.Martin0207.LazyBread:core:v1.0.2'
        annotationProcessor 'com.github.Martin0207.LazyBread:processor:v1.0.2'
}

框架使用

public class TwoFragment extends Fragment {

    private static final String TAG = TwoFragment.class.getSimpleName();
    private TextView mTv;

    @Override
    public void setUserVisibleHint(boolean isVisibleToUser) {
        super.setUserVisibleHint(isVisibleToUser);
        /*
            手动监听Fragment的显隐
         */
        LazyBread.onUserVisibleHint(this, isVisibleToUser);
    }

    @Override
    public void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        /*
            绑定Fragment
            需要在onActivityCreated或之前调用
         */
        LazyBread.bind(this);
    }

    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View inflate = inflater.inflate(R.layout.normal_fragment, container, false);
        mTv = inflate.findViewById(R.id.tv);
        return inflate;
    }

    /**
     * 注解方法,实现懒加载
     */
    @LazyInit()
    public void lazy() {
        mTv.setText(TAG);
    }
}

逻辑图

逻辑图

框架优势

1.使用简单

如上图展示,仅需要简单的三步就可以实现Fragment的懒加载功能,并且不破坏原有代码。

2.支持懒加载方法排序

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface LazyInit {

    /**
     * 是否在每次Fragment对用户可见时都调用
     * 默认情况下,Fragment只需要调用一次初始化方法
     * @return 默认不重复
     */
    boolean isCycle() default false;

    /**
     * 优先值
     * 同一个Fragment中,若拥有多个方法被注解,
     * 则按照优先值由大到小的顺序调用
     * @return 默认为1
     */
    int priority() default 1;

}

如源码中展示,可以根据priority排列调用顺序。

3.支持方法重复调用

代码如上,我们可以设置被LazyInit注解的方法是否在每次触发时调用

4.支持Fragment多层嵌套

5.支持框架自动解绑

框架绑定有@LazyInit注解方法的Fragment时,会主动监听Fragment的生命周期,并且在onFragmentDestroyed时解除Fragment的绑定。当然也你也可以手动解除绑定。

结语

框架功能主要由Annotation和AnnotationProcessor来实现,实现方式与思路并不复杂,这里就不做源码分析了。如果有兴趣,可以来看下源码
上文没有太多文字描述内容,我主要还是喜欢在代码备注中表示内容,感觉更直接了当。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 请允许我借鉴前辈们的东西~~~~ 感激不尽~~~~~ 以下为Android 框架排行榜 么么哒~ Android...
    嗯_新阅读 2,147评论 3 32
  • Dagger2 转载请注明原作者,如果你觉得这篇文章对你有帮助或启发,可以关注打赏。 前言本文翻译自Google ...
    轻云时解被占用了阅读 6,748评论 4 31
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,145评论 1 32
  • spring官方文档:http://docs.spring.io/spring/docs/current/spri...
    牛马风情阅读 1,733评论 0 3
  • 这个村子挺大,总共230户人家。俗话说“林子大了,什么鸟都有”,这个村里也不太平。村里的几大家族,为了...
    飘尘多多阅读 636评论 1 7