Databinding(kotlin)

简单使用(只作为view获取)

  1. build.gradle.kts配置
java 复制代码
android {
    dataBinding {
        enable = true
    }
  }
  1. activity注入
java 复制代码
//setContentView(R.layout.activity_main)
val binding: ActivityMainBinding = DataBindingUtil.setContentView(this, R.layout.activity_main)
  1. xml配置(只需要binding组件而不需要binding数据时,可以将<data></data>删除)
  2. 直接使用binding获取组件,不用再findById()
java 复制代码
  binding.button.setOnClickListener {
      binding.textView.text="Hello"
  }

binding组件原理

  • 跟入DataBindingUtil.setContentView
  • 跟入bindToAddedViews --> bind(component, childView, layoutId)-->sMapper.getDataBinder(bindingComponent, root, layoutId)
  • 此时没有设置tag,代码也会自动设置一个tag
  • 跟入private ActivityMainBindingImpl(androidx.databinding.DataBindingComponent bindingComponent, View root, Object\[\] bindings)
  • mapBindings(DataBindingComponent bindingComponent, View view,Object\[\] bindings, IncludedLayouts includes, SparseIntArray viewsWithIds,boolean isRoot) 递归获取组件,存入数组bindings
  • 使用父抽象类的初始化方法,将组件绑定在对应的变量上。返回一个绑定了组件的对象。所以可以直接使用对象 . 获取组件。
java 复制代码
  protected ActivityMainBinding(Object _bindingComponent, View _root, int _localFieldCount,
      Button button1, Button button2, LinearLayoutCompat linearLayout, ConstraintLayout main,
      TextView textView) {
    super(_bindingComponent, _root, _localFieldCount);
    this.button1 = button1;
    this.button2 = button2;
    this.linearLayout = linearLayout;
    this.main = main;
    this.textView = textView;
  }
  • 主逻辑流程图:

双向绑定

java 复制代码
android:text="@={user.pwd}"
java 复制代码
public class User extends BaseObservable {
    private String name;
    private String pwd;


    public User(String name, String pwd) {
        this.name = name;
        this.pwd = pwd;
    }

    @Bindable
    public String getName() {
        return name;
    }


    public void setName(String name) {
        this.name = name;
        notifyPropertyChanged(BR.name);
    }

    @Bindable
    public String getPwd() {
        return pwd;
    }

    public void setPwd(String pwd) {
        this.pwd = pwd;
        notifyPropertyChanged(BR.pwd);
    }
}

此时user和UI中的数据会自动同步更改。

同步原理

user推给UI

notifyPropertyChanged(BR.name);

UI推给user
ex:

mDirtyFlags保证只有修改的值进行推送,

  1. 初始化:
    在绑定类初始化时,mDirtyFlags 被设置为一个初始值,通常为 0,表示所有属性都是"干净"的。
  2. 设置数据:
    当数据源发生变化时,相应的位被设置为"脏"。例如,如果某个属性发生了变化,mDirtyFlags 对应的位会被置为 1。
  3. 更新视图:
    在 executeBindings 方法中,会检查 mDirtyFlags 的值,决定哪些视图需要更新。只有那些相应位被设置为"脏"的视图才会重新绑定数据。
相关推荐
逐光老顽童1 天前
Java 与 Kotlin 混合开发避坑指南:30 个真实案例实录
android·kotlin
爱勇宝2 天前
鸿蒙生态的下半场:开发者不只要能开发,还要能赚钱
android·前端·程序员
Yeyu2 天前
刷新一帧的艺术:invalidate / postInvalidate / postInvalidateOnAnimation全解析
android
潘潘潘2 天前
Android OTA 升级原理和流程介绍
android
plainGeekDev2 天前
null 判断 → Kotlin 可空类型
android·java·kotlin
plainGeekDev2 天前
getter/setter → Kotlin 属性
android·java·kotlin
Junerver2 天前
我写了一个 Compose Multiplatform 组件库,你可能会用到
kotlin·android jetpack
YXL1111YXL2 天前
Handler 消息回收与协程异步执行的时序陷阱
android
恋猫de小郭2 天前
KMP / CMP 鸿蒙版本 Beta 发布,他有什么特别之处?
android·前端·flutter
三少爷的鞋2 天前
Android 协程并发控制:别动线程池,控制好并发语义就够了
android