Android Jetpack 之ViewBinding和DataBinding

58 阅读3分钟

xmlns:tools="schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context=".Main2Activity">

使用数据绑定的xml文件根布局必须是layout标签,我们新建一个User类,有姓名和性别字段

public class User {

....

private String userName;

private String userGender;

....

}

首先通过data标签导入要绑定的数据

<variable

name="user"

type="com.example.jetpackdemo.bean.User" />

我们在xml中加入两个textView用来显示用户姓名和性别

<LinearLayout

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:orientation="vertical">

<TextView

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:text="@{user.userName}"

android:textSize="17sp" />

<TextView

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:text="@{user.userGender}"

android:textSize="17sp" />

通过@{}的引用方式设置数据

在Main2Activity中通过如下方法 设置数据源:

ActivityMain2Binding activityMain2Binding = DataBindingUtil.setContentView(this, R.layout.activity_main2);

User user = new User("黄林晴", "男");

activityMain2Binding.setUser(user);

运行程序如下所示:

如果我们现在把性别改为null,则性别会直接不显示

如果我们现在要求当性别为null的时候显示“未设置”要怎么做呢,我们可以在xml中进行判断

在data标签下导入TextUtil 

<TextView

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:text='@{TextUtils.isEmpty(user.userGender)? "未设置": user.userGender}'

android:textSize="17sp" />

运行结果如下图所示

除了数据绑定外,还有监听事件绑定等,就不详细举例了。我们当前做的是静态数据绑定,很多时候我们都需要动态绑定,那么如何在数据变化的时候自动更新呢?

使用可观察的数据对象

  • 可观察字段

可观察数据类型 类型如下:

修改User类字段属性如下:

public class User {

public final ObservableField userName = new ObservableField<>();

public final ObservableField userGender = new ObservableField<>();

}

注意 这里必须定义为final类型,在Main2Activity中如下所示:

ActivityMain2Binding activityMain2Binding = DataBindingUtil.setContentView(this, R.layout.activity_main2);

User user = new User();

user.userName.set("黄林晴-初始值");

user.userGender.set("男");

activityMain2Binding.setUser(user);

运行结果如下所示:

接下来 我们添加一个按钮 在按钮中重新设置user中的数据

btnChanged = findViewById(R.id.btn_change);

btnChanged.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

user.userName.set("黄林晴-改变后的值");

}

});

点击按钮,运行结果如下所示:

如此一来数据变化的时候我们控件上的数据也就可以变化了

  • 可观察集合

可观察集合 常用于动态数据结构,使用[ObservableArrayMap]( )访问键值类似HashMap中的数据访问,这里不做介绍了。

  • 可观察对象

和可观察数据字段和集合相比,我们最喜欢的应该是可观察对象了,这样我们我们不需要受原有访问数据方法的限制

public class User extends BaseObservable {

private String userName;

private String userGender;

public User(String userName, String userGender) {

this.userName = userName;

this.userGender = userGender;

}

@Bindable

public String getUserName() {

return userName;

}

public void setUserName(String userName) {

this.userName = userName;

notifyPropertyChanged(BR.userName);

}

@Bindable

public String getUserGender() {

return userGender;

}

public void setUserGender(String userGender) {

this.userGender = userGender;

notifyPropertyChanged(BR.userGender);

}

}

我们让User类继承自BaseObservable,使用Bindable注解注册通知,当值改变的时候通过notifyPropertyChanged()发送通知,为BR 类是数据绑定生成的一个用于数据绑定的资源的 ID的类。在Main2Activity中同样的设置初始值,点击按钮改变值

ActivityMain2Binding activityMain2Binding = DataBindingUtil.setContentView(this, R.layout.activity_main2);

User user = new User("黄林晴-可变对象", "男");

activityMain2Binding.setUser(user);

btnChanged = findViewById(R.id.btn_change);

btnChanged.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

user.setUserName("黄林晴-数据更新");

}