Jetpack Compose 可以访问 Android 项目中定义的资源。本文档解释了 Compose 提供的一些用于执行此操作的 API。
资源是代码使用的附加文件和静态内容,例如位图、布局定义、用户界面字符串、动画说明等等。如果您不熟悉 Android 中的资源,请查看应用资源概述指南。
字符串
最常见的资源类型是您的字符串。使用stringResource
API 静态地检索在 XML 资源中定义的字符串。
// In the res/values/strings.xml file // <string name="compose">Jetpack Compose</string> // In your Compose code Text( text = stringResource(R.string.compose) )
stringResource
也适用于位置格式。
// In the res/values/strings.xml file // <string name="congratulate">Happy %1$s %2$d</string> // In your Compose code Text( text = stringResource(R.string.congratulate, "New Year", 2021) )
字符串复数 (实验性)
使用pluralStringResource
API 加载具有特定数量的复数。
// In the res/strings.xml file // <plurals name="runtime_format"> // <item quantity="one">%1$d minute</item> // <item quantity="other">%1$d minutes</item> // </plurals> // In your Compose code Text( text = pluralStringResource( R.plurals.runtime_format, quantity, quantity ) )
使用pluralStringResource
方法时,如果您的字符串包含使用数字的字符串格式,则需要两次传递计数。例如,对于字符串%1$d minutes
,第一个计数参数选择合适的复数字符串,第二个计数参数插入到%1$d
占位符中。如果您的复数字符串不包含字符串格式,则无需将第三个参数传递给pluralStringResource
。
有关复数的更多信息,请查看数量字符串文档。
尺寸
类似地,使用dimensionResource
API 从资源 XML 文件中获取尺寸。
// In the res/values/dimens.xml file // <dimen name="padding_small">8dp</dimen> // In your Compose code val smallPadding = dimensionResource(R.dimen.padding_small) Text( text = "...", modifier = Modifier.padding(smallPadding) )
颜色
如果您在应用中逐步采用 Compose,请使用colorResource
API 从资源 XML 文件中获取颜色。
// In the res/colors.xml file // <color name="purple_200">#FFBB86FC</color> // In your Compose code Divider(color = colorResource(R.color.purple_200))
colorResource
可与静态颜色一起按预期工作,但它会展平颜色状态列表资源。
矢量资源和图像资源
使用painterResource
API 加载矢量可绘制对象或栅格化资产格式(如 PNG)。您不需要知道可绘制对象的类型,只需在Image
可组合项或paint
修饰符中使用painterResource
。
// Files in res/drawable folders. For example: // - res/drawable-nodpi/ic_logo.xml // - res/drawable-xxhdpi/ic_logo.png // In your Compose code Icon( painter = painterResource(id = R.drawable.ic_logo), contentDescription = null // decorative element )
painterResource
在主线程上解码和解析资源内容。
动画矢量可绘制对象
使用AnimatedImageVector.animatedVectorResource
API 加载动画矢量可绘制 XML。此方法返回一个AnimatedImageVector
实例。为了显示动画图像,请使用rememberAnimatedVectorPainter
方法创建一个Painter
,该Painter
可用于Image
和Icon
可组合项。rememberAnimatedVectorPainter
方法的布尔值atEnd
参数指示是否应在所有动画结束时绘制图像。如果与可变状态一起使用,则此值的更改会触发相应的动画。
// Files in res/drawable folders. For example: // - res/drawable/ic_hourglass_animated.xml // In your Compose code val image = AnimatedImageVector.animatedVectorResource(R.drawable.ic_hourglass_animated) val atEnd by remember { mutableStateOf(false) } Icon( painter = rememberAnimatedVectorPainter(image, atEnd), contentDescription = null // decorative element )
图标
Jetpack Compose 带有Icons
对象,它是Compose中使用Material Icons的入口点。共有五个不同的图标主题:填充、轮廓、圆角、双色和锐角。每个主题都包含相同的图标,但具有不同的视觉风格。您通常应选择一个主题并在整个应用程序中使用它以保持一致性。
要绘制图标,您可以使用Icon
可组合项,它应用色调并提供与图标匹配的布局大小。
Icon(Icons.Rounded.Menu, contentDescription = "Localized description")
一些最常用的图标可作为androidx.compose.material
依赖项的一部分使用。要使用任何其他 Material 图标,请将material-icons-extended
依赖项添加到build.gradle
文件中。
dependencies {
def composeBom = platform('androidx.compose:compose-bom:2024.10.01')
implementation composeBom
implementation 'androidx.compose.material:material-icons-extended'
}
字体
要在 Compose 中使用字体,请将字体文件直接下载并捆绑到您的 APK 中,方法是将它们放在res/font
文件夹中。
使用Font
API 加载每个字体,并使用它们创建一个FontFamily
,您可以在TextStyle
实例中使用它来创建您自己的Typography
。以下是Crane compose 示例及其Typography.kt
文件中的代码。
// Define and load the fonts of the app private val light = Font(R.font.raleway_light, FontWeight.W300) private val regular = Font(R.font.raleway_regular, FontWeight.W400) private val medium = Font(R.font.raleway_medium, FontWeight.W500) private val semibold = Font(R.font.raleway_semibold, FontWeight.W600) // Create a font family to use in TextStyles private val craneFontFamily = FontFamily(light, regular, medium, semibold) // Use the font family to define a custom typography val craneTypography = Typography( titleLarge = TextStyle( fontFamily = craneFontFamily ) /* ... */ ) // Pass the typography to a MaterialTheme that will create a theme using // that typography in the part of the UI hierarchy where this theme is used @Composable fun CraneTheme(content: @Composable () -> Unit) { MaterialTheme(typography = craneTypography) { content() } }
有关在 Compose 中使用可下载字体的更多信息,请参见可下载字体页面。
在Compose 主题文档中了解更多关于排印的信息
为您推荐
- 注意:当 JavaScript 关闭时显示链接文本
- 加载图像 {:#loading-images}
- Compose 中的 Material Design 2
- Compose 中的自定义设计系统