首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何缩短MaterialTheme.colors.primary?

如何缩短MaterialTheme.colors.primary?
EN

Stack Overflow用户
提问于 2022-08-14 12:58:21
回答 4查看 65关注 0票数 2

在编写合成代码时,我们经常使用MaterialTheme代码。有办法缩短代码的这一部分吗?例如:mColor.primay

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2022-08-15 11:03:38

我认为最好的答案是:

代码语言:javascript
复制
val mColors: MColor()   @Composable get() = MyTheme.colors

我们可以这样称呼颜色:mColors.primary,我们也可以为排版,形状和尺寸做这个。

票数 2
EN

Stack Overflow用户

发布于 2022-08-14 13:30:04

这不是一个Jetpack组合解决方案-更多的是“使用Kotlin语言特性”。

您可以使用with作用域函数来生成MaterialTheme,这是一个object,是一个隐式接收器。然后,您可以引用colors.primarycolors.whatever,而不必说MaterialTheme

您可以用一个with块包围整个封闭函数:

代码语言:javascript
复制
@Composable
fun foo() {
    with(MaterialTheme) {
        // compose your view here...
        // and you can say "colors.primary" instead of 
        // "MaterialTheme.colors.primary" in here
    }
}

或者,只需使用类型别名来缩短名称MaterialTheme

代码语言:javascript
复制
typealias MT = MaterialTheme
// now you can say "MT.colors.primary" instead of "MaterialTheme.colors.primary"
票数 5
EN

Stack Overflow用户

发布于 2022-08-14 13:12:45

我想这可以用不同的方式来完成。其中之一是

代码语言:javascript
复制
val mColor
    get() =  @Composable{
        MaterialTheme.colors
    }

用法

代码语言:javascript
复制
mColor().primary
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73351839

复制
相关文章

相似问题

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