Butter Knife使用详解

Posted Tyhoo Wu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Butter Knife使用详解相关的知识,希望对你有一定的参考价值。

转载请注明出处:http://www.cnblogs.com/cnwutianhao/p/6610529.html 

 

Butter Knife

Github地址: https://github.com/JakeWharton/butterknife

官方说明给出的解释是 Bind android views and callbacks to fields and methods. 

Field and method binding for Android views which uses annotation processing to generate boilerplate code for you.

  • Eliminate findViewById calls by using @BindView on fields.
  • Group multiple views in a list or array. Operate on all of them at once with actions, setters, or properties.
  • Eliminate anonymous inner-classes for listeners by annotating methods with @OnClick and others.
  • Eliminate resource lookups by using resource annotations on fields.

意思就是:将Android视图和回调绑定到字段和方法。使用注释处理为您生成样板代码的Android视图的字段和方法绑定。通过在字段上使用@BindView消除findViewById调用。在列表或数组中分组多个视图。 使用操作,设置器或属性一次操作所有这些。通过使用@OnClick和其他方法注释方法,消除匿名内部类的侦听器。通过在字段上使用资源注释来消除资源查找。

 

官方文档给出了Butter Knife在Gradle里面如何配置

 

下面我们就来配置Buffer Knife到工程里面

新建Android Studio工程(作者的Android Studio版本是2.3)

项目主体结构如下:

首先,配置build.gradle(Project:XXX)

新建工程的build.gradle(Project:XXX)初始样子如下:

然后我们按照官方文档进行配置

在repositories {}里面添加

mavenCentral()

在dependencies {}里面添加

classpath \'com.jakewharton:butterknife-gradle-plugin:8.5.1\'

build.gradle(Project:XXX)完整代码即:

// Top-level build file where you can add configuration options common to all sub-projects/modules.

buildscript {
    repositories {
        jcenter()
        mavenCentral()
    }
    dependencies {
        classpath \'com.android.tools.build:gradle:2.3.0\'
        classpath \'com.jakewharton:butterknife-gradle-plugin:8.5.1\'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        jcenter()
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

其次,修改build.gradle(Module:XXX)

新建工程的build.gradle(Module:XXX)初始样子如下:

然后我们按照官方文档进行配置

在开头添加
apply plugin: \'com.jakewharton.butterknife\'
在dependencies {} 里面添加 
compile \'com.jakewharton:butterknife:8.5.1\'
annotationProcessor \'com.jakewharton:butterknife-compiler:8.5.1\'
build.gradle(Module:XXX)完整代码即:
apply plugin: \'com.android.application\'
apply plugin: \'com.jakewharton.butterknife\'

android {
    compileSdkVersion 25
    buildToolsVersion "25.0.2"
    defaultConfig {
        applicationId "com.tnnowu.android.butterknifedemo"
        minSdkVersion 14
        targetSdkVersion 25
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile(\'proguard-android.txt\'), \'proguard-rules.pro\'
        }
    }
}

dependencies {
    compile fileTree(dir: \'libs\', include: [\'*.jar\'])
    androidTestCompile(\'com.android.support.test.espresso:espresso-core:2.2.2\', {
        exclude group: \'com.android.support\', module: \'support-annotations\'
    })
    compile \'com.android.support:appcompat-v7:25.3.0\'
    compile \'com.android.support.constraint:constraint-layout:1.0.2\'
    testCompile \'junit:junit:4.12\'

    compile \'com.jakewharton:butterknife:8.5.1\'
    annotationProcessor \'com.jakewharton:butterknife-compiler:8.5.1\'
}
至此,我们的Butter Knife就已经正确的配置到我们的工程里面了。
彩蛋:
做过安卓项目的同学都知道,比如工程里面的get、set 方法,都是通过Generate快速编译的。(说到这里如果你没看懂的话,说明你的Android开发经验太少了,请自行百度查找)

又有同学问了,我在Github上面看到大神们用Butter Knife去编写代码,初始化的时候总是蒙圈。其实 Butter Knife的初衷就是简化代码,让程序员更有效率的开发。

这时候可以利用Android Studio里面的 Plugins来辅助我们开发。

File -> Settings -> Plguins

然后在右面的搜索框里面输入 ButterKnife,然后点击下面的 Search in repositories

就会出现下图的场景:

选择第一个 Android ButterKnife PPlugin Plus 然后点击 Install,重启Android Studio

重启之后,Butter Knife就可以很好的为我们效劳了。

 

那么Butter Knife如何使用呢?

首先,打开布局文件

Android Studio更新到2.3以后的布局文件初始是这样的

为了做演示,我们稍微修改一下,添加几个控件。

一个EditText,两个Button

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context="com.tnnowu.android.butterknifedemo.MainActivity">

    <EditText
        android:id="@+id/edit_text"
        android:layout_width="match_parent"
        android:layout_height="50dp" />

    <Button
        android:id="@+id/btn1"
        android:layout_width="match_parent"
        android:layout_height="50dp" />

    <Button
        android:id="@+id/btn2"
        android:layout_width="match_parent"
        android:layout_height="50dp" />

</LinearLayout>

然后,我到Class类里面去用 Butter Knife绑定控件,代替 findViewById

初始Class类文件如下:

在布局文件上面右键,选择Generate

然后选择 Generate Butterknife Injections

这里我们可以看到布局文件中的控件都出现在上面,可以额外选择点击事件OnClick

 

Confirm之后的场景如下:

package com.tnnowu.android.butterknifedemo;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;

import butterknife.BindView;
import butterknife.ButterKnife;
import butterknife.OnClick;

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

    @BindView(R.id.edit_text)
    EditText editText;
    @BindView(R.id.btn1)
    Button btn1;
    @BindView(R.id.btn2)
    Button btn2;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        ButterKnife.bind(this);
    }

    @OnClick({R.id.btn1, R.id.btn2})
    public void onClick(View view) {
        switch (view.getId()) {
            case R.id.btn1:
                break;
            case R.id.btn2:
                break;
        }
    }
}

可以清晰的看到 Butter Knife 已经开始为我们效劳了。

(注意:ButterKnife.bind(this) 是一定要写在onCreate里面)

学会使用 BUffer Knife,可以让程序自动化帮忙减轻工作量!

 

关注我的新浪微博,获取更多Android开发资讯!

关注科技评论家,领略科技、创新、教育以及最大化人类智慧与想象力!

以上是关于Butter Knife使用详解的主要内容,如果未能解决你的问题,请参考以下文章

[轉]Android Libraries 介紹 - Butter knife

Android框架式编程之BufferKnife

butterknife

w3school

SpringBoot使用拦截器和swagger(knife4j)配置

SpringBoot使用拦截器和swagger(knife4j)配置