在 Android 数据绑定库中,DataBindingUtil 是一个工具类,它允许您将 XML 布局与 Java 类进行绑定。以下是 DataBindingUtil 的使用步骤:
1、在 build.gradle 文件中添加以下依赖项:
android {
...
dataBinding {
enabled true
}
}
2、创建一个 XML 布局文件,将它的根元素设置为 <layout>。例如,我们创建一个名为 "activity_main.xml" 的布局文件:
<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android">
<LinearLayout
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/myTextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello, World!" />
</LinearLayout>
</layout>
3、创建一个与 XML 布局文件对应的 Java 类,并通过 DataBindingUtil.setContentView() 方法将它们绑定在一起。例如,我们创建一个名为 "MainActivity.java" 的类:
public class MainActivity extends AppCompatActivity {
ActivityMainBinding binding = null
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// 创建绑定类
binding = DataBindingUtil.setContentView(this, R.layout.activity_main);
// 设置 TextView 的文本
binding.myTextView.setText("Hello, DataBinding!");
}
override fun onDestroy() {
super.onDestroy();
binding = null;
}
}
在上面的代码中,DataBindingUtil.setContentView() 方法返回一个自动生成的绑定类 ActivityMainBinding 的实例,我们可以使用该实例获取 XML 布局文件中定义的视图,并在代码中对它们进行操作。
注意:Activity的另外一种写法:
class SixActivity: AppCompatActivity() {
var binding:ActivitySixBinding? = null
override fun onCreate(savedInstanceState: Bundle?) {
supportRequestWindowFeature(Window.FEATURE_NO_TITLE)
super.onCreate(savedInstanceState)
//1、获取布局
binding = ActivitySixBinding.inflate(layoutInflater)
//2、设置布局
setContentView(binding?.root)
binding?.tvContent?.text = "涛哥试试"
}
}
4、特别注意:
//Kotlin 主要在Activity或Fragment中使用:
ActivityMainBinding binding = DataBindingUtil.setContentView(context, R.layout.activity_main);
//获取整体布局view
val view = binding.root
//java 主要在adapter或者自定view中使用绑定
ItemFlowLayoutBinding binding = DataBindingUtil.inflate(LayoutInflater.from(context), R.layout.item_flow_layout, null, false);
//获取整体布局view
View view = binding.getRoot()
Kotlin:主要在adapter或者自定view中使用绑定
fun test(){
val binding: ItemFlowLayoutBinding = DataBindingUtil.inflate(
LayoutInflater.from(this),
R.layout.item_flow_layout,
null,
false
)
//获取整体布局view
val view = binding.root
}
5、实例代码
Java使用:
/**
* FlowLayout按钮
*/
public class MainFlowLayoutAdapter extends FlowLayoutAdapter {
private List<String> dataList;
private int mCheckedPosition = -1;
public MainFlowLayoutAdapter(List<String> datas) {
this.dataList = datas;
}
@Override
protected View createView(Context context, FlowLayout flowLayout, int position) {
//-------普通使用---------
// View view = View.inflate(context, R.layout.item_flow_layout, null);
// TextView tvContent = view.findViewById(R.id.tv_content);
// tvContent.setText(dataList.get(position));
// return view;
//------dataBinding绑定形式------
ItemFlowLayoutBinding binding = DataBindingUtil.inflate(LayoutInflater.from(context), R.layout.item_flow_layout, null, false);
binding.tvContent.setText(dataList.get(position));
return binding.getRoot();
}
@Override
public int getItemCount() {
return dataList == null ? 0 : dataList.size();
}
@Override
public Object getItem(int position) {
return dataList.get(position);
}
}
Kotlin使用:
fun test(){
// 创建绑定类
var binding: ActivityNewSearchBinding = DataBindingUtil.setContentView(this, R.layout.activity_new_search)
//获取整体布局view
val view = binding.root
}
6、BaseQuickAdapter中使用:
1、普通Adapter中使用:
class BookCatalogAdapter:BaseQuickAdapter<String,BaseViewHolder>(R.layout.item_catalog_layout) {
override fun convert(holder: BaseViewHolder, item: String) {
}
}
2、数据绑定Adapter中使用:
class BookCatalogAdapter:BaseQuickAdapter<String,BaseDataBindingHolder<ItemCatalogLayoutBinding>>(R.layout.item_catalog_layout) {
override fun convert(holder: BaseDataBindingHolder<ItemCatalogLayoutBinding>, item: String) {
}
}
网友评论