【Android-JetpackCompose】11、主题设置:Theme、Colors、Typography、Shapes

本文主要是介绍【Android-JetpackCompose】11、主题设置:Theme、Colors、Typography、Shapes,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、颜色
  • 二、定义 Theme
  • 三、Color 的 Alpha 值
  • 四、文本、自定义组件

首先,从下面的仓库克隆代码:

git clone https://github.com/googlecodelabs/android-compose-codelabs.git
cd android-compose-codelabs/ThemingCodelab

一、颜色

Material Design 定义了一些从语义上命名的颜色:
在这里插入图片描述

primary 是主要品牌颜色,secondary 用于提供强调色。您可以为形成对比的区域提供颜色更深/更浅的变体。background 和 surface 这两种颜色用于那些容纳在概念上驻留在应用“Surface”的组件的容器。此外,Material 还定义了“on”颜色,即针对具名颜色上层的内容使用的颜色;例如,“surface”色容器中的文本应采用“on surface”颜色。

通过定义具名颜色,可以提供备用调色板,例如浅色主题和深色主题:

在这里插入图片描述

二、定义 Theme

新建 Colors.kt 代码如下:

package com.codelab.theming.ui.startimport androidx.compose.ui.graphics.Colorval Red700 = Color(0xffdd0d3c)
val Red800 = Color(0xffd00036)
val Red900 = Color(0xffc20029)
val Red200 = Color(0xfff297a2)
val Red300 = Color(0xffea6d7e)

新建 Shape.kt 代码如下:

package com.codelab.theming.ui.startimport androidx.compose.foundation.shape.CutCornerShape
import androidx.compose.foundation.shape.RoundedCornerShape
import androidx.compose.material.Shapes
import androidx.compose.ui.unit.dpval JetnewsShapes = Shapes(small = CutCornerShape(topStart = 8.dp),medium = CutCornerShape(topStart = 24.dp),large = RoundedCornerShape(8.dp)
)

新建 Typography.kt 代码如下:

package com.codelab.theming.ui.startimport androidx.compose.material.Typography
import androidx.compose.ui.text.TextStyle
import androidx.compose.ui.text.font.Font
import androidx.compose.ui.text.font.FontFamily
import androidx.compose.ui.text.font.FontWeight
import androidx.compose.ui.unit.sp
import com.codelab.theming.Rprivate val Montserrat = FontFamily(Font(R.font.montserrat_regular),Font(R.font.montserrat_medium, FontWeight.W500),Font(R.font.montserrat_semibold, FontWeight.W600)
)private val Domine = FontFamily(Font(R.font.domine_regular),Font(R.font.domine_bold, FontWeight.Bold)
)val JetnewsTypography = Typography(h4 = TextStyle(fontFamily = Montserrat,fontWeight = FontWeight.W600,fontSize = 30.sp),h5 = TextStyle(fontFamily = Montserrat,fontWeight = FontWeight.W600,fontSize = 24.sp),h6 = TextStyle(fontFamily = Montserrat,fontWeight = FontWeight.W600,fontSize = 20.sp),subtitle1 = TextStyle(fontFamily = Montserrat,fontWeight = FontWeight.W600,fontSize = 16.sp),subtitle2 = TextStyle(fontFamily = Montserrat,fontWeight = FontWeight.W500,fontSize = 14.sp),body1 = TextStyle(fontFamily = Domine,fontWeight = FontWeight.Normal,fontSize = 16.sp),body2 = TextStyle(fontFamily = Montserrat,fontSize = 14.sp),button = TextStyle(fontFamily = Montserrat,fontWeight = FontWeight.W500,fontSize = 14.sp),caption = TextStyle(fontFamily = Montserrat,fontWeight = FontWeight.Normal,fontSize = 12.sp),overline = TextStyle(fontFamily = Montserrat,fontWeight = FontWeight.W500,fontSize = 12.sp)
)

新建 Theme.kt 代码如下:

package com.codelab.theming.ui.startimport androidx.compose.foundation.isSystemInDarkTheme
import androidx.compose.material.MaterialTheme
import androidx.compose.material.darkColors
import androidx.compose.material.lightColors
import androidx.compose.runtime.Composable
import androidx.compose.ui.graphics.Color@Composable
fun JetnewsTheme(darkTheme: Boolean = isSystemInDarkTheme(), content: @Composable () -> Unit) {MaterialTheme(content = content, colors = if (darkTheme) DarkColors else LightColors, typography = JetnewsTypography, shapes = JetnewsShapes)
}private val LightColors = lightColors(primary = Red700,primaryVariant = Red900,onPrimary = Color.White,secondary = Red700,secondaryVariant = Red900,onSecondary = Color.White,error = Red800
)private val DarkColors = darkColors(primary = Red300,primaryVariant = Red700,onPrimary = Color.Black,secondary = Red300,onSecondary = Color.Black,error = Red200
)

最终,在 Home.kt 中引用 Theme,代码如下:

@Preview("Featured Post")
@Composable
private fun FeaturedPostPreview() {val post = remember { PostRepo.getFeaturedPost() }JetnewsTheme {FeaturedPost(post = post)}
}@Preview("Featured Post • Dark")
@Composable
private fun FeaturedPostDarkPreview() {val post = remember { PostRepo.getFeaturedPost() }JetnewsTheme(darkTheme = true) {FeaturedPost(post = post)}
}

预览效果如下:

在这里插入图片描述

三、Color 的 Alpha 值

通常情况下,我们希望通过强调或弱化内容来突出重点并体现出视觉上的层次感。Material Design 建议采用不同的不透明度来传达这些不同的重要程度。

Jetpack Compose 通过 LocalContentAlpha 实现此功能。您可以通过为此 CompositionLocal 提供一个值来为层次结构指定内容 Alpha 值。子可组合项可以使用此值,例如 Text 和 Icon 默认使用 LocalContentColor 的组合,已调整为使用 LocalContentAlpha。Material 指定了一些标准 Alpha 值(high、medium、disabled),这些值由 ContentAlpha 对象建模。请注意,MaterialTheme 默认将 LocalContentAlpha 设置为 ContentAlpha.high。

// By default, both Icon & Text use the combination of LocalContentColor &
// LocalContentAlpha. De-emphasize content by setting a different content alpha
CompositionLocalProvider(LocalContentAlpha provides ContentAlpha.medium) {Text(...)
}
CompositionLocalProvider(LocalContentAlpha provides ContentAlpha.disabled) {Icon(...)Text(...)
}

我们将使用内容 Alpha 值来阐明精选博文的信息层次结构。在 Home.kt 的 PostMetadata 可组合项中,重点突出元数据 medium:

+ CompositionLocalProvider(LocalContentAlpha provides ContentAlpha.medium) {Text(text = text,modifier = modifier)
+ }

效果如下,主标题的透明度,和次标题的透明度不同,效果如下:

在这里插入图片描述

四、文本、自定义组件

如果您需要自定义 TextStyle,可以对其执行 copy 操作并替换相关属性(它只是一个 data class),或者让 Text 可组合项接受大量样式参数,这些参数会叠加到任何 TextStyle 的上层:

Text(text = "Hello World",style = MaterialTheme.typography.body1.copy(background = MaterialTheme.colors.secondary)
)

Compose 没有提供用于提取组件样式(例如,Android View 样式或 CSS 样式)的明确方法。由于所有 Compose 组件都是用 Kotlin 编写的,因此还可通过其他方法来实现相同的目的。您可以改为创建自己的自定义组件库,并在整个应用中使用这些组件。

下例中,Header 可组合项本质上是样式化的 Text,可供我们在整个应用中使用,代码如下:

@Composable
fun Header(text: String,modifier: Modifier = Modifier
) {Surface(color = MaterialTheme.colors.onSurface.copy(alpha = 0.1f),contentColor = MaterialTheme.colors.primary,modifier = modifier.semantics { heading() }) {Text(text = text,style = MaterialTheme.typography.subtitle2,modifier = Modifier.fillMaxWidth().padding(horizontal = 16.dp, vertical = 8.dp))}
}

可通过下文定制自定义的 Button,代码如下:

@Composable
fun AcmeButton(// expose Button params consumers should be able to change
) {val acmeButtonShape: Shape = ...Button(shape = acmeButtonShape,// other params)
}
@Composable
fun LoginButton(onClick: () -> Unit,modifier: Modifier = Modifier,content: @Composable RowScope.() -> Unit
) {Button(colors = ButtonConstants.defaultButtonColors(backgroundColor = MaterialTheme.colors.secondary),onClick = onClick,modifier = modifier) {ProvideTextStyle(...) { // set our own text stylecontent()}}
}

这篇关于【Android-JetpackCompose】11、主题设置:Theme、Colors、Typography、Shapes的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/169663

相关文章

JAVA Calendar设置上个月时,日期不存在或错误提示问题及解决

《JAVACalendar设置上个月时,日期不存在或错误提示问题及解决》在使用Java的Calendar类设置上个月的日期时,如果遇到不存在的日期(如4月31日),默认会自动调整到下个月的相应日期(... 目录Java Calendar设置上个月时,日期不存在或错误提示java进行日期计算时如果出现不存在的

Java利用Spire.XLS for Java自动化设置Excel的文档属性

《Java利用Spire.XLSforJava自动化设置Excel的文档属性》一个专业的Excel文件,其文档属性往往能大大提升文件的可管理性和可检索性,下面我们就来看看Java如何使用Spire... 目录Spire.XLS for Java 库介绍与安装Java 设置内置的 Excel 文档属性Java

idea设置快捷键风格方式

《idea设置快捷键风格方式》在IntelliJIDEA中设置快捷键风格,打开IDEA,进入设置页面,选择Keymap,从Keymaps下拉列表中选择或复制想要的快捷键风格,点击Apply和OK即可使... 目录idea设www.chinasem.cn置快捷键风格按照以下步骤进行总结idea设置快捷键pyth

MyBatis配置文件中最常用的设置

《MyBatis配置文件中最常用的设置》文章主要介绍了MyBatis配置的优化方法,包括引用外部的properties配置文件、配置外置以实现环境解耦、配置文件中最常用的6个核心设置以及三种常用的Ma... 目录MyBATis配置优化mybatis的配置中引用外部的propertis配置文件⚠️ 注意事项X

Android使用java实现网络连通性检查详解

《Android使用java实现网络连通性检查详解》这篇文章主要为大家详细介绍了Android使用java实现网络连通性检查的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录NetCheck.Java(可直接拷贝)使用示例(Activity/Fragment 内)权限要求

2025最新版Android Studio安装及组件配置教程(SDK、JDK、Gradle)

《2025最新版AndroidStudio安装及组件配置教程(SDK、JDK、Gradle)》:本文主要介绍2025最新版AndroidStudio安装及组件配置(SDK、JDK、Gradle... 目录原生 android 简介Android Studio必备组件一、Android Studio安装二、A

Java JAR 启动内存参数配置指南(从基础设置到性能优化)

《JavaJAR启动内存参数配置指南(从基础设置到性能优化)》在启动Java可执行JAR文件时,合理配置JVM内存参数是保障应用稳定性和性能的关键,本文将系统讲解如何通过命令行参数、环境变量等方式... 目录一、核心内存参数详解1.1 堆内存配置1.2 元空间配置(MetASPace)1.3 线程栈配置1.

C#借助Spire.XLS for .NET实现Excel工作表自动化样式设置

《C#借助Spire.XLSfor.NET实现Excel工作表自动化样式设置》作为C#开发者,我们经常需要处理Excel文件,本文将深入探讨如何利用C#代码,借助强大的Spire.XLSfor.N... 目录为什么需要自动化工作表样式使用 Spire.XLS for .NET 实现工作表整体样式设置样式配置

Java实现为PDF设置背景色和背景图片

《Java实现为PDF设置背景色和背景图片》在日常的文档处理中,PDF格式因其稳定性和跨平台兼容性而广受欢迎,本文将深入探讨如何利用Spire.PDFforJava库,以简洁高效的方式为你的PDF文档... 目录库介绍与安装步骤Java 给 PDF 设置背景颜色Java 给 PDF 设置背景图片总结在日常的

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型