在项目根目录的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);
}
}
如上图展示,仅需要简单的三步就可以实现Fragment的懒加载功能,并且不破坏原有代码。
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface LazyInit {
/**
* 是否在每次Fragment对用户可见时都调用
* 默认情况下,Fragment只需要调用一次初始化方法
* @return 默认不重复
*/
boolean isCycle() default false;
/**
* 优先值
* 同一个Fragment中,若拥有多个方法被注解,
* 则按照优先值由大到小的顺序调用
* @return 默认为1
*/
int priority() default 1;
}
如源码中展示,可以根据priority
排列调用顺序。
代码如上,我们可以设置被LazyInit注解的方法是否在每次触发时调用
框架绑定有@LazyInit注解方法的Fragment时,会主动监听Fragment的生命周期,并且在onFragmentDestroyed
时解除Fragment的绑定。当然也你也可以手动解除绑定。
框架功能主要由Annotation和AnnotationProcessor来实现,实现方式与思路并不复杂,这里就不做源码分析了。如果有兴趣,可以来看下源码 上文没有太多文字描述内容,我主要还是喜欢在代码备注中表示内容,感觉更直接了当。