ButterKnife基本使用

ButterKnife框架使用可以方便我們不用寫大量的重復(fù)繁瑣的findViewById和setOnClickListener等代碼,它采用依賴注入的方式,通過注解的方式讓view和代碼中的對象綁定起來。

logo.png

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

ButterKnife使用

  • 添加依賴

由于8.0.0之后的版本和之前的版本有差異,這里主要是8.1.0最新版本的添加方法,注意兩個步驟都要完成:

1.Project的build.gradle中添加:
    dependencies { 
        classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
    }
2.App的build.gradle中添加:
    apply plugin: 'com.neenbedankt.android-apt'

    dependencies {
        compile 'com.jakewharton:butterknife:8.1.0'
        apt 'com.jakewharton:butterknife-compiler:8.1.0'
    }
  • Activity中使用

      public class MainActivity extends AppCompatActivity {
          @BindView(R.id.title_tv) TextView titleTv;
          @BindView(R.id.back_btn) Button backBtn;
          @BindView(R.id.logo_img) ImageView logoImg;
          
          @Override 
          public void onCreate(Bundle savedInstanceState) {
              super.onCreate(savedInstanceState);
              setContentView(R.layout.activity_main);
              ButterKnife.bind(this);
          }
      }
    

注意:ButterKnife.bind(this)必須在setContentView之后。

  • Fragment中使用

      public class ListFragment extends Fragment{
          @BindView(R.id.title_tv) TextView titleTv;
          @BindView(R.id.listview) ListView listView;
          private Unbinder unbinder;
          @Override 
          public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
              View view = inflater.inflate(R.layout.fragment_list, container, false);
              unbinder = ButterKnife.bind(this, view);
              return view;
          }
          @Override
          public void onDestroyView() {    
              super.onDestroyView();    
              unbinder.unbind();
          }
      }
    

由于Fragment的生命周期不同于Activity,當在CreateView方法中綁定視圖時,需要在onDestoryView中把對應(yīng)的視圖設(shè)置為null,這時需要解綁ButterKnife。

  • ViewHolder中使用

      static class ViewHolder {
          @BindView(R.id.name_tv) TextView nameTv;
          @BindView(R.id.content_tv) TextView contentTv;
          @BindView(R.id.head_img) ImageView headImg;
    
          public ViewHolder(View view) {
              ButterKnife.bind(this, view);
          }
      }
    
  • 事件監(jiān)聽綁定

      //點擊事件
      @OnClick(R.id.submit)
      public void buttonClick(Button button){
          //TODO ...
      }
    
      //listview item點擊事件
      @OnItemClick(R.id.listview)
      public void itemClick(ListView listView){
          //TODO ...
      }
    
      //多個控件具有相同的點擊事件
      @OnClick({ R.id.btn1, R.id.btn2, R.id.btn3 })
      public void buttonsClick(Button button){
          //TODO ...
      }
    

ps:方法中的參數(shù)是可選的,但如果存在,必須是這個控件類或者控件類的父類。

  • 資源綁定

可以用@BindBool,@BindColor,@BindDimen,@BindDrawable,@BindInt和@BindString通過綁定R.bool以及其他對應(yīng)id來進行資源的預(yù)定義。
@BindString(R.string.title) String title;
@BindDrawable(R.drawable.graphic) Drawable graphic;
@BindColor(R.color.red) int red;
@BindDimen(R.dimen.spacer) Float spacer;
//...
通過這種方式,就可以把資源直接賦值給變量,從而不再需要初始化。

  • 可選綁定

默認情況下,@bind和監(jiān)聽器綁定都必須有一個目標view,當butter knife找不到對應(yīng)的view時會拋出一個異常。為了防止這種異常情況的發(fā)生,可以在綁定的字段前面使用@Nullable注解,在綁定的方法前面則可使用@Option注解,來表明對應(yīng)的是一個可選綁定。

注:任何名為@Nullable第三方的注解都可以對字段起作用,這里推薦使用Android的”support-annotations“ library提供的@Nullable注解。
@Nullable @BindView(R.id.might_not_be_there) TextView mightNotBeThere;
@Optional @OnClick(R.id.maybe_missing)
void onMaybeMissingClicked() {
// TODO ...
}

  • 其他

butter knife也提供了一個findById方法,如果要在某些情況下查找某些子view,可以使用它來簡化代碼。
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);

  • 混淆

    -keep class butterknife.** { *; }
    -dontwarn butterknife.internal.**
    -keep class **$$ViewBinder { *; }
    -keepclasseswithmembernames class * {
        @butterknife.* <fields>;
    }
    -keepclasseswithmembernames class * {
        @butterknife.* <methods>;
    }
    

參考資料

官方文檔:https://jakewharton.github.io/butterknife/

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,156評論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,401評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,069評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,873評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,635評論 6 408
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,128評論 1 323
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,203評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,365評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,881評論 1 334
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,733評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,935評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,475評論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,172評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,582評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,821評論 1 282
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,595評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,908評論 2 372

推薦閱讀更多精彩內(nèi)容