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 集成
相关推荐
l软件定制开发工作室1 小时前
Spring开发系列教程(37)——使用Conditional
java·后端·spring
代码漫谈1 小时前
Spring Boot日志配置全攻略:打造高效、可靠的日志系统
java·spring boot·log4j·日志
ideal-cs1 小时前
总结:生产环境Release、Snapshot两种包版本该如何管理与发布构建
java·maven·snapshot·release
yangminlei1 小时前
Spring Boot Starter自定义开发 构建企业级组件库
java·spring boot·后端
牛奶咖啡131 小时前
CI/CD——在jenkins中构建流程实现springboot项目的自动化构建与部署
java·ci/cd·k8s·jenkins·springboot·springboot制作镜像·使用源码项目制作镜像
桔筐1 小时前
Redis 无锁化库存扣减方案(INCR + SETNX 实现,高并发不超卖)
java·redis
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题 第44题】【JVM篇】第4题:什么时候会触发 Young GC?什么时候会触发 Full GC?
java·开发语言·jvm·后端·面试
Kapaseker1 小时前
reified 如何骗过 JVM 类型擦除
android·kotlin
小妖6661 小时前
js 实现python的SortedList有序集合
java·javascript·python