使用 Material Design 组件实现深色主题

本文详细介绍了如何使用Material Design组件在Android应用中实现深色主题,包括更改主题、选择模式、测试和调整颜色,以适应深色背景,并提供用户更好的视觉体验和能源效率。文章还探讨了深色主题的重要性,以及Material Design深色主题的设计原则和调色板应用。
摘要由CSDN通过智能技术生成

作者 / Chris Banes, Android 开发者关系团队工程师

Material 主题 (Theming) 涵盖的内容很多,但都旨在帮助开发者打造优良且富有表现力的用户体验,如果您对 Material 主题的颜色、字体和形状内容感兴趣的话,欢迎阅读 Nick Rout 的系列博文:

  • Material Design 组件: Android 上的颜色主题

    https://medium.com/androiddevelopers/material-theming-with-mdc-color-860dbba8ce2f

  • Material Design 组件: Android 上的字体主题

    https://medium.com/androiddevelopers/material-theming-with-mdc-type-8c2013430247

  • Material Design 组件: Android 上的形状主题

    https://medium.com/androiddevelopers/material-theming-with-mdc-shape-126c4e5cd7b4

本文将在此基础上,探讨如何调整应用以支持深色主题。

用户可选的深色主题在 Android 10 中被添加到 Android 平台,但应用开发者们应该早就接触过深色主题了: 在 Android 5.0 (Lollipop) 之前,Android 设备的默认主题都是深色!

  • Android 10

    https://developer.android.google.cn/about/versions/10

  • Android 5.0

    https://developer.android.google.cn/about/versions/lollipop

去年加入的深色主题的特别之处在于,平台增加了一个设备级别的设置,让用户可以对设备整体的主题进行控制,同时还能设置应用单独的主题。

除了最近加入的设备级别设置,在 material.io 上还提供了全面的设计指南,我们将在本文中详细介绍。

  • 设计指南: 深色主题

    https://material.io/design/color/dark-theme.html

为什么要支持深色主题?

首先,到底为什么要支持深色主题?在 material.io 上很好地总结了深色主题的技术优势 (我加粗了想要强调的部分):

深色主题可以降低设备屏幕发出的亮度 […]。能够通过减少用眼疲劳、根据当前照明条件调节亮度,以及让屏幕在黑暗环境中也便于观看等方式,改善视觉工效,同时还能降低电量消耗 [OLED 显示屏]。

  • Material Design: 深色主题

    https://material.io/design/color/dark-theme.html#usage

不过,最根本的原因是用户想要深色主题——这是用户们一直以来的首要需求,因此 Android 团队添加了系统级别的深色主题设置。

相信看到这里,您已经打算在应用中支持深色主题了,接下来就让我们来看看怎么实现它。

快速入门

要向应用添加深色主题,可以使用 Android 版的 Material Design 组件 (MDC)。

  • Material Design 组件: Android

    https://material.io/develop/android/

1. 更改主题

您需要更改主题,使其扩展自一个 Theme.MaterialComponents.DayNight 主题:

<style name="Theme.MyApp"
    parent="Theme.MaterialComponents.DayNight">
    <!-- Other theme attributes -->
</style>

2. 选择模式 (可选)

这是可选步骤,可以支持 Android 10 之前版本的设备。由于 Android 10 之前大多数设备没有系统级的深色主题设置*,应用可以提供自己的应用内设置,允许用户按应用选择主题。

* 严格来说并不绝对是这样,因为有些设备制造商已经在运行 Android 9 (和更低版本) 的设备上添加了系统级深色主题。只不过这一点无法在运行时确定。

△ 应用内深色主题设置示例

这在 Android 10 及以上版本的系统中也很有用,因为这让用户可以根据需要覆盖系统设置。比如用户将设备主题设置为按时间调整,但又希望社交应用始终为深色主题。

为了做到这一点,(MDC 使用的) AppCompat 提供了一个 API 来设置模式: AppCompatDelegate.setDefaultNightMode()。通常,当偏好设置发生变化时就会调用这个 API。

  • AppCompat

    https://developer.android.google.cn/jetpack/androidx/releases/appcompat

  • setDefaultNightMode()

    https://developer.android.google.cn/reference/androidx/appcompat/app/AppCompatDelegate#setDefaultNightMode(int)

如果您想进一步了解 AppCompat 中夜间模式功能的运作细节,可以阅读这篇博文。

  • DayNight - 在应用中添加深色主题

    h

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值