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

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


另一篇:Android注解神器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中加入以下依赖:

    1
    2
    3
    4
    5
    6
    7
    8
    buildscript {
    repositories {
    mavenCentral()
    }
    dependencies {
    classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
    }
    }
  2. 在你的Module的build.gradle中加入以下依赖:

1
2
3
4
5
6
7
8
9
10
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的基本使用技巧:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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)

对监听事件:

1
2
3
@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中:

1
2
@BindViews({ R.id.first_name, R.id.middle_name, R.id.last_name })
List<EditText> nameViews;

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

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

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

③. 实现接口:

1
2
3
4
5
6
7
8
9
10
static final ButterKnife.Action<View> DISABLE = new ButterKnife.Action<View>() {
@Override public void apply(View view, int index) {
view.setEnabled(false);
}
};
static final ButterKnife.Setter<View, Boolean> ENABLED = new ButterKnife.Setter<View, Boolean>() {
@Override public void set(View view, Boolean value, int index) {
view.setEnabled(value);
}
};

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

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

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

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

1
2
3
4
5
6
7
8
@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的请况的发生

1
2
3
4
5
@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的注解实现

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

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

1
2
3
4
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全家桶系列。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值