Android Compose 依赖配置解读

文章目录

libs.versions.toml 依赖项版本管理

AS 版本:
Android Studio Otter 3 Feature Drop | 2025.2.3

新建一个 Compose 项目

项目创建好后,在 project-dir/gradle 中,有个 名为 "libs.versions.toml" 的配置文件,里面配置了 [versions][libraries][plugins]

复制代码
[versions]
agp = "8.13.1"
kotlin = "2.0.21"
coreKtx = "1.10.1"
composeBom = "2025.05.01"
...

[libraries]
androidx-core-ktx = { group = "androidx.core", name = "core-ktx", version.ref = "coreKtx" }
androidx-compose-bom = { group = "androidx.compose", name = "compose-bom", version.ref = "composeBom" }
androidx-compose-ui = { group = "androidx.compose.ui", name = "ui" }
androidx-compose-ui-graphics = { group = "androidx.compose.ui", name = "ui-graphics" }
...

[plugins]
android-application = { id = "com.android.application", version.ref = "agp" }
kotlin-android = { id = "org.jetbrains.kotlin.android", version.ref = "kotlin" }
kotlin-compose = { id = "org.jetbrains.kotlin.plugin.compose", version.ref = "kotlin" }
...

composeBom 是一个用来集中管理 Jetpack Compose 所有相关库版本。它内部使用的各个compose 子lib,都是兼容的。使用后,在依赖androidx-compose-ui 等其它相关的 compose lib 时,不需要指定 version


project-dir/build.gradle.kts

复制代码
plugins {
    alias(libs.plugins.android.application) apply false
    alias(libs.plugins.kotlin.android) apply false
    alias(libs.plugins.kotlin.compose) apply false
    ...
}

alias() 别名引用 libs.versions.tomlplugins 下的 key,将 key name 中的 "-"替换成 "."

这里的 apply false ,表示 在此根目录中不应用,而是在 模块内使用时才去应用


app-dir/build.gradle.kts

复制代码
plugins {
    alias(libs.plugins.android.application)
    alias(libs.plugins.kotlin.android)
    alias(libs.plugins.kotlin.compose)
    id("kotlin-kapt")
    ...
}

alias 别名 引用 libs.versions.tomlplugins 插件

id("kotlin-kapt") , 使用 id 方式应用,因 kapt 属于 kotlin.android 的子插件

复制代码
dependencies {
    implementation(libs.androidx.core.ktx)
    implementation(libs.androidx.lifecycle.runtime.ktx)
    implementation(libs.androidx.activity.compose)
    implementation(platform(libs.androidx.compose.bom))
    implementation(libs.androidx.compose.ui)
    implementation(libs.androidx.compose.ui.graphics)
    implementation(libs.androidx.compose.ui.tooling.preview)
    implementation(libs.androidx.compose.material3)
    implementation(libs.androidx.material3)
	...
    androidTestImplementation(platform(libs.androidx.compose.bom))
    androidTestImplementation(libs.androidx.compose.ui.test.junit4)
    debugImplementation(libs.androidx.compose.ui.tooling)
    debugImplementation(libs.androidx.compose.ui.test.manifest)
}

implementation(platform(libs.androidx.compose.bom)) platform() 是一个专门用来 导入 BOM(物料清单) 的内置函数
platform() 是软约束:如果你手动给某个 Compose 库强行指定了一个更高的版本号,Gradle 会尊重你的选择。

enforcedPlatform() 是硬约束:强制整个项目(包括其他第三方库带进来的间接依赖)必须严格使用 BOM 里规定的版本

android 域 配置 :

复制代码
android {
	buildFeatures {
        compose = true
    }
}

此外,在 AS 默认 Kotlin 版本 小于2.0的的旧版中,可能看到

复制代码
android {
	composeOptions {
        kotlinCompilerExtensionVersion '1.5.4' // 依赖的 compose complier 编译器版本
    }
}

从 Kotlin 2.0 开始,Compose 编译器已整合进 Kotlin 官方仓库,即 应用 alias(libs.plugins.kotlin.compose),不需要单独指定 compose complier 编译器版本

相关推荐
石山岭5 小时前
自己动手写了一个 Android 虚拟定位 App:GPSSimulate 技术实
android·前端
杉氧7 小时前
副作用 (Side Effects) 全攻略:如何像大师一样掌控 Composable 的生命周期?
android·架构·android jetpack
Kapaseker12 小时前
Kotlin Toolchain 0.11 发布:主要是把 Amper 干没了
android·kotlin
三少爷的鞋13 小时前
Android 现代架构不需要事件总线进阶篇
android
杉氧1 天前
深入理解 Compose 重组机制:快照系统如何驱动 UI 精准刷新?
android·架构·android jetpack
召钱熏1 天前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
杉氧1 天前
深度解析:Jetpack Compose 核心架构与底层原理 —— 十年安卓老兵的“破茧重生”
android·架构·android jetpack
通玄1 天前
Jetpack Compose 入门系列(七):ViewModel 与界面状态管理
android
落魄Android在线炒饭1 天前
Android Framework 开发技巧:android.jar 生成与系统快速编译验证
android
如此风景1 天前
Kotlin Flow操作符学习
android·kotlin