ButterKnife的使用

在Android編程我們要使布局文件如TextView葵姥、Button遗座、ImageView與代碼關(guān)聯(lián)起來就要使用到FindViewById這個方法舞丛,要為他們設(shè)置監(jiān)聽器的話就要setOnClickListener撒踪。雖然用起來很簡單偷俭,但如果布局控件一旦多了起來就會感覺很重復(fù)麻煩不便以后的維護(hù)走贪,常常會使我們分不清楚哪個控件才是我們想使用的佛猛。

使用ButtonKnife的優(yōu)勢
  1. 強(qiáng)大的View綁定和Click事件處理功能,簡化代碼坠狡,提升開發(fā)效率
  2. 方便的處理Adapter里的ViewHolder綁定問題
  3. 運(yùn)行時不會影響APP效率继找,使用配置方便
  4. 代碼清晰,可讀性強(qiáng)
配置ButtonKnife

在app->build gradle中添加依賴

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

點(diǎn)擊按鈕: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設(shè)置監(jiān)聽
@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...  
}

還可以批量為多個控件添加為同一個響應(yīng)函數(shù):

@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;
  }
}
優(yōu)化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類加了一個帶參數(shù)View的構(gòu)造方法,用注解標(biāo)記每個字段,再也不需要在getView()方法里調(diào)用findViewById()方法了码荔。

控件的批量操作

ButterKnife中還有一個好玩的地方莫過于控件的批量操作,我們可以定義統(tǒng)一的行為感挥,來設(shè)置給某一組控件缩搅,比如我想給我某一組的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設(shè)置不同的背景顏色硼瓣,那么還可以這樣來定義:

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中使用時置谦,初始化代碼有所不同,多了個參數(shù)VIew對象.ButterKnife.bind(this, mRootView);
  3. 使用ButterKnife設(shè)置控件點(diǎn)擊事件,其方法權(quán)限必須在默認(rèn)權(quán)限以上方可(包括默認(rèn)權(quán)限)
    參考文獻(xiàn):http://jakewharton.github.io/butterknife/
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末堂鲤,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子媒峡,更是在濱河造成了極大的恐慌瘟栖,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,430評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件谅阿,死亡現(xiàn)場離奇詭異半哟,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)签餐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,406評論 3 398
  • 文/潘曉璐 我一進(jìn)店門寓涨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人氯檐,你說我怎么就攤上這事戒良。” “怎么了冠摄?”我有些...
    開封第一講書人閱讀 167,834評論 0 360
  • 文/不壞的土叔 我叫張陵糯崎,是天一觀的道長几缭。 經(jīng)常有香客問我,道長拇颅,這世上最難降的妖魔是什么奏司? 我笑而不...
    開封第一講書人閱讀 59,543評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮樟插,結(jié)果婚禮上韵洋,老公的妹妹穿的比我還像新娘。我一直安慰自己黄锤,他們只是感情好搪缨,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,547評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著鸵熟,像睡著了一般副编。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上流强,一...
    開封第一講書人閱讀 52,196評論 1 308
  • 那天痹届,我揣著相機(jī)與錄音,去河邊找鬼打月。 笑死队腐,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的奏篙。 我是一名探鬼主播柴淘,決...
    沈念sama閱讀 40,776評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼秘通!你這毒婦竟也來了为严?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,671評論 0 276
  • 序言:老撾萬榮一對情侶失蹤肺稀,失蹤者是張志新(化名)和其女友劉穎第股,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體话原,經(jīng)...
    沈念sama閱讀 46,221評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡炸茧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,303評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了稿静。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,444評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡辕狰,死狀恐怖改备,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情蔓倍,我是刑警寧澤悬钳,帶...
    沈念sama閱讀 36,134評論 5 350
  • 正文 年R本政府宣布盐捷,位于F島的核電站,受9級特大地震影響默勾,放射性物質(zhì)發(fā)生泄漏碉渡。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,810評論 3 333
  • 文/蒙蒙 一母剥、第九天 我趴在偏房一處隱蔽的房頂上張望滞诺。 院中可真熱鬧,春花似錦环疼、人聲如沸习霹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,285評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽淋叶。三九已至,卻和暖如春伪阶,著一層夾襖步出監(jiān)牢的瞬間煞檩,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,399評論 1 272
  • 我被黑心中介騙來泰國打工栅贴, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留斟湃,地道東北人。 一個月前我還...
    沈念sama閱讀 48,837評論 3 376
  • 正文 我出身青樓筹误,卻偏偏與公主長得像桐早,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子厨剪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,455評論 2 359

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