是的,Android Data Binding 可以跨模块使用。要在跨模块项目中使用 Android Data Binding,请按照以下步骤操作:
- 在 app 模块的 build.gradle 文件中启用数据绑定:
android { ... dataBinding { enabled = true } }
- 确保在 app 模块的 build.gradle 文件中添加了数据绑定依赖项:
dependencies { ... dataBinding { implementation 'androidx.databinding:databinding:4.2.0' } }
- 在需要使用数据绑定的模块中,同样需要启用数据绑定并添加相应的依赖项。例如,如果要在 library 模块中使用数据绑定,请在 library 模块的 build.gradle 文件中添加以下内容:
apply plugin: 'kotlin-kapt' android { ... dataBinding { enabled = true } } dependencies { ... kapt "androidx.databinding:compiler:4.2.0" }
- 在 library 模块的 build.gradle 文件中,还需要将 dataBinding 生成的类添加到 android.libraryVariants.each 闭包中,以便在每个构建变体中生成相应的绑定类:
android.libraryVariants.each { variant -> variant.outputs.all { output -> def outputFile = output.outputFile if (outputFile != null && outputFile.name.endsWith('.aar')) { def bindingOutputDir = file("$buildDir/generated/data_binding") bindingOutputDir.mkdirs() outputFileName = "${outputFile.nameWithoutExtension}_databinding.aar" output.outputFile = new File(bindingOutputDir, outputFileName) } } }
- 在 library 模块的 XML 布局文件中,使用
标签包裹根视图,并在需要数据绑定的视图上添加android:id="@+id/binding"
属性。例如:
- 在 library 模块的 Java 或 Kotlin 代码中,使用
LayoutInflater
的inflate
方法创建视图,并将生成的绑定类与视图关联:
// Java LayoutInflater inflater = LayoutInflater.from(context); MyBinding binding = DataBindingUtil.inflate(inflater, R.layout.my_library_layout, parent, false);
// Kotlin val inflater = LayoutInflater.from(context) val binding: MyBinding = DataBindingUtil.inflate(inflater, R.layout.my_library_layout, parent, false)
完成以上步骤后,您就可以在跨模块项目中使用 Android Data Binding 了。