目前,我正在迁移我的一个应用程序到材料设计3,这是完全用Kotlin编写的Jetpack撰写。
在使用MaterialDesign2时,我能够使用下面的代码更改文本的重点。
CompositionLocalProvider(LocalContentAlpha provides ContentAlpha.medium) {
Text(
text = "Hello, world",
style = MaterialTheme.typography.h6,
fontWeight = FontWeight.SemiBold,
)
}
然而,相同的代码不适用于材料设计3,文本有默认的重点。此外,我找不到相关功能的材料设计3。我想知道是否有任何官方的方式来达到同样的效果。
发布于 2022-06-13 12:59:21
MaterialTheme.typography.h6
来自于Matter2,这意味着您也在使用来自Matter2的可组合的Text
。
材料3 h6
的模拟物是MaterialTheme.typography.headlineSmall
。
确保Text
和MaterialTheme
都有正确的导入--这些导入应该从androidx.compose.material3
包中导入。还要确保您提供了一个正确导入的主题,例如这里。
错误的导入是迁移到M3时最常见的错误,所以请耐心等待。
还请注意,LocalContentAlpha
并不存在于M3中,提供M2版本对M3视图没有任何影响。您可以比较Text
是如何在M2和M3中确定其颜色的。
我不确定以后是否会添加它(毕竟是alpha ),还是在M3中以其他方式处理它,这里有一个解决办法(这不是很完美):
CompositionLocalProvider(LocalContentColor provides LocalContentColor.current.copy(alpha = 0.4f)) {
附注:LocalContentColor
也需要从M3导入
https://stackoverflow.com/questions/72574071
复制相似问题