深入解析 androidx.databinding.BaseObservable

# 深入解析 androidx.databinding.BaseObservable

在现代 Android 开发中,数据绑定 (Data Binding) 是一个重要的技术,它简化了 UI 和数据之间的交互。在数据绑定框架中,androidx.databinding.BaseObservable 是一个关键类,用于实现可观察的数据模型。本文将详细介绍 BaseObservable 的用法和原理,帮助你更好地掌握数据绑定技术。

什么是 BaseObservable?

BaseObservable 是一个基础类,它实现了 Observable 接口,使得数据模型能够被观察。当数据模型中的属性发生变化时,BaseObservable 可以通知所有的观察者(通常是绑定的 UI 视图)自动更新。

基本用法

创建一个继承自 BaseObservable 的类

要使用 BaseObservable,我们需要创建一个继承自 BaseObservable 的类,并在需要通知变化的属性上添加 @Bindable 注解。然后,在属性的 setter 方法中调用 notifyPropertyChanged 方法。

下面是一个简单的示例,展示如何创建一个用户类,并使用 BaseObservable@Bindable 实现数据绑定:

import androidx.databinding.BaseObservable
import androidx.databinding.Bindableclass User : BaseObservable() {var firstName: String = ""@Bindable get() = fieldset(value) {field = valuenotifyPropertyChanged(BR.firstName)}var lastName: String = ""@Bindable get() = fieldset(value) {field = valuenotifyPropertyChanged(BR.lastName)}
}

在这个示例中,User 类继承自 BaseObservable,并且使用 @Bindable 注解标记了 firstNamelastName 属性。当这些属性的值发生变化时,notifyPropertyChanged 方法会通知数据绑定框架更新 UI。

在布局文件中使用数据绑定

接下来,我们需要在布局文件中使用数据绑定。首先,在项目的 build.gradle 文件中启用数据绑定:

android {...dataBinding {enabled = true}
}

然后,在布局文件中使用数据绑定。在根布局中添加 layout 标签,并声明一个 User 类型的变量:

<layout xmlns:android="http://schemas.android.com/apk/res/android"><data><variablename="user"type="com.example.app.User" /></data><LinearLayoutandroid:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><EditTextandroid:layout_width="match_parent"android:layout_height="wrap_content"android:text="@={user.firstName}" /><EditTextandroid:layout_width="match_parent"android:layout_height="wrap_content"android:text="@={user.lastName}" /></LinearLayout>
</layout>

在 Activity 或 Fragment 中绑定数据

最后,在 ActivityFragment 中绑定数据并设置视图模型:

import android.os.Bundle
import androidx.appcompat.app.AppCompatActivity
import androidx.databinding.DataBindingUtil
import com.example.app.databinding.ActivityMainBindingclass MainActivity : AppCompatActivity() {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)val binding: ActivityMainBinding = DataBindingUtil.setContentView(this, R.layout.activity_main)val user = User().apply {firstName = "John"lastName = "Doe"}binding.user = user}
}

深入理解 BaseObservable 的工作原理

BaseObservable 的核心在于它实现了 Observable 接口,并且提供了一组方法,用于管理观察者和通知属性变化。

notifyPropertyChanged 方法

notifyPropertyChanged 方法用于通知数据绑定框架某个属性的值发生了变化。我们需要在属性的 setter 方法中调用它,并传递相应的属性 ID。例如:

var firstName: String = ""@Bindable get() = fieldset(value) {field = valuenotifyPropertyChanged(BR.firstName)}

notifyChange 方法

如果多个属性的值发生了变化,或者我们想要一次性通知所有的绑定属性发生了变化,可以使用 notifyChange 方法:

fun updateUser(firstName: String, lastName: String) {this.firstName = firstNamethis.lastName = lastNamenotifyChange()
}

自动生成的 BR 类

当我们在属性上添加 @Bindable 注解时,数据绑定框架会自动生成一个 BR 类。这个类包含了所有绑定属性的 ID,用于在属性值变化时通知数据绑定框架。例如,BR.firstNameBR.lastName 就是自动生成的 ID。

object BR {@JvmFieldval _all = 0@JvmFieldval firstName = 1@JvmFieldval lastName = 2
}

高级用法

双向数据绑定

双向数据绑定允许我们在视图和数据模型之间实现双向同步。例如,当用户在 EditText 中输入文本时,数据模型会自动更新;同样,当数据模型的值发生变化时,视图也会自动更新。我们可以通过在 XML 中使用 @= 语法来实现双向数据绑定:

<EditTextandroid:layout_width="match_parent"android:layout_height="wrap_content"android:text="@={user.firstName}" />

自定义属性和 BindingAdapter

有时候,我们需要在视图上绑定一些自定义属性。为此,我们可以使用 BindingAdapter 注解来自定义数据绑定逻辑。例如,我们可以为 ImageView 创建一个自定义绑定适配器,用于加载网络图片:

import android.widget.ImageView
import androidx.databinding.BindingAdapter
import com.bumptech.glide.Glideobject BindingAdapters {@JvmStatic@BindingAdapter("imageUrl")fun loadImage(view: ImageView, url: String?) {if (!url.isNullOrEmpty()) {Glide.with(view.context).load(url).into(view)}}
}

在布局文件中使用自定义属性:

<ImageViewandroid:layout_width="match_parent"android:layout_height="wrap_content"app:imageUrl="@{viewModel.imageUrl}" />

性能优化

在使用数据绑定时,我们需要注意性能优化,特别是在大型项目中。以下是一些常见的优化建议:

使用 ObservableField

对于简单的单个字段绑定,可以使用 ObservableField 来代替 @Bindable 注解和 BaseObservable,这样可以减少代码量并提高性能:

import androidx.databinding.ObservableFieldclass User {val firstName = ObservableField<String>()val lastName = ObservableField<String>()
}

避免过度绑定

绑定的数据越多,数据绑定框架的开销就越大。尽量只绑定必要的数据,避免不必要的绑定和数据刷新。

结论

BaseObservable 是 Android 数据绑定框架中的一个重要组件,通过它可以实现数据和视图的双向绑定,从而简化代码结构,提高代码的可维护性。通过本文的介绍,相信你已经对 BaseObservable 的基本用法、高级用法和性能优化有了更深入的了解。在实际开发中,合理使用 BaseObservable 和数据绑定框架,可以大大提升开发效率和应用的用户体验。

Best regards!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/38605.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python-求s=a+aa+aaa+aaaa+aa...a的值(赛氪OJ)

[题目描述] 求 saaaaaaaaaaaa...a 的值&#xff0c;其中 a 是一个一位的整数。 例如 &#xff1a;2222222222222222(此时共有 5 个数相加)。输入格式&#xff1a; 整数 a 和 n &#xff08; n 个数相加&#xff09;。输出格式&#xff1a; s 的值。样例输入 2 2样例输出 24数据…

WSL——忘记root密码(Ubuntu)

1、问题描述 Windows下的WSL&#xff08;Ubuntu&#xff09;忘记了root密码&#xff0c;无法使用管理员权限。 2、解决方法 关闭 Ubuntu 窗口。打开 Windows 的 Powershell 或 cmd&#xff0c; 以 root 默认登陆 WSL。 wsl -u root 修改对应用户密码。 # xxx为要修改密码的用…

Stable Diffusion【真人模型】:人脸特美的人像摄影大模型wuhaXL_realisticMixV3.0

今天和大家分享一个基于SDXL的真人大模型&#xff1a;wuhaXL_realisticMix。该模型无需使用LORA**就能生成的特别漂亮的人脸&#xff0c;虽然有时候人脸有些假&#xff0c;但是生成的人脸确实非常漂亮。 该模型底模融合了WhiteXL_realisticMix&#xff0c;训练素材来自于视频转…

pytorch统计学分布

1、pytorch统计学函数 import torcha torch.rand(2,2) print(a) print(torch.sum(a, dim0)) print(torch.mean(a, dim0)) print(torch.prod(a, dim0))print(torch.argmax(a, dim0)) print(torch.argmin(a, dim0)) print(torch.std(a)) print(torch.var(a)) print(torch.median…

如何学好AI绘画?点这里有答案!

前言 地狱难度的求职模式下&#xff0c;“掌握一门技术”的那部分求职者&#xff0c;远比其他人更有竞争力&#xff1b;而拥有出色技术和技能的设计师、以及未来想做设计师的小伙伴们&#xff0c;怎么才能更好实现工作自由&#xff1f; 只有两个字&#xff1a;学习。 学习新…

EE trade:白银什么情况下会暴涨

白银价格的暴涨通常由多种因素共同作用引发&#xff0c;包括宏观经济背景、市场供需变化、地缘政治紧张局势以及金融市场波动等。本文整理了一些具体情况和实例&#xff0c;说明白银在什么情况下可能会暴涨。 1. 宏观经济因素 通货膨胀急剧上升 背景&#xff1a;当通货膨胀急…

电脑怎么录屏幕视频带声音?2种方法教会你

在数字时代的浪潮中&#xff0c;电脑屏幕视频录制已经成为一项潮流且实用的技能。无论是为了创作短视频、分享游戏过程&#xff0c;还是为了记录在线会议或教程&#xff0c;电脑录屏都是非常重要的功能。但是不少的人都会遇上录制好的视频没有声音的困境&#xff0c;面对这种情…

HTML5+CSS3+JS小实例:图片九宫格

实例:图片九宫格 技术栈:HTML+CSS+JS 效果: 源码: 【HTML】 <!DOCTYPE html> <html lang="zh-CN"> <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1…

操作系统精选题(四)(论述题)

&#x1f308; 个人主页&#xff1a;十二月的猫-CSDN博客 &#x1f525; 系列专栏&#xff1a; &#x1f3c0;操作系统 &#x1f4aa;&#x1f3fb; 十二月的寒冬阻挡不了春天的脚步&#xff0c;十二点的黑夜遮蔽不住黎明的曙光 目录 前言 一、银行家算法的一道例题 二、页…

二叉搜索树的实现与测试

目录 1.二叉搜索树的结构与特性 2.二叉搜索树的实现 &#xff08;1&#xff09;节点 &#xff08;2&#xff09;功能实现 插入&#xff1a; 删除&#xff1a; 查找: 打印&#xff1a; 3.测试 插入删除&#xff1a; 查找&#xff1a; 4.变种测试&#xff0c;即带valu…

vue3 【提效】自动注册组件 unplugin-vue-components 实用教程

还在为每次都要导入组件而烦恼吗 &#xff1f; // 每次都需手动导入组件 import webName from /components/webName.vue用 unplugin-vue-components 来帮你吧&#xff0c;以后组件直接拿来用即可&#xff0c;无需再导入啦 &#xff01; <webName />使用流程 1. 安装 un…

逻辑这回事(七)---- 器件基础

Xilinx FPGA创建了先进的硅模块(ASMBL)架构,以实现FPGA具有针对不同应用程序领域优化的各种功能组合的平台。通过这一创新,Xilinx提供了更多的设备选择,使客户能够为其特定设计选择具有正确的功能和功能组合的FPGA。ASMBL体系结构通过以下方式突破了传统的设计障碍:消除几…

LINUX系统编程:多线程互斥

目录 1.铺垫 2.线程锁接口的认识 静态锁分配 动态锁的分配 互斥量的销毁 互斥量加锁和解锁 3.加锁版抢票 4.互斥的底层实现 1.铺垫 先提一个小场景&#xff0c;有1000张票&#xff0c;现在有4个进程&#xff0c;这四个进程疯狂的去抢这1000张票&#xff0c;看看会发生什…

新书速览|Adobe Firefly:萤火虫:AI绘画快速创意设计

《Adobe Firefly&#xff1a;萤火虫&#xff1a;AI绘画快速创意设计》 本书内容 人工智能&#xff08;Artificial Intelligence&#xff0c;AI&#xff09;浪潮的席卷已经变成不可阻挡的趋势&#xff0c;伴随着这种变化&#xff0c;在图形设计、图像制作、绘画领域也相应发生了…

什么是接口测试,我们如何实现接口测试?

1. 什么是接口测试 顾名思义&#xff0c;接口测试是对系统或组件之间的接口进行测试&#xff0c;主要是校验数据的交换&#xff0c;传递和控制管理过程&#xff0c;以及相互逻辑依赖关系。其中接口协议分为HTTP,WebService,Dubbo,Thrift,Socket等类型&#xff0c;测试类型又主…

NewspaceGPT带你玩系列之SQL专家(强烈推荐)

目录 注册一个账号&#xff0c;用qq邮箱&#xff0c;然后登录选一个可用的Plus&#xff0c;不要选3.5探索GPT今天的主角是SQL Expert&#xff08;SQL 专家&#xff09;问题1&#xff1a;答1. 索引原因&#xff1a;优化措施&#xff1a;示例&#xff1a; 2. 查询设计原因&#x…

ros中teleop_twist_keyboard安装使用

目录 1.安装 2.使用 3.说明 1.安装 sudo apt-get install ros-noetic-teleop-twist-keyboard 其中noetic替换成你自己的ros版本 2.使用 roscore #启动roscore rosrun teleop_twist_keyboard teleop_twist_keyboard.py …

零基础STM32单片机编程入门(五)FreeRTOS实时操作系统详解及实战含源码视频

文章目录 一.概要二.什么是实时操作系统三.FreeRTOS的特性四.FreeRTOS的任务详解1.任务函数定义2.任务的创建3.任务的调度原理 五.CubeMX配置一个FreeRTOS例程1.硬件准备2.创建工程3.调试FreeRTOS任务调度 六.CubeMX工程源代码下载七.讲解视频链接地址八.小结 一.概要 FreeRTO…

[SwiftUI 开发] 嵌套的ObservedObject中的更改不会更新UI

1. 发生问题的demo 业务逻辑代码 class Address: ObservableObject {Published var street "123 Apple Street"Published var city "Cupertino" }class User: ObservableObject {Published var name "Tim Cook"Published var address Addr…

nacos漏洞小结

Alibaba Nacos是阿里巴巴推出来的一个新开源项目&#xff0c;是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。致力于帮助发现、配置和管理微服务。Nacos提供了一组简单易用的特性集&#xff0c;可以快速实现动态服务发现、服务配置、服务元数据及流量管理…