安卓基礎開發庫,讓開發簡單點。
DevRing & Demo地址:https://github.com/LJYcoder/DevRing
學習/參考地址:
http://www.lxweimin.com/p/9ad21e548b69
http://www.cnblogs.com/zhaoyanjun/p/6016341.html
前言
ButterKnife是一個資源綁定框架,它使用注解來進行資源綁定、監聽事件綁定的操作,可以幫我們省去findViewById、setXXXListener等繁瑣的代碼。使用方便,不影響性能(編譯時就生成相應文件),提高開發效率。
介紹
下面從 配置、使用、插件、混淆 這幾個部分來介紹。
1. 配置
在Module下的build.gradle中添加
//ButterKnife注入
compile 'com.jakewharton:butterknife:8.8.1'
annotationProcessor 'com.jakewharton:butterknife-compiler:8.8.1'
2. 使用
使用流程可以分成 設置資源綁定、設置監聽綁定、開啟綁定
2.1 設置資源綁定
2.1.1綁定視圖 @BindView( ) / @BindViews( )
- 使用@BindView( )綁定單個視圖
@BindView(R.id.rv_collect)
RecyclerView mRvCollect;
- 使用@BindViews( )綁定一組視圖
bindviews設置屬性
@BindViews({ R2.id.tv_name, R2.id.tv_age, R2.id.tv_introduce })
List<TextView> buttonList ;
另外,ButterKnife提供了apply方法,可對一組視圖進行操作。
1)對一組視圖進行操作(不傳值)
ButterKnife.apply(@NonNull List< T> list, @NonNull Action< ? super T> action)
@BindViews({ R2.id.tv_name, R2.id.tv_age, R2.id.tv_introduce })
List<TextView> listTv;
//統一把文字顏色設為紅色
ButterKnife.Action<TextView> SET_COLOR =new ButterKnife.Action<TextView>() {
@Override
public void apply(@NonNull TextView textView, int index) {
textView.setTextColor(Color.RED);
}
};
ButterKnife.apply(listTv, SET_COLOR);
2)對一組視圖進行操作(傳值)
ButterKnife.apply(@NonNull List<T> list, @NonNull Setter<? super T, V> setter, V value)
@BindViews({ R2.id.tv_name, R2.id.tv_age, R2.id.tv_introduce })
List<TextView> listTv;
List<String> listTitle= Arrays.asList(new String[]{"姓名","年齡","介紹"});
//按順序取出標題寫入TextView
ButterKnife.Setter<TextView, List<String>> SET_TEXT = new ButterKnife.Setter<TextView, List<String>>() {
@Override
public void set(@NonNull TextView textView, List<String> listTitle, int index) {
textView.setText(listTitle.get(index));
}
};
ButterKnife.apply(listTv, SET_TEXT, listTitle);
3)對一組視圖的Property屬性進行操作
ButterKnife.apply(listTv, View.ALPHA, 0.3f);
2.1.2 綁定字符串 @BindString( ) / @BindArray( )
- 使用BindString( )綁定單個字符串資源
@BindString(R.string.tip)
String tip;
- 使用@BindArray( )綁定一組字符串資源
@BindArray(R.array.tips)
String[] tips ;
2.1.3 綁定顏色值 @BindColor( )
@BindColor(R.color.theme)
int themeColor;
2.1.4 綁定圖片 @BindBitmap( )
@BindBitmap(R.mipmap.ic_launcher)
Bitmap appLogo ;
2.1.5 注意
- 使用注解聲明的資源變量,不能用private或static修飾,否則會保錯。
- 當指定資源id對應的View找不到時,會拋出異常,可以加多個@Nullable注解來聲明變量,以防止崩潰(建議使用Android注解庫“support-annotations”中的@Nullable)
2.2 設置監聽綁定
定義一個方法,用相關注解進行監聽事件的綁定,
2.2.1 點擊事件 @OnClick( )
@OnClick(R.id.btn1)
public void show1(){
Toast.makeText(this, "onClick", Toast.LENGTH_SHORT).show();
}
2.2.2 長按事件 @OnLongClick( )
@OnLongClick(R.id.btn2)
public void show2(){
Toast.makeText(this, "onLongClick", Toast.LENGTH_SHORT).show();
}
2.2.3 多個控件綁定一個事件
以onclick事件舉例。
方法可以定義適當的參數,它將會被自動轉化。
@OnClick( {R.id.btn1, R.id.btn2, R.id.btn3, R.id.btn4} )
public void onViewClicked(View view) {
switch (view.getId()) {
case R.id.btn1:
Toast.makeText(this, "onclick1", Toast.LENGTH_SHORT).show();
break;
case R.id.btn2:
Toast.makeText(this, "onclick2", Toast.LENGTH_SHORT).show();
break;
case R.id.btn3:
Toast.makeText(this, "onclick3", Toast.LENGTH_SHORT).show();
break;
case R.id.btn4:
Toast.makeText(this, "onclick4", Toast.LENGTH_SHORT).show();
break;
}
}
2.2.4 其他事件
除了點擊事件和長按事件,ButterKnife還提供了很多點擊事件,比如
@OnCheckedChanged(),
@OnEditorAction(),
@OnFocusChange(),
@OnItemClick(),
@OnItemLongClick(),
@OnItemSelected(),
@OnPageChange() 等
2.2.5 注意
- 使用注解聲明的監聽方法,不能用private或static修飾,否則會保錯。
- 當指定資源id對應的View找不到時,會拋出異常,可以加多個@Optional注解來聲明方法,以防止崩潰
2.3 開啟綁定
設置完資源綁定和監聽事件綁定后,需要通過ButterKnife.bind()方法開啟綁定,調用該方法后,對應的資源和監聽事件就會開始進行注入綁定。
2.3.1 在Activity中開啟綁定
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//在setContentView后調用
ButterKnife.bind(this);
}
2.3.2 在Fragment中開啟綁定
在Fragment中開啟綁定后,需要在視圖銷毀時進行解綁操作。
private Unbinder unbinder;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment, container, false);
//返回Unbinder值用于解綁
//這里調用的方法與Activity調用的有區別
unbinder = ButterKnife.bind(this, view);
return view;
}
@Override
public void onDestroyView() {
super.onDestroyView();
//解綁
unbinder.unbind();
}
2.3.3 在ViewHolder中開啟綁定
使用列表控件時,常常用到ViewHolder,可以通過以下方式進行綁定
//來自http://www.lxweimin.com/p/9ad21e548b69
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("John Doe");
// etc...
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);
}
}
}
3. 插件
zelezny插件可以快速自動生成ButterKnife綁定相關的代碼。
1.先通過Android Studio ---> Setting---> Plugins ---> Browse Responsitories ---> 搜索zelezny并下載,下載后請重啟Android Studio。
2.右鍵R.layout.xxxx,點擊Generate--->Generate ButterKnife Injections,選擇目標View,即可生成相應的代碼。
4. 混淆
在proguard-rules.pro文件中添加以下內容進行混淆配置
#butterknife開始
-keep class butterknife.** { *; }
-dontwarn butterknife.internal.**
-keep class **$$ViewBinder { *; }
-keepclasseswithmembernames class * { @butterknife.* <fields>;}
-keepclasseswithmembernames class * { @butterknife.* <methods>;}
#butterknife結束