Jetpack Compose - 设置 Compose 编译器、设置 Compose 依赖项

设置 Compose 编译器

1、具体实现
  1. libs.versions.toml 文件中,添加如下内容
toml 复制代码
[versions]
kotlin = "2.0.0"

[plugins]
kotlin-android = { id = "org.jetbrains.kotlin.android", version.ref = "kotlin" }

# 添加 Compose 编译器
kotlin-compose = { id = "org.jetbrains.kotlin.plugin.compose", version.ref = "kotlin" }
  1. 在项目级 build.gradle.kts 文件中,添加如下内容,项目级声明,告诉 Gradle 这个插件可能会用,但不激活
kotlin 复制代码
plugins {
    alias(libs.plugins.kotlin.compose) apply false
}
  1. 在模块级 build.gradle.kts 文件中,添加如下内容,模块级启用,在具体的模块真正激活插件
kotlin 复制代码
plugins {
    alias(libs.plugins.kotlin.compose)
}
2、补充学习
  1. 可以直接在模块级启用,项目级声明不是必须的

  2. 项目级声明的真正价值在于,项目级 build.gradle.kts 文件只声明版本,不应用,各个模块级 build.gradle.kts 文件继承版本,直接应用

  3. 版本集中在 libs.versions.toml 文件管理,所有模块版本统一,升级只需改一处

  4. 对于单模块项目,可以直接模块级启用;对于多模块项目,项目级声明更好


设置 Compose 依赖项

1、具体实现
  1. 在模块级 build.gradle.kts 文件中,添加如下内容,以在 Android Studio 中启用 Compose 功能
kotlin 复制代码
android {
    buildFeatures {
        compose = true
    }
}
  1. 设置 Compose 依赖项
kotlin 复制代码
dependencies {

    val composeBom = platform("androidx.compose:compose-bom:2026.04.01")
    implementation(composeBom)
    androidTestImplementation(composeBom)

    // Choose one of the following:
    // Material Design 3
    implementation("androidx.compose.material3:material3")
    // or skip Material Design and build directly on top of foundational components
    implementation("androidx.compose.foundation:foundation")
    // or only import the main APIs for the underlying toolkit systems,
    // such as input and measurement/layout
    implementation("androidx.compose.ui:ui")

    // Android Studio Preview support
    implementation("androidx.compose.ui:ui-tooling-preview")
    debugImplementation("androidx.compose.ui:ui-tooling")

    // UI Tests
    androidTestImplementation("androidx.compose.ui:ui-test-junit4")
    debugImplementation("androidx.compose.ui:ui-test-manifest")

    // Optional - Add window size utils
    implementation("androidx.compose.material3.adaptive:adaptive")

    // Optional - Integration with activities
    implementation("androidx.activity:activity-compose:1.13.0")
    // Optional - Integration with ViewModels
    implementation("androidx.lifecycle:lifecycle-viewmodel-compose:2.10.0")
    // Optional - Integration with LiveData
    implementation("androidx.compose.runtime:runtime-livedata")
    // Optional - Integration with RxJava
    implementation("androidx.compose.runtime:runtime-rxjava2")

}
2、解读
kotlin 复制代码
val composeBom = platform("androidx.compose:compose-bom:2026.04.01")
implementation(composeBom)
androidTestImplementation(composeBom)
  1. BOM(Bill of Materials,物料清单)统一管理所有 Compose 库的版本,确保兼容性,后续依赖不需要写版本号,由 BOM 自动决定

  2. 主代码模块使用 BOM,后续所有 Compose 依赖无需写版本号

  3. 测试模块也使用同一个 BOM,保证测试代码与主代码版本一致

kotlin 复制代码
// Choose one of the following:
// Material Design 3
implementation("androidx.compose.material3:material3")
// or skip Material Design and build directly on top of foundational components
implementation("androidx.compose.foundation:foundation")
// or only import the main APIs for the underlying toolkit systems,
// such as input and measurement/layout
implementation("androidx.compose.ui:ui")
依赖项 说明
material3 Material Design 3 组件(按钮、卡片等),大多数项目选这个
foundation 无 Material 风格的基础组件(例如,BasicTextField)
ui 最底层,布局、输入、测量,需要自己构建 UI
  • 一般只选 material3,它已包含 foundation 和 ui
kotlin 复制代码
// Android Studio Preview support
implementation("androidx.compose.ui:ui-tooling-preview")
debugImplementation("androidx.compose.ui:ui-tooling")

// UI Tests
androidTestImplementation("androidx.compose.ui:ui-test-junit4")
debugImplementation("androidx.compose.ui:ui-test-manifest")
依赖项 说明
ui-tooling-preview @Preview 注解支持
ui-tooling 交互式预览、检查布局
ui-test-junit4 UI 测试框架
ui-test-manifest 测试用的 AndroidManifest
kotlin 复制代码
// Optional - Add window size utils
implementation("androidx.compose.material3.adaptive:adaptive")

// Optional - Integration with activities
implementation("androidx.activity:activity-compose:1.13.0")
// Optional - Integration with ViewModels
implementation("androidx.lifecycle:lifecycle-viewmodel-compose:2.10.0")
// Optional - Integration with LiveData
implementation("androidx.compose.runtime:runtime-livedata")
// Optional - Integration with RxJava
implementation("androidx.compose.runtime:runtime-rxjava2")
依赖项 说明
adaptive 窗口大小适配工具
activity-compose 将 Compose 与 ComponentActivity 深度集成
lifecycle-viewmodel-compose ViewModel 集成
runtime-livedata LiveData 集成
runtime-rxjava2 RxJava2 集成
相关推荐
weixin_BYSJ198714 小时前
springboot鹿邑县旅游网站99312(源码+文档)
java·javascript·spring boot·python·django·flask·php
七夜zippoe14 小时前
DolphinDB异常检测引擎:实时告警
java·服务器·网络·异常·告警·dolphindb
bqliang14 小时前
译 · Jake Wharton 访谈:Android 圈最熟悉的那个名字
android·程序员·开源
三少爷的鞋14 小时前
Android Data 层 Flow 最佳实践:以冷流为基础,按需转热,避免过早共享状态
android
私人珍藏库1 天前
【Android】Soul v5.86.0 内置模块版
android·app·工具·软件·多功能
橙淮1 天前
并发编程(六)
java·jvm
千里马学框架1 天前
aosp新增窗口层级 Type 完整实现方案(有源码)-wms需求和面试题
android·智能手机·架构·wms·aaos·车机
拽着尾巴的鱼儿1 天前
springboot openfeign 自定义feign 接口重试机制
java·spring boot·后端
白露与泡影1 天前
2026大厂Java面试题大全!牛客网最新版
java·开发语言
EntyIU1 天前
JVM内存与GC笔记
java·jvm·笔记