ButterKnife的使用

在Android编程我们要使布局文件如TextView、Button、ImageView与代码关联起来就要使用到FindViewById这个方法,要为他们设置监听器的话就要setOnClickListener。虽然用起来很简单,但如果布局控件一旦多了起来就会感觉很重复麻烦不便以后的维护,常常会使我们分不清楚哪个控件才是我们想使用的。

使用ButtonKnife的优势
  1. 强大的View绑定和Click事件处理功能,简化代码,提升开发效率
  2. 方便的处理Adapter里的ViewHolder绑定问题
  3. 运行时不会影响APP效率,使用配置方便
  4. 代码清晰,可读性强
配置ButtonKnife

在app->build gradle中添加依赖

compile 'com.jakewharton:butterknife:(butterknife:7.0.1)'
annotationProcessor 'com.jakewharton:butterknife-compiler:(butterknife:7.0.1)'

点击按钮:Sync Projects with Gradle Files重新编译即可。

常见使用ButtonKnife的方法:

绑定view
    @Bind(R.id.tvTitle)
    TextView mTvTitle;

    @Bind(R.id.iv_avatar)
    ImageView mIvAvatar;

    @Bind(R.id.tv_author)
    TextView mTvAuthor;

    @Bind(R.id.tv_time)
    TextView mTvTime;

    @Bind(R.id.wv_content)
    WebView mWvContent;

之后View对象就可以直接使用了.
需要注意的是View变量声明的时候不能为private或者static.

绑定资源文件
@BindString(R.string.app_name)  
String appName;
@BindColor(R.color.red)  
int textColor;  
@BindDrawable(R.mipmap.ic_launcher)  
Drawable drawable;//drawble  
@Bind(R.id.imageview)  
ImageView mImageView;  
@Bind(R.id.checkbox)  
CheckBox mCheckBox;  
@BindDrawable(R.drawable.selector_image)  
Drawable selector;
@BindString(R.string.app_name)  
String appName;
@BindDrawable(R.mipmap.ic_launcher)  
Drawable drawable;
为View设置监听
@OnClick(R.id.iv_avatar)  
public void submit() {  
  // TODO submit data to server...  
} 

或者

@OnClick(R.id.iv_avatar)  
public void submit(View view) {  
  // TODO submit data to server...  
}

还可以批量为多个控件添加为同一个响应函数:

@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();
   }
   }
Fragment控件
public class FancyFragment extends Fragment {
  @BindView(R.id.button1) Button button1;
  @BindView(R.id.button2) Button button2;

  @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.fancy_fragment, container, false);
    ButterKnife.bind(this, view);
    // TODO Use fields...
    return view;
  }
}
优化ViewHolder
public class MyAdapter extends BaseAdapter {
  @Override public View getView(int position, View view, ViewGroup parent) {
    ViewHolder holder;
    if (view != null) {
      holder = (ViewHolder) view.getTag();
    } else {
      view = inflater.inflate(R.layout.whatever, parent, false);
      holder = new ViewHolder(view);
      view.setTag(holder);
    }

    holder.name.setText("helloworld");
    return view;
  }

  static class ViewHolder {
    @BindView(R.id.title) TextView name;
    @BindView(R.id.job_title) TextView jobTitle;

    public ViewHolder(View view) {
      ButterKnife.bind(this, view);
    }
  }
}

可以看到ViewHolder类加了一个带参数View的构造方法,用注解标记每个字段,再也不需要在getView()方法里调用findViewById()方法了。

控件的批量操作

ButterKnife中还有一个好玩的地方莫过于控件的批量操作,我们可以定义统一的行为,来设置给某一组控件,比如我想给我某一组的TextView修改背景颜色,可以定义如下行为:

ButterKnife.Action<View> CHANGECOLOR = new ButterKnife.Action<View>() {  
            @Override  
            public void apply(@NonNull View view, int index) {  
                view.setBackgroundColor(Color.RED);  
            }  
        }; 

使用方式如下:

ButterKnife.apply(textViews, CHANGECOLOR);  

其中textViews是一个TextView的集合。
如果你想给TextView设置不同的背景颜色,那么还可以这样来定义:

ButterKnife.Setter<View,List<Integer>> CHANGECOLOR2 = new ButterKnife.Setter<View, List<Integer>>() {  
            @Override  
            public void set(@NonNull View view, List<Integer> value, int index) {  
                view.setBackgroundColor(value.get(index));  
            }  
        };  

使用方式:

List<Integer> colors = new ArrayList<>();  
        colors.add(Color.RED);  
        colors.add(Color.GREEN);  
        colors.add(Color.BLUE);  
        ButterKnife.apply(textViews,CHANGECOLOR2,colors);  

注意

  1. ButtKnife初始化ButterKnife.bind(this)必须在加载布局资源之后(在setContentView(),Inflate等方法下面),所以ButterKnife不能在Application中初始化。
  2. ButtKnife在Fragment和Adapter中使用时,初始化代码有所不同,多了个参数VIew对象.ButterKnife.bind(this, mRootView);
  3. 使用ButterKnife设置控件点击事件,其方法权限必须在默认权限以上方可(包括默认权限)
    参考文献:http://jakewharton.github.io/butterknife/
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351

推荐阅读更多精彩内容