瞅瞅AS3.6新增ViewBinding
目錄
- 基本使用
- 查看ViewBinding實現(xiàn)方式
- include陵刹,merge,viewstub的配合使用
開啟流程
- 首先更新AS到3.6版本
- 打開module的gradle文件
- 在android函數(shù)里面添加如下代碼,這樣就開啟完成了
android {
//...
viewBinding.enabled = true
}
使用
- 默認情況下布局XML文件都會生成一個 XXXBinding 類
- 如有不需要生成Binding類的禁炒,可在跟布局添加屬性 tools:viewBindingIgnore="true"如:
<FrameLayout
tools:viewBindingIgnore="true">
</FrameLayout>
- 接著就可以在Activity里面進行使用 XXXBinding 類,該類提供了三個初始化函數(shù)
fun inflate(inflater: LayoutInflater): XXXBinding
fun inflate(inflater: LayoutInflater, parent: ViewGroup, attachToParent: boolean): XXXBinding
fun bind(view: View): XXXBinding
- 初始化后,可通過返回的XXXBinding類的getRoot函數(shù)獲取布局的跟View锈颗,再通過setContentView添加到Activity
- XXXBinding實例的成員變量是以布局文件里View的ID來命名
- 附加兩個例子圖
以上就是基礎(chǔ)用法
看看ViewBinding為我們做了什么
- 打開生成的XXXBinding類,文件路徑為: {module_path}/build/generated/data_binding_base_class_source_out/debug/out/cc/xiaobaicz/test/databinding/XXXBinding.java
- 看看實現(xiàn)咪惠,比較簡單的實現(xiàn)击吱, 主要邏輯 在于bind函數(shù)內(nèi)部,可以看到綁定過程做了非空判斷
public final class ActivityMainBinding implements ViewBinding {
@NonNull
private final LinearLayout rootView;
@NonNull
public final Button btnCancel;
@NonNull
public final Button btnSubmit;
@NonNull
public final TextView tvMsg;
private ActivityMainBinding(@NonNull LinearLayout rootView, @NonNull Button btnCancel,
@NonNull Button btnSubmit, @NonNull TextView tvMsg) {
this.rootView = rootView;
this.btnCancel = btnCancel;
this.btnSubmit = btnSubmit;
this.tvMsg = tvMsg;
}
@Override
@NonNull
public LinearLayout getRoot() {
return rootView;
}
@NonNull
public static ActivityMainBinding inflate(@NonNull LayoutInflater inflater) {
return inflate(inflater, null, false);
}
@NonNull
public static ActivityMainBinding inflate(@NonNull LayoutInflater inflater,
@Nullable ViewGroup parent, boolean attachToParent) {
View root = inflater.inflate(R.layout.activity_main, parent, false);
if (attachToParent) {
parent.addView(root);
}
return bind(root);
}
//這里是主要的View綁定實現(xiàn)
@NonNull
public static ActivityMainBinding bind(@NonNull View rootView) {
// The body of this method is generated in a way you would not otherwise write.
// This is done to optimize the compiled bytecode for size and performance.
String missingId;
missingId: {
//綁定View且做了非空判斷遥昧,拋出空指針異常
Button btnCancel = rootView.findViewById(R.id.btn_cancel);
if (btnCancel == null) {
missingId = "btnCancel";
break missingId;
}
Button btnSubmit = rootView.findViewById(R.id.btn_submit);
if (btnSubmit == null) {
missingId = "btnSubmit";
break missingId;
}
TextView tvMsg = rootView.findViewById(R.id.tv_msg);
if (tvMsg == null) {
missingId = "tvMsg";
break missingId;
}
return new ActivityMainBinding((LinearLayout) rootView, btnCancel, btnSubmit, tvMsg);
}
throw new NullPointerException("Missing required view with ID: ".concat(missingId));
}
}
include覆醇,merge,viewstub的配合使用
- 單獨使用 include 的情況炭臭,可以直接給 include節(jié)點 添加id永脓,XXXBinding類會直接把需要導入的布局的XXXBinding類做為成員變量(變量名為include標簽的id)供開發(fā)者使用; (PS:ViewStub用法和include差不多鞋仍,區(qū)別是 include 的成員變量是 XXXBinding常摧,ViewStub成員變量就是ViewStub自己,然后用法跟原本ViewStub一致) 如:
- 帶 merge 的 include
這個情況有點特殊,帶 merge 標簽的include不能使用ID落午,否則會找不到View報空指針異常
這個情況谎懦,我們可以先初始化主布局,再初始帶 merge 的布局溃斋,如下示例:
好了界拦,這就是ViewBing的基本使用~~