知识点:
1.开启 在build.gradle app下配置
viewBinding{
enabled= true
}
2.使用自动生成的视图绑定类进行视图操作,绑定类名称生成规则:布局文件名称去除下划线,并且每段首字母大写,并在末尾追加Binding。
3.通过点击生成的绑定类可跳转到布局文件。
4.绑定类位置:build/generated/data_binding_base_class_source_out/debug/out/包名/databinding/。
5.可在布局文件根布局中使用 tools:viewBindingIgnore="true" 来关闭生成视图绑定类。
6.可点击Build/Make按钮更新自动生成的类(绑定类)
7.生成的id命名规则:例:tv_info -> tvInfo
1.目的
在大多数情况下,可以替代findViewById(),减少模版代码。通过视图绑定功能,可以更轻松地编写可与视图交互的代码。在模块中启用视图绑定之后,系统会为该模块中的每个 XML 布局文件生成一个绑定类。绑定类的实例包含对在相应布局中具有 ID 的所有视图的直接引用。
2.配置
在AS3.6 android模块中直接配置开启即可。
注意:视图绑定在 Android Studio 3.6 Canary 11 及更高版本中可用。
android {
...
viewBinding {
enabled = true
}
}
如果希望在生成绑定类时忽略某个布局文件,请将 tools:viewBindingIgnore="true"
属性添加到相应布局文件的根视图中。
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:viewBindingIgnore="true"
tools:context=".MainActivity">
...
</androidx.constraintlayout.widget.ConstraintLayout>
3.使用
在模块中开启ViewBinding之后,系统会为该模块中包含的每个xml文件都声明一个对应的绑定类。每个绑定类均会包含根视图以及具有ID的所有视图的引用。
视图绑定类名称生成规则:将 XML 文件的名称转换为驼峰式大小写,并在末尾添加“Binding”一词。
绑定类位置:build/generated/data_binding_base_class_source_out/debug/out/包名/databinding/。
可点击Build/Make按钮更新自动生成的类(绑定类)
布局文件:activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<TextView
android:id="@+id/tv_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello World!"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
生成的视图绑定类:ActivityMainBinding
@NonNull
public ConstraintLayout getRoot();
@NonNull
public static ActivityMainBinding inflate(@NonNull LayoutInflater inflater) ;
@NonNull
public static ActivityMainBinding inflate(@NonNull LayoutInflater inflater,@Nullable ViewGroup parent, boolean attachToParent) ;
@NonNull
public static ActivityMainBinding bind(@NonNull View rootView) ;
4.原理
在生成的绑定类中有三个静态方法,通过这三个方法可以在Actvity/Fragment/View/以及在已经通过布局填充器解析好的View来构建ViewBinding。其内部也是通过findViewById方法来查找View,并把View作为绑定类的成员,所以我们可以直接通过绑定类来使用对应的View。
// Generated by view binder compiler. Do not edit!
package com.kyunglp.jetpack.databinding;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.constraintlayout.widget.ConstraintLayout;
import androidx.viewbinding.ViewBinding;
import com.kyunglp.jetpack.R;
import java.lang.NullPointerException;
import java.lang.Override;
import java.lang.String;
public final class ActivityMainBinding implements ViewBinding {
@NonNull
private final ConstraintLayout rootView;
@NonNull
public final TextView tvText;
private ActivityMainBinding(@NonNull ConstraintLayout rootView, @NonNull TextView tvText) {
this.rootView = rootView;
this.tvText = tvText;
}
@Override
@NonNull
public ConstraintLayout 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);
}
@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: {
TextView tvText = rootView.findViewById(R.id.tv_text);
if (tvText == null) {
missingId = "tvText";
break missingId;
}
return new ActivityMainBinding((ConstraintLayout) rootView, tvText);
}
throw new NullPointerException("Missing required view with ID: ".concat(missingId));
}
}
5.Demo地址