Square全家桶正传——偷懒神器ButterKnife及其附属插件的使用

写作原因:程序员喜欢偷懒,对于安卓程序员来说,把时间花在不用动脑筋的findViewById()上简直让人难以忍受。此外大量的点击监听事件的分散化使得代码可读性下降。于是,基于注解的ButterKnife应运而生。

参考链接:

ButterKnife官网:http://jakewharton.github.io/butterknife/

ButterKnife GitHub地址:https://github.com/JakeWharton/butterknife

ButterKnife-Zelezny地址:https://github.com/avast/android-butterknife-zelezny


简介

先来看看ButterKnife有哪些功能吧,官网上是这样描述的:

  1. 通过使用@BindView来消除调用findViewById();
  2. 可以把多个View放在一个数组或者list中。然后一次性可以同时对这些View的动作,属性等进行操作;
  3. 通过使用@OnClick注解来消除由监听器带来的匿名内部类;
  4. 通过对resource进行注解来消除多余的资源查找代码。

获取ButterKnife:

  1. 在你的项目的build.gradle中加入以下依赖:
buildscript {
  repositories {
    mavenCentral()
   }
  dependencies {
    classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
  }
}
  1. 在你的Module的build.gradle中加入以下依赖:
apply plugin: 'android-apt'

android {
  ...
}

dependencies {
  compile 'com.jakewharton:butterknife:8.1.0'
  apt 'com.jakewharton:butterknife-compiler:8.1.0'
}

注意:apply plugin: 'android-apt'

基本使用

下面的代码演示了ButterKnife的基本使用技巧:

class ExampleActivity extends Activity {
  @BindView(R.id.user) EditText username;
  @BindView(R.id.pass) EditText password;

  @BindString(R.string.login_error) String loginErrorMessage;

  @OnClick(R.id.submit) void submit() {
    // TODO call server...
  }

  @Override public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.simple_activity);
    ButterKnife.bind(this);
    // TODO Use fields...
  }
}

包括以下几个步骤:

1.定义UnBinder对象,对待操作元素进行注解:

定义:private UnBinder unBinder;

对View:@BindView(R.id.user) EditText username;

对Resource:@BindString(R.string.login_error) String loginErrorMessage;

(注:资源绑定有以下注解:@BindBool, @BindColor, @BindDimen, @BindDrawable, @BindInt, @BindString)

对监听事件:

@OnClick(R.id.submit) void submit() {
  // TODO call server...
}

2.在onCreate方法或者onCreateView方法中调用方法:

unBinder = ButterKnife.bind(this);//如果在Fragment中使用ButterKnife.bind(this,view);

3.在onDestory方法或者onDestoryView中解除绑定:

unBinder = ButterKnife.unbind();

进阶操作:

1.利用ViewList实现同时配置多个View:

①. 将多个View绑定到一个List中:

@BindViews({ R.id.first_name, R.id.middle_name, R.id.last_name })
List nameViews;

②. 调用ButterKnife.apply()方法:

ButterKnife.apply(nameViews, DISABLE);
ButterKnife.apply(nameViews, ENABLED, false);
ButterKnife.apply(nameViews, View.ALPHA, 0.0f);

按照官网的思路,上面三行分别是对nameViews中所有View的action,Setter和Property的设置,但是仅仅调用了apply()方法并不能真正修改nameViews中的View,必须完成下一步工作。

③. 实现接口:

static final ButterKnife.Action DISABLE = new ButterKnife.Action() {
  @Override public void apply(View view, int index) {
    view.setEnabled(false);
  }
};
static final ButterKnife.Setter ENABLED = new ButterKnife.Setter() {
  @Override public void set(View view, Boolean value, int index) {
    view.setEnabled(value);
  }
};

上面代码已经将action和Setter实现,重写接口内部方法apply或set,在内部实现对nameViews的操作。这样就完成了同时操作多个View的功能。

2. 利用形参直接对当前View进行操作

@OnClick(R.id.submit)
public void sayHi(Button button) {
  button.setText("Hello!");
}

3. 实现多View点击事件的关联(原理同2)

@OnClick({ R.id.door1, R.id.door2, R.id.door3 })
public void pickDoor(DoorView door) {
  if (door.hasPrizeBehind()) {
    Toast.makeText(this, "You win!", LENGTH_SHORT).show();
  } else {
    Toast.makeText(this, "Try again", LENGTH_SHORT).show();
  }
}

4.防止目标View不存在出现exception的请况的发生

@Nullable @BindView(R.id.might_not_be_there) TextView mightNotBeThere;

@Optional @OnClick(R.id.maybe_missing) void onMaybeMissingClicked() {
  // TODO ...
}

通过使用@Nullable或者@Optional实现防止因为目标View不存在出现exception的请况的发生。

5. 代替onItemClickListener的注解实现

@OnItemSelected(R.id.list_view)
void onItemSelected(int position) {
  // TODO ...
}

6. 通过LayoutInflater获取View的ButterKnife实现方法findById:

View view = LayoutInflater.from(context).inflate(R.layout.thing, null);
TextView firstName = ButterKnife.findById(view, R.id.first_name);
TextView lastName = ButterKnife.findById(view, R.id.last_name);
ImageView photo = ButterKnife.findById(view, R.id.photo);

注:这个真没觉得哪里简单了。。。

到此我们讲完了ButterKnife的基本使用。怎样不错吧?下面有更强大的东西——ButterKnifeZelezny,配合着这个神器一起使用,可以为我们的项目节省大量时间和增加代码可读性。

ButterKnifeZelezny

下载地址:

http://plugins.jetbrains.com/plugin/7369

关于AS安装插件的问题在这里不多阐述了,不会的自行百度。

基本用法

下面这幅图展示了ButterKnifeZelezny的基本用法。


bkz

基本步骤:

  1. 有所使用的布局 ID 上点击右键 (例如上图中的 R.layout.activity_settings ), 然后选择 Generate -> Generate ButterKnife Injections
  2. 在对话框中选择需要注入的 View, 还有个选项可以给 Adapter 创建一个 ViewHolder。
  3. 点击 Confirm , 代码自动生成!

总结:

本文只是关于ButterKnife用法的介绍,关于Java中的依赖注解的知识博主仍在学习中,有兴趣参照《Java编程思想》一书关于Annotation的介绍,此外欢迎继续关注博主的Square全家桶系列。

你可能感兴趣的:(Square全家桶正传——偷懒神器ButterKnife及其附属插件的使用)