首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >无法在材料设计3中使用LocalContentAlpha更改文本重点

无法在材料设计3中使用LocalContentAlpha更改文本重点
EN

Stack Overflow用户
提问于 2022-06-10 12:08:37
回答 1查看 413关注 0票数 1

目前,我正在迁移我的一个应用程序到材料设计3,这是完全用Kotlin编写的Jetpack撰写。

在使用MaterialDesign2时,我能够使用下面的代码更改文本的重点。

代码语言:javascript
运行
复制
CompositionLocalProvider(LocalContentAlpha provides ContentAlpha.medium) {
                Text(
                    text = "Hello, world",
                    style = MaterialTheme.typography.h6,
                    fontWeight = FontWeight.SemiBold,
                )
            }

然而,相同的代码不适用于材料设计3,文本有默认的重点。此外,我找不到相关功能的材料设计3。我想知道是否有任何官方的方式来达到同样的效果。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-06-13 12:59:21

MaterialTheme.typography.h6来自于Matter2,这意味着您也在使用来自Matter2的可组合的Text

材料3 h6的模拟物是MaterialTheme.typography.headlineSmall

确保TextMaterialTheme都有正确的导入--这些导入应该从androidx.compose.material3包中导入。还要确保您提供了一个正确导入的主题,例如这里

错误的导入是迁移到M3时最常见的错误,所以请耐心等待。

还请注意,LocalContentAlpha并不存在于M3中,提供M2版本对M3视图没有任何影响。您可以比较Text是如何在M2M3中确定其颜色的。

我不确定以后是否会添加它(毕竟是alpha ),还是在M3中以其他方式处理它,这里有一个解决办法(这不是很完美):

代码语言:javascript
运行
复制
CompositionLocalProvider(LocalContentColor provides LocalContentColor.current.copy(alpha = 0.4f)) {

附注:LocalContentColor也需要从M3导入

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72574071

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档