ButterKnife框架使用可以方便我们不用写大量的重复繁琐的findViewById和setOnClickListener等代码,它采用依赖注入的方式,通过注解的方式让view和代码中的对象绑定起来。
GitHub地址:https://github.com/JakeWharton/butterknife
ButterKnife使用
添加依赖
由于8.0.0之后的版本和之前的版本有差异,这里主要是8.1.0最新版本的添加方法,注意两个步骤都要完成:
1.Project的build.gradle中添加:
1 | dependencies { |
2.App的build.gradle中添加:
1 | apply plugin: 'com.neenbedankt.android-apt' |
Activity中使用
1 | public class MainActivity extends AppCompatActivity { |
Activity中使用
注意:ButterKnife.bind(this)必须在setContentView之后。
Fragment中使用
1 | public class ListFragment extends Fragment{ |
由于Fragment的生命周期不同于Activity,当在CreateView方法中绑定视图时,需要在onDestoryView中把对应的视图设置为null,这时需要解绑ButterKnife。
ViewHolder中使用
1 | static class ViewHolder { |
事件监听绑定
1 | //点击事件 |
ps:方法中的参数是可选的,但如果存在,必须是这个控件类或者控件类的父类。
资源绑定
可以用@BindBool,@BindColor,@BindDimen,@BindDrawable,@BindInt和@BindString通过绑定R.bool以及其他对应id来进行资源的预定义。
1 | @BindString(R.string.title) String title; |
通过这种方式,就可以把资源直接赋值给变量,从而不再需要初始化。
可选绑定
默认情况下,@bind和监听器绑定都必须有一个目标view,当butter knife找不到对应的view时会抛出一个异常。为了防止这种异常情况的发生,可以在绑定的字段前面使用@Nullable注解,在绑定的方法前面则可使用@Option注解,来表明对应的是一个可选绑定。
注:任何名为@Nullable第三方的注解都可以对字段起作用,这里推荐使用Android的”support-annotations“ library提供的@Nullable注解。
1 | @Nullable @BindView(R.id.might_not_be_there) TextView mightNotBeThere; |
其他
butter knife也提供了一个findById方法,如果要在某些情况下查找某些子view,可以使用它来简化代码。
1 | View view = LayoutInflater.from(context).inflate(R.layout.thing, null); |
混淆
1 | -keep class butterknife.** { *; } |