A partir de 27 de março de 2025, recomendamos usar android-latest-release em vez de aosp-main para criar e contribuir com o AOSP. Para mais informações, consulte Mudanças no AOSP.
Cada um deles é composto por um conjunto de 13 cores com vários valores de luminância
definidos, conforme descrito em
R.color,
mas com valores de matiz e croma indefinidos que podem ser gerados dinamicamente pelo
sistema Android no momento da execução.
Estilos de tema para cores dinâmicas
A partir do Android 13, seis estilos de tema diferentes
são compatíveis com variações no algoritmo de cores dinâmicas que mantêm
as necessidades e expectativas de contraste do desenvolvedor. Eles estão listados para gerar as
65 cores dinâmicas usadas pelos apps:
TONAL_SPOT é uma paleta de vibração média que usa uma cor system_accent3_0
análoga à cor system_accent1_0 (transferida da versão do Android 12
e ligeiramente ajustada).
VIBRANT é uma paleta de alta vibração que mistura harmoniosamente a mudança sutil
entre as cores.
EXPRESSIVE é uma paleta de alta vibração que combina cores de destaque
inesperadas e únicas.
SPRITZ é uma paleta de baixa vibração que cria uma lavagem suave entre as cores.
O RAINBOW usa tons cromáticos e superfícies neutras para criar uma experiência de cores mais
sutil para os usuários.
NÃO É RECOMENDÁVEL usar esse método com a extração de cores
baseada em plano de fundo. Em vez disso, use temas de cores estáticos.
FRUIT_SALAD oferece duas cores de tom para dar mais expressão aos usuários.
NÃO É RECOMENDÁVEL usar esse método com a extração de cores
baseada em plano de fundo. Em vez disso, use temas de cores estáticos.
O tema do sistema é controlado pela mesma configuração do Android 12,
que é Settings.Secure.THEME_CUSTOMIZATION_OVERLAY_PACKAGES. Para o Android
13, é necessária apenas uma chave no JSON que envie a
cor de origem para gerar as 65 paletas de cores:
Cada paleta tonal tem 13 valores de cor que terminam nos índices 0, 10, 50, 100,
200, 300, 400, 500, 600, 700, 800, 900 e 1000.
A API resultante é uma combinação do nome da paleta tonal, que termina no
índice. Por exemplo:
R.color#system_accent1_10
Como uma paleta tonal dinâmica é gerada?
Uma paleta tonal dinâmica precisa ser gerada a partir de uma única cor de origem que precisa
ser derivada do plano de fundo usando
com.android.systemui.monet.ColorScheme#getSeedColors, que fornece várias
cores de origem válidas. Se nenhuma das cores fornecidas atender ao requisito de cor
de origem, a cor de origem única precisará usar o valor 0xFF1B6EF3.
O conteúdo e os exemplos de código nesta página estão sujeitos às licenças descritas na Licença de conteúdo. Java e OpenJDK são marcas registradas da Oracle e/ou suas afiliadas.
Última atualização 2025-08-24 UTC.
[[["Fácil de entender","easyToUnderstand","thumb-up"],["Meu problema foi resolvido","solvedMyProblem","thumb-up"],["Outro","otherUp","thumb-up"]],[["Não contém as informações de que eu preciso","missingTheInformationINeed","thumb-down"],["Muito complicado / etapas demais","tooComplicatedTooManySteps","thumb-down"],["Desatualizado","outOfDate","thumb-down"],["Problema na tradução","translationIssue","thumb-down"],["Problema com as amostras / o código","samplesCodeIssue","thumb-down"],["Outro","otherDown","thumb-down"]],["Última atualização 2025-08-24 UTC."],[],[],null,["# Dynamic color\n\nMaterial You design was launched with the Android 12\nrelease and expanded with Android 13.\n\nThis page focuses on updates to the Material You logic to help you integrate\nwith richer dynamic color support.\n\nDynamic color tonal palettes\n----------------------------\n\nStarting with Android 12, the following dynamic color\ntonal palettes are supported:\n\n- [`system_accent1_0`](https://developer.android.com/reference/android/R.color#system_accent1_0)\n- [`system_accent2_0`](https://developer.android.com/reference/android/R.color#system_accent2_0)\n- [`system_accent3_0`](https://developer.android.com/reference/android/R.color#system_accent3_0)\n- [`system_neutral1_0`](https://developer.android.com/reference/android/R.color#system_neutral1_0)\n- [`system_neutral2_0`](https://developer.android.com/reference/android/R.color#system_neutral2_0))\n\nEach of them comprise of a set of 13 colors with defined various luminance\nvalues as described at\n[`R.color`](https://developer.android.com/reference/android/R.color),\nbut with undefined hue and chroma values that can be dynamically generated by\nthe Android system at runtime.\n\nTheme styles for dynamic color\n------------------------------\n\nStarting with Android 13, six different theme styles\nare supported with variations on the dynamic color algorithm that maintain\ndeveloper needs and contrast expectations. These are listed for generating the\n65 dynamic color used by apps:\n\n- `TONAL_SPOT` is a mid-vibrancy palette that uses an `system_accent3_0` color analogous to the `system_accent1_0` color (carried over from the Android 12 release and slightly adjusted).\n- `VIBRANT` is a high-vibrancy palette that harmoniously blends subtle shift between colors.\n- `EXPRESSIVE` is a high-vibrancy palette that pairs unexpected and unique accents colors together.\n- `SPRITZ` is a low-vibrancy palette that creates a soft wash between colors.\n- `RAINBOW` uses both chromatic accents and neutral surfaces to create a more subtle color experience for users.\n - This is **NOT RECOMMENDED** to be used with wallpaper-based color extraction and should instead be used with static color themes.\n- `FRUIT_SALAD` provides *two tone colors* to give users more expression.\n - This is **NOT RECOMMENDED** to be used with wallpaper-based color extraction and should instead be used with static color themes.\n\nThe system theme is driven by the same setting as it was in Android 12,\nwhich is `Settings.Secure.THEME_CUSTOMIZATION_OVERLAY_PACKAGES`. For Android\n13, it requires only one key on its JSON that sends the\nsource color to generate the 65 color palettes: \n\n {\n \"android.theme.customization.system_palette\":\"746BC1\"\n }\n\nThe default theme style is `TONAL_SPOT`, but you can optionally specify one of\nthe other theme styles with an additional key with the JSON above: \n\n {\n \"android.theme.customization.system_palette\":\"746BC1\"\n \"android.theme.customization.theme_style\":\"EXPRESSIVE\"\n }\n\n| **Note:** You aren't required to expose ALL of the new theme styles in your UI, and can decide which to expose based on your user/brand needs. However, dynamic color palettes **MUST** be generated through one of these theme styles as CTS-tested by `SystemPaletteTest#testThemeStyles` and mandated by CDD.\n\nIntegrating dynamic color\n-------------------------\n\nFor guidelines on integrating dynamic color, see [Integrating Material You\nDesign](/docs/core/display/material).\n\nFrequently asked questions (FAQs)\n---------------------------------\n\n### What does the dynamic tonal palette API include?\n\n- There are five tonal palettes:\n\n - [`system_accent1`](https://developer.android.com/reference/android/R.color#system_accent1_0)\n - [`system_accent2`](https://developer.android.com/reference/android/R.color#system_accent2_0)\n - [`system_accent3`](https://developer.android.com/reference/android/R.color#system_accent3_0)\n - [`system_neutral1`](https://developer.android.com/reference/android/R.color#system_neutral1_0)\n - [`system_neutral2`](https://developer.android.com/reference/android/R.color#system_neutral2_0)\n- Each tonal palette has 13 color values ending in the indexes 0, 10, 50, 100,\n 200, 300, 400, 500, 600, 700, 800, 900, and 1000.\n\n- The resulting API is a combination of the tonal palette name, ending in the\n index. For example:\n [`R.color#system_accent1_10`](https://developer.android.com/reference/android/R.color#system_accent1_10)\n\n### How is a dynamic tonal pallet generated?\n\nA dynamic tonal palette must be generated from a single source color that should\nbe derived from wallpaper using\n`com.android.systemui.monet.ColorScheme#getSeedColors`, which provides multiple\nvalid source colors. If none of the provided colors meet the source color\nrequirement, the single source color should use the value `0xFF1B6EF3`."]]