Material Design 3 в Compose

Jetpack Compose предлагает реализацию Material Design 3 , следующую эволюцию Material Design. Material 3 включает обновленные темы, компоненты и функции персонализации Material You, такие как динамический цвет, и разработан с учетом нового визуального стиля и системного пользовательского интерфейса на Android 12 и более поздних версиях.

Ниже мы демонстрируем реализацию Material Design 3 на примере приложения «Ответ» . Пример ответа полностью основан на Material Design 3.

Пример приложения «Ответ» с использованием Material Design 3
Рисунок 1 . Пример приложения «Ответ» с использованием Material Design 3

Зависимость

Чтобы начать использовать Material 3 в своем приложении Compose, добавьте зависимость Compose Material 3 в файлы build.gradle :

implementation "androidx.compose.material3:material3:$material3_version"

После добавления зависимости вы можете начать добавлять в свои приложения системы Material Design, включая цвет, типографику и форму.

Экспериментальные API

Некоторые API M3 считаются экспериментальными. В таких случаях вам необходимо согласиться на уровне функции или файла, используя аннотацию ExperimentalMaterial3Api :

// import androidx.compose.material3.ExperimentalMaterial3Api
@Composable
fun AppComposable() {
    // M3 composables
}

Тематика материалов

Тема M3 содержит следующие подсистемы: цветовая схема , типографика и фигуры . Когда вы настраиваете эти значения, ваши изменения автоматически отражаются в компонентах M3, которые вы используете для создания своего приложения.

Подсистемы материального дизайна: цвет, типографика и формы
Рисунок 2 . Подсистемы материального дизайна: цвет, типографика и формы

Jetpack Compose реализует эти концепции с помощью компонуемого M3 MaterialTheme :

MaterialTheme(
    colorScheme = /* ...
    typography = /* ...
    shapes = /* ...
) {
    // M3 app content
}

Чтобы оформить содержимое вашего приложения, определите цветовую схему, типографику и формы, специфичные для вашего приложения.

Цветовая гамма

Основой цветовой схемы является набор из пяти ключевых цветов. Каждый из этих цветов относится к тоновой палитре из 13 тонов, которые используются компонентами Материала 3. Например, это цветовая схема светлой темы для ответа :

Пример цветовой схемы подсветки приложения для ответа
Рисунок 3 . Пример цветовой схемы подсветки приложения для ответа

Подробнее о Цветовой схеме и цветовых ролях читайте здесь.

Создание цветовых схем

Хотя вы можете создать собственную ColorScheme вручную, зачастую проще создать ее, используя исходные цвета вашего бренда. Инструмент Material Theme Builder позволяет вам сделать это и при необходимости экспортировать код темы Compose. Создаются следующие файлы:

  • Color.kt содержит цвета вашей темы со всеми ролями, определенными как для светлых, так и для темных цветов темы.

val md_theme_light_primary = Color(0xFF476810)
val md_theme_light_onPrimary = Color(0xFFFFFFFF)
val md_theme_light_primaryContainer = Color(0xFFC7F089)
// ..
// ..

val md_theme_dark_primary = Color(0xFFACD370)
val md_theme_dark_onPrimary = Color(0xFF213600)
val md_theme_dark_primaryContainer = Color(0xFF324F00)
// ..
// ..

  • Theme.kt содержит настройки светлых и темных цветовых схем, а также тему приложения.

private val LightColorScheme = lightColorScheme(
    primary = md_theme_light_primary,
    onPrimary = md_theme_light_onPrimary,
    primaryContainer = md_theme_light_primaryContainer,
    // ..
)
private val DarkColorScheme = darkColorScheme(
    primary = md_theme_dark_primary,
    onPrimary = md_theme_dark_onPrimary,
    primaryContainer = md_theme_dark_primaryContainer,
    // ..
)

@Composable
fun ReplyTheme(
    darkTheme: Boolean = isSystemInDarkTheme(),
    content: @Composable () -> Unit
) {
    val colorScheme =
        if (!darkTheme) {
            LightColorScheme
        } else {
            DarkColorScheme
        }
    MaterialTheme(
        colorScheme = colorScheme,
        content = content
    )
}

Для поддержки светлых и темных тем используйте isSystemInDarkTheme() . В зависимости от настроек системы определите, какую цветовую схему использовать: светлую или темную.

Динамические цветовые схемы

Динамический цвет — ключевая часть Material You, в которой алгоритм извлекает пользовательские цвета из обоев пользователя для применения к их приложениям и системному пользовательскому интерфейсу. Эта цветовая палитра используется в качестве отправной точки для создания светлых и темных цветовых схем.

Пример динамической темы приложения для ответа из обоев (слева) и темы приложения по умолчанию (справа)
Рисунок 4 . Пример динамической темы приложения для ответа из обоев (слева) и темы приложения по умолчанию (справа)

Динамический цвет доступен на Android 12 и более поздних версиях. Если доступен динамический цвет, вы можете настроить динамическую ColorScheme . Если нет, вам следует вернуться к использованию пользовательской светлой или темной ColorScheme .

ColorScheme предоставляет функции компоновщика для создания динамической светлой или темной цветовой схемы:

// Dynamic color is available on Android 12+
val dynamicColor = Build.VERSION.SDK_INT >= Build.VERSION_CODES.S
val colors = when {
    dynamicColor && darkTheme -> dynamicDarkColorScheme(LocalContext.current)
    dynamicColor && !darkTheme -> dynamicLightColorScheme(LocalContext.current)
    darkTheme -> DarkColorScheme
    else -> LightColorScheme
}

Использование цвета

Вы можете получить доступ к цветам темы Material в своем приложении через MaterialTheme.colorScheme :

Text(
    text = "Hello theming",
    color = MaterialTheme.colorScheme.primary
)

Каждую цветовую роль можно использовать в различных местах в зависимости от состояния, значимости и акцента компонента.

  • Первичный — это базовый цвет, используемый для основных компонентов, таких как заметные кнопки, активные состояния и оттенок приподнятых поверхностей.
  • Цвет вторичного ключа используется для менее заметных компонентов пользовательского интерфейса, таких как фильтрующие элементы, и расширяет возможности цветового выражения.
  • Третичный ключевой цвет используется для определения роли контрастных акцентов, которые можно использовать для балансировки основных и второстепенных цветов или для привлечения повышенного внимания к элементу.

В примере дизайна приложения «Ответ» используется цвет основного контейнера поверх основного контейнера, чтобы подчеркнуть выбранный элемент.

Основной контейнер и текстовые поля с цветом основного контейнера.
Рисунок 5 . Основной контейнер и текстовые поля с цветом основного контейнера.

Card(
    colors = CardDefaults.cardColors(
        containerColor =
        if (isSelected) MaterialTheme.colorScheme.primaryContainer
        else
            MaterialTheme.colorScheme.surfaceVariant
    )
) {
    Text(
        text = "Dinner club",
        style = MaterialTheme.typography.bodyLarge,
        color =
        if (isSelected) MaterialTheme.colorScheme.onPrimaryContainer
        else MaterialTheme.colorScheme.onSurface,
    )
}

Здесь вы можете увидеть в панели «Навигация по ответам», как контрастно используются вторичные и третичные цвета контейнера для создания акцента и акцента.

Комбинация третичного контейнера и третичного контейнера для кнопки плавающего действия.
Рисунок 6 . Комбинация третичного контейнера и третичного контейнера для кнопки плавающего действия.

Типография

Material Design 3 определяет масштаб шрифта , включая стили текста, адаптированные из Material Design 2. Именование и группировка были упрощены: отображение, заголовок, заголовок, тело и метка, с большими, средними и маленькими размерами для каждого. .

Масштаб типографики по умолчанию для Material design 3
Рисунок 7 . Масштаб типографики по умолчанию для Material Design 3
М3 Размер шрифта по умолчанию/высота строки
displayLarge Roboto 57/64
displayMedium Roboto 45/52
displaySmall Roboto 36/44
headlineLarge Roboto 32/40
headlineMedium Roboto 28/36
headlineSmall Roboto 24/32
titleLarge New- Roboto Medium 22/28
titleMedium Roboto Medium 16/24
titleSmall Roboto Medium 14/20
bodyLarge Roboto 16/24
bodyMedium Roboto 14/20
bodySmall Roboto 12/16
labelLarge Roboto Medium 14/20
labelMedium Roboto Medium 12/16
labelSmall New Roboto Medium, 11/16

Определение типографики

Compose предоставляет класс M3 Typography — наряду с существующими классами TextStyle и шрифтами — для моделирования масштаба шрифта Material 3. Конструктор Typography предлагает значения по умолчанию для каждого стиля, поэтому вы можете опустить любые параметры, которые не хотите настраивать:

val replyTypography = Typography(
    titleLarge = TextStyle(
        fontWeight = FontWeight.SemiBold,
        fontSize = 22.sp,
        lineHeight = 28.sp,
        letterSpacing = 0.sp
    ),
    titleMedium = TextStyle(
        fontWeight = FontWeight.SemiBold,
        fontSize = 16.sp,
        lineHeight = 24.sp,
        letterSpacing = 0.15.sp
    ),
    // ..
)
// ..

Тело большое, тело среднего размера и этикетка среднего размера для различных типографских вариантов использования.
Рисунок 8 . Тело большое, тело среднего размера и этикетка среднего размера для различных типографских вариантов использования.

Вашему продукту, скорее всего, не понадобятся все 15 стилей по умолчанию из шкалы типов Material Design. В этом примере для сокращенного набора выбраны пять размеров, а остальные опущены.

Вы можете настроить свою типографику, изменив значения по умолчанию TextStyle и свойства , связанные со шрифтом, такие как fontFamily и letterSpacing .

bodyLarge = TextStyle(
    fontWeight = FontWeight.Normal,
    fontFamily = FontFamily.SansSerif,
    fontStyle = FontStyle.Italic,
    fontSize = 16.sp,
    lineHeight = 24.sp,
    letterSpacing = 0.15.sp,
    baselineShift = BaselineShift.Subscript
),

После того, как вы определили свою Typography , передайте ее в MaterialTheme M3:

MaterialTheme(
    typography = replyTypography,
) {
    // M3 app Content
}

Используйте стили текста

Вы можете получить типографику, предоставленную для компоновки M3 MaterialTheme , с помощью MaterialTheme.typography :

Text(
    text = "Hello M3 theming",
    style = MaterialTheme.typography.titleLarge
)
Text(
    text = "you are learning typography",
    style = MaterialTheme.typography.bodyMedium
)

Вы можете прочитать больше о рекомендациях по применению типографики .

Формы

Поверхности материала могут отображаться в различных формах. Формы направляют внимание, определяют компоненты, сообщают о состоянии и выражают бренд.

Масштаб формы определяет стиль углов контейнера, предлагая диапазон закруглений от квадратного до полностью круглого.

Определение фигур

Compose предоставляет классу M3 Shapes расширенные параметры для поддержки новых фигур M3. Масштаб фигур M3 больше похож на масштаб текста , обеспечивая выразительный диапазон фигур в пользовательском интерфейсе.

Есть разные размеры фигур:

  • Очень маленький
  • Маленький
  • Середина
  • Большой
  • Очень большой

По умолчанию каждая фигура имеет значение по умолчанию, но вы можете переопределить его:

val replyShapes = Shapes(
    extraSmall = RoundedCornerShape(4.dp),
    small = RoundedCornerShape(8.dp),
    medium = RoundedCornerShape(12.dp),
    large = RoundedCornerShape(16.dp),
    extraLarge = RoundedCornerShape(24.dp)
)

После того, как вы определили свои Shapes , вы можете передать их в M3 MaterialTheme :

MaterialTheme(
    shapes = replyShapes,
) {
    // M3 app Content
}

Используйте фигуры

Вы можете настроить масштаб формы для всех компонентов в MaterialTheme или сделать это для каждого компонента отдельно.

Примените среднюю и большую фигуру со значениями по умолчанию:

Card(shape = MaterialTheme.shapes.medium) { /* card content */ }
FloatingActionButton(
    shape = MaterialTheme.shapes.large,
    onClick = {
    }
) {
    /* fab content */
}

Средняя форма для карточки и большая форма для плавающей кнопки действия в примере приложения «Ответить».
Рисунок 9 . Средняя форма для карточки и большая форма для плавающей кнопки действия в примере приложения «Ответить»

Есть еще две фигуры — RectangleShape и CircleShape , которые являются частью Compose. Прямоугольная форма не имеет радиуса границы, а форма круга показывает полностью закругленные края:

Card(shape = RectangleShape) { /* card content */ }
Card(shape = CircleShape) { /* card content */ }

В примерах ниже показаны некоторые компоненты, к которым применены значения формы по умолчанию:

Значения форм по умолчанию для всех компонентов Материала 3.
Рисунок 10 . Значения форм по умолчанию для всех компонентов Материала 3.

Вы можете прочитать больше о рекомендациях Material по применению формы .

Акцент

Акцент в М3 делается с помощью вариаций цвета и его цветовых сочетаний. В M3 есть два способа сделать акцент на вашем пользовательском интерфейсе:

  • Использование поверхности, варианта поверхности и фона наряду с цветами поверхности и вариантов поверхности из расширенной цветовой системы M3. Например, поверхность можно использовать с вариантом на поверхности, а вариант поверхности можно использовать с вариантом на поверхности, чтобы обеспечить разные уровни акцента.
Использование нейтральных цветовых сочетаний для акцента.
Рисунок 11 . Использование нейтральных цветовых сочетаний для акцента.
  • Использование разной толщины шрифта для текста. Выше вы видели, что вы можете задать собственный вес для нашей шкалы шрифтов, чтобы придать различный акцент.

bodyLarge = TextStyle(
    fontWeight = FontWeight.Bold
),
bodyMedium = TextStyle(
    fontWeight = FontWeight.Normal
)

Высота

Материал 3 представляет возвышение, в основном, с использованием наложений тонального цвета. Это новый способ отличить контейнеры и поверхности друг от друга — при увеличении высоты тона в дополнение к теням используется более заметный тон.

Тональное возвышение с возвышением тени
Рисунок 12 . Тональное возвышение с возвышением тениE

Наложения возвышений в темных темах также изменились на наложения тональных цветов в Материале 3. Цвет наложения берется из слота основного цвета.

Высота тени и высота тона в Material Design 3
Рисунок 13 . Высота тени и высота тона в Material Design 3

Поверхность M3 — составная основа большинства компонентов M3 — включает поддержку как тонального, так и теневого возвышения:

Surface(
    modifier = Modifier,
    tonalElevation = /*...
    shadowElevation = /*...
) {
    Column(content = content)
}

Компоненты материала

Material Design поставляется с богатым набором компонентов Material (таких как кнопки, чипы, карточки, панель навигации), которые уже поддерживают Material Theming и помогают создавать красивые приложения Material Design. Вы можете начать использовать компоненты со свойствами по умолчанию прямо из коробки.

Button(onClick = { /*..*/ }) {
    Text(text = "My Button")
}

M3 предоставляет множество версий одних и тех же компонентов, которые можно использовать в разных ролях в зависимости от акцента и внимания.

Выделение кнопки от FAB, основной до кнопки «Текст»
Рисунок 14 . Выделение кнопок от FAB, Primary до кнопки Text
  • Расширенная плавающая кнопка действия для действия с наибольшим акцентом:

ExtendedFloatingActionButton(
    onClick = { /*..*/ },
    modifier = Modifier
) {
    Icon(
        imageVector = Icons.Default.Edit,
        contentDescription = stringResource(id = R.string.edit),
    )
    Text(
        text = stringResource(id = R.string.add_entry),
    )
}

  • Заполненная кнопка для действия с сильным акцентом:

Button(onClick = { /*..*/ }) {
    Text(text = stringResource(id = R.string.view_entry))
}

  • Текстовая кнопка для действия с низким выделением:

TextButton(onClick = { /*..*/ }) {
    Text(text = stringResource(id = R.string.replated_articles))
}

Подробнее о кнопках материалов и других компонентах можно прочитать здесь. Material 3 предоставляет широкий выбор наборов компонентов, таких как кнопки, панели приложений, компоненты навигации, которые специально разработаны для различных вариантов использования и размеров экрана.

Material также предоставляет несколько навигационных компонентов, которые помогут вам реализовать навигацию в зависимости от различных размеров и состояний экрана.

NavigationBar используется для компактных устройств, когда вы хотите настроить таргетинг на 5 или менее пунктов назначения:

NavigationBar(modifier = Modifier.fillMaxWidth()) {
    Destinations.entries.forEach { replyDestination ->
        NavigationBarItem(
            selected = selectedDestination == replyDestination,
            onClick = { },
            icon = { }
        )
    }
}

NavigationRail используется для планшетов или телефонов малого и среднего размера в ландшафтном режиме. Он обеспечивает эргономику пользователей и улучшает взаимодействие с этими устройствами.

NavigationRail(
    modifier = Modifier.fillMaxHeight(),
) {
    Destinations.entries.forEach { replyDestination ->
        NavigationRailItem(
            selected = selectedDestination == replyDestination,
            onClick = { },
            icon = { }
        )
    }
}

Демонстрация ответов BottomNavigationBar (слева) и NavigationRail (справа)
Рисунок 15 . Демонстрация ответов BottomNavigationBar (слева) и NavigationRail (справа)

Ответьте, используя обе темы по умолчанию, чтобы обеспечить захватывающий пользовательский интерфейс для устройств всех размеров.

NavigationDrawer используется для планшетов среднего и большого размера, где достаточно места для отображения деталей. Вы можете использовать как PermanentNavigationDrawer , так и ModalNavigationDrawer вместе с NavigationRail .

PermanentNavigationDrawer(modifier = Modifier.fillMaxHeight(), drawerContent = {
    Destinations.entries.forEach { replyDestination ->
        NavigationRailItem(
            selected = selectedDestination == replyDestination,
            onClick = { },
            icon = { },
            label = { }
        )
    }
}) {
}

Ответить Демонстрация постоянного навигационного ящика
Рисунок 16 . Ответная витрина постоянного ящика навигации

Возможности навигации повышают удобство использования, эргономику и доступность. Подробнее о компонентах навигации по материалам можно узнать в лаборатории адаптивного кода Compose .

Настройка темы компонента

M3 поощряет персонализацию и гибкость. Ко всем компонентам применены цвета по умолчанию, но при необходимости предоставляются гибкие API-интерфейсы для настройки их цветов.

Большинство компонентов, таких как карточки и кнопки, предоставляют объект по умолчанию, предоставляющий интерфейсы цвета и высоты, которые можно изменить для настройки вашего компонента:

val customCardColors = CardDefaults.cardColors(
    contentColor = MaterialTheme.colorScheme.primary,
    containerColor = MaterialTheme.colorScheme.primaryContainer,
    disabledContentColor = MaterialTheme.colorScheme.surface,
    disabledContainerColor = MaterialTheme.colorScheme.onSurface,
)
val customCardElevation = CardDefaults.cardElevation(
    defaultElevation = 8.dp,
    pressedElevation = 2.dp,
    focusedElevation = 4.dp
)
Card(
    colors = customCardColors,
    elevation = customCardElevation
) {
    // m3 card content
}

Подробнее о настройке Материала 3 можно прочитать.

Системный интерфейс

Некоторые аспекты Material You взяты из нового визуального стиля и системного пользовательского интерфейса на Android 12 и более поздних версиях. Двумя ключевыми областями, где происходят изменения, являются пульсация и чрезмерная прокрутка. Для реализации этих изменений не требуется никаких дополнительных действий.

Пульсация

Ripple теперь использует легкие блестки для освещения поверхностей при нажатии. Compose Material Ripple использует платформу RippleDrawable на Android, поэтому sparkle Ripple доступен на Android 12 и более поздних версиях для всех компонентов Material.

Пульсация в M2 против M3
Рисунок 17 . Пульсация на M2 и M3

Прокрутка

Overscroll теперь использует эффект растяжения по краям прокручиваемых контейнеров. Чрезмерная прокрутка растяжения включена по умолчанию в составных элементах контейнера с прокруткой — например, LazyColumn , LazyRow и LazyVerticalGrid — в Compose Foundation 1.1.0 и выше, независимо от уровня API.

Прокрутка с использованием эффекта растяжения на краю контейнера
Рисунок 18 . Прокрутка с использованием эффекта растяжения на краю контейнера

Доступность

Стандарты доступности, встроенные в компоненты Material, призваны обеспечить основу для инклюзивного дизайна продукта. Понимание доступности вашего продукта может повысить удобство использования для всех пользователей, включая людей с плохим зрением, слепотой, нарушениями слуха, когнитивными нарушениями, двигательными нарушениями или ситуативными нарушениями (например, сломанной рукой).

Доступность цвета

Динамический цвет разработан в соответствии со стандартами доступности для цветового контраста. Система тональных палитр имеет решающее значение для обеспечения доступности любой цветовой схемы по умолчанию.

Цветовая система материала обеспечивает стандартные значения тонов и измерения, которые можно использовать для достижения доступных коэффициентов контрастности.

Пример приложения для ответа: Первичные, вторичные и третичные тональные палитры (сверху вниз)
Рисунок 19 . Пример приложения-ответа: первичные, вторичные и третичные тональные палитры (сверху вниз)

Все компоненты Material и динамическое оформление уже используют указанные выше цветовые роли из набора тоновых палитр , выбранных с учетом требований доступности. Однако если вы настраиваете компоненты, обязательно используйте соответствующие цветовые роли и избегайте несоответствий.

Используйте on-primary поверх основного и on-primary-container поверх основного-контейнера, а также то же самое для других акцентных и нейтральных цветов, чтобы обеспечить доступный пользователю контраст.

Использование третичного контейнера поверх первичного дает пользователю кнопку с плохим контрастом:

// ✅ Button with sufficient contrast ratio
Button(
    onClick = { },
    colors = ButtonDefaults.buttonColors(
        containerColor = MaterialTheme.colorScheme.primary,
        contentColor = MaterialTheme.colorScheme.onPrimary
    )
) {
}

// ❌ Button with poor contrast ratio
Button(
    onClick = { },
    colors = ButtonDefaults.buttonColors(
        containerColor = MaterialTheme.colorScheme.tertiaryContainer,
        contentColor = MaterialTheme.colorScheme.primaryContainer
    )
) {
}

Достаточный контраст (слева) и плохой контраст (справа)
Рисунок 20 . Достаточный контраст (слева) и плохой контраст (справа)

Доступность типографики

Шкала типов M3 обновляет шкалу статического типа и значения, предлагая упрощенную, но динамичную структуру категорий размеров, которые масштабируются на разных устройствах.

Например, в M3 Display Small можно присваивать разные значения в зависимости от контекста устройства, например телефона или планшета.

Большие экраны

Материал содержит рекомендации по адаптивным макетам и складным устройствам, которые сделают ваши приложения доступными и улучшат эргономику пользователей, владеющих большими устройствами.

Material предоставляет различные виды навигации , которые помогут вам улучшить взаимодействие с пользователем на больших устройствах.

Вы можете узнать больше о рекомендациях по обеспечению качества приложений для больших экранов Android и просмотреть наш образец ответа на тему адаптивного и доступного дизайна.

Узнать больше

Чтобы узнать больше о темировании материалов в Compose, посетите следующие ресурсы:

Примеры приложений

Документы

Ссылка на API и исходный код

Видео

{% дословно %} {% дословно %} {% дословно %} {% endverbatim %} ,

Jetpack Compose предлагает реализацию Material Design 3 , следующую эволюцию Material Design. Material 3 включает обновленные темы, компоненты и функции персонализации Material You, такие как динамический цвет, и разработан с учетом нового визуального стиля и системного пользовательского интерфейса на Android 12 и более поздних версиях.

Ниже мы демонстрируем реализацию Material Design 3 на примере приложения «Ответ» . Пример ответа полностью основан на Material Design 3.

Пример приложения «Ответ» с использованием Material Design 3
Рисунок 1 . Пример приложения «Ответ» с использованием Material Design 3

Зависимость

Чтобы начать использовать Material 3 в своем приложении Compose, добавьте зависимость Compose Material 3 в файлы build.gradle :

implementation "androidx.compose.material3:material3:$material3_version"

После добавления зависимости вы можете начать добавлять в свои приложения системы Material Design, включая цвет, типографику и форму.

Экспериментальные API

Некоторые API M3 считаются экспериментальными. В таких случаях вам необходимо согласиться на уровне функции или файла, используя аннотацию ExperimentalMaterial3Api :

// import androidx.compose.material3.ExperimentalMaterial3Api
@Composable
fun AppComposable() {
    // M3 composables
}

Тематика материалов

Тема M3 содержит следующие подсистемы: цветовая схема , типографика и фигуры . Когда вы настраиваете эти значения, ваши изменения автоматически отражаются в компонентах M3, которые вы используете для создания своего приложения.

Подсистемы материального дизайна: цвет, типографика и формы
Рисунок 2 . Подсистемы материального дизайна: цвет, типографика и формы

Jetpack Compose реализует эти концепции с помощью компонуемого M3 MaterialTheme :

MaterialTheme(
    colorScheme = /* ...
    typography = /* ...
    shapes = /* ...
) {
    // M3 app content
}

Чтобы оформить контент вашего приложения, определите цветовую схему, типографику и формы, специфичные для вашего приложения.

Цветовая гамма

Основой цветовой схемы является набор из пяти ключевых цветов. Каждый из этих цветов относится к тоновой палитре из 13 тонов, которые используются компонентами Материала 3. Например, это цветовая схема светлой темы для ответа :

Пример цветовой схемы подсветки приложения для ответа
Рисунок 3 . Пример цветовой схемы подсветки приложения для ответа

Подробнее о Цветовой схеме и цветовых ролях читайте здесь.

Создание цветовых схем

Хотя вы можете создать собственную ColorScheme вручную, зачастую проще создать ее, используя исходные цвета вашего бренда. Инструмент Material Theme Builder позволяет вам сделать это и при необходимости экспортировать код темы Compose. Создаются следующие файлы:

  • Color.kt содержит цвета вашей темы со всеми ролями, определенными как для светлых, так и для темных цветов темы.

val md_theme_light_primary = Color(0xFF476810)
val md_theme_light_onPrimary = Color(0xFFFFFFFF)
val md_theme_light_primaryContainer = Color(0xFFC7F089)
// ..
// ..

val md_theme_dark_primary = Color(0xFFACD370)
val md_theme_dark_onPrimary = Color(0xFF213600)
val md_theme_dark_primaryContainer = Color(0xFF324F00)
// ..
// ..

  • Theme.kt содержит настройки светлых и темных цветовых схем, а также тему приложения.

private val LightColorScheme = lightColorScheme(
    primary = md_theme_light_primary,
    onPrimary = md_theme_light_onPrimary,
    primaryContainer = md_theme_light_primaryContainer,
    // ..
)
private val DarkColorScheme = darkColorScheme(
    primary = md_theme_dark_primary,
    onPrimary = md_theme_dark_onPrimary,
    primaryContainer = md_theme_dark_primaryContainer,
    // ..
)

@Composable
fun ReplyTheme(
    darkTheme: Boolean = isSystemInDarkTheme(),
    content: @Composable () -> Unit
) {
    val colorScheme =
        if (!darkTheme) {
            LightColorScheme
        } else {
            DarkColorScheme
        }
    MaterialTheme(
        colorScheme = colorScheme,
        content = content
    )
}

Для поддержки светлых и темных тем используйте isSystemInDarkTheme() . В зависимости от настроек системы определите, какую цветовую схему использовать: светлую или темную.

Динамические цветовые схемы

Динамический цвет — ключевая часть Material You, в которой алгоритм извлекает пользовательские цвета из обоев пользователя для применения к их приложениям и системному пользовательскому интерфейсу. Эта цветовая палитра используется в качестве отправной точки для создания светлых и темных цветовых схем.

Пример динамической темы приложения для ответа из обоев (слева) и темы приложения по умолчанию (справа)
Рисунок 4 . Пример динамической темы приложения для ответа из обоев (слева) и темы приложения по умолчанию (справа)

Динамический цвет доступен на Android 12 и более поздних версиях. Если доступен динамический цвет, вы можете настроить динамическую ColorScheme . Если нет, вам следует вернуться к использованию пользовательской светлой или темной ColorScheme .

ColorScheme предоставляет функции компоновщика для создания динамической светлой или темной цветовой схемы:

// Dynamic color is available on Android 12+
val dynamicColor = Build.VERSION.SDK_INT >= Build.VERSION_CODES.S
val colors = when {
    dynamicColor && darkTheme -> dynamicDarkColorScheme(LocalContext.current)
    dynamicColor && !darkTheme -> dynamicLightColorScheme(LocalContext.current)
    darkTheme -> DarkColorScheme
    else -> LightColorScheme
}

Использование цвета

Вы можете получить доступ к цветам темы Material в своем приложении через MaterialTheme.colorScheme :

Text(
    text = "Hello theming",
    color = MaterialTheme.colorScheme.primary
)

Каждую цветовую роль можно использовать в различных местах в зависимости от состояния, значимости и акцента компонента.

  • Первичный — это базовый цвет, используемый для основных компонентов, таких как заметные кнопки, активные состояния и оттенок приподнятых поверхностей.
  • Цвет вторичного ключа используется для менее заметных компонентов пользовательского интерфейса, таких как фильтрующие элементы, и расширяет возможности цветового выражения.
  • Третичный ключевой цвет используется для определения роли контрастных акцентов, которые можно использовать для балансировки основных и второстепенных цветов или для привлечения повышенного внимания к элементу.

В примере дизайна приложения «Ответ» используется цвет основного контейнера поверх основного контейнера, чтобы подчеркнуть выбранный элемент.

Основной контейнер и текстовые поля с цветом основного контейнера.
Рисунок 5 . Основной контейнер и текстовые поля с цветом основного контейнера.

Card(
    colors = CardDefaults.cardColors(
        containerColor =
        if (isSelected) MaterialTheme.colorScheme.primaryContainer
        else
            MaterialTheme.colorScheme.surfaceVariant
    )
) {
    Text(
        text = "Dinner club",
        style = MaterialTheme.typography.bodyLarge,
        color =
        if (isSelected) MaterialTheme.colorScheme.onPrimaryContainer
        else MaterialTheme.colorScheme.onSurface,
    )
}

Здесь вы можете увидеть в панели «Навигация по ответам», как контрастно используются вторичные и третичные цвета контейнера для создания акцента и акцента.

Комбинация третичного контейнера и третичного контейнера для кнопки плавающего действия.
Рисунок 6 . Комбинация третичного контейнера и третичного контейнера для кнопки плавающего действия.

Типография

Material Design 3 определяет масштаб шрифта , включая стили текста, адаптированные из Material Design 2. Именование и группировка были упрощены: отображение, заголовок, заголовок, тело и метка, с большими, средними и маленькими размерами для каждого. .

Масштаб типографики по умолчанию для Material design 3
Рисунок 7 . Масштаб типографики по умолчанию для Material Design 3
М3 Размер шрифта по умолчанию/высота строки
displayLarge Roboto 57/64
displayMedium Roboto 45/52
displaySmall Roboto 36/44
headlineLarge Roboto 32/40
headlineMedium Roboto 28/36
headlineSmall Roboto 24/32
titleLarge New- Roboto Medium 22/28
titleMedium Roboto Medium 16/24
titleSmall Roboto Medium 14/20
bodyLarge Roboto 16/24
bodyMedium Roboto 14/20
bodySmall Roboto 12/16
labelLarge Roboto Medium 14/20
labelMedium Roboto Medium 12/16
labelSmall New Roboto Medium, 11/16

Определение типографики

Compose предоставляет класс M3 Typography , а также существующие классы TextStyle и классы , связанные со шрифтами , для моделирования масштаба шрифта Material 3. Конструктор Typography предлагает значения по умолчанию для каждого стиля, поэтому вы можете опустить любые параметры, которые не хотите настраивать:

val replyTypography = Typography(
    titleLarge = TextStyle(
        fontWeight = FontWeight.SemiBold,
        fontSize = 22.sp,
        lineHeight = 28.sp,
        letterSpacing = 0.sp
    ),
    titleMedium = TextStyle(
        fontWeight = FontWeight.SemiBold,
        fontSize = 16.sp,
        lineHeight = 24.sp,
        letterSpacing = 0.15.sp
    ),
    // ..
)
// ..

Тело большое, тело среднего размера и этикетка среднего размера для различных типографских вариантов использования.
Рисунок 8 . Тело большое, тело среднего размера и этикетка среднего размера для использования в различной типографике.

Вашему продукту, скорее всего, не понадобятся все 15 стилей по умолчанию из шкалы типов Material Design. В этом примере для сокращенного набора выбраны пять размеров, а остальные опущены.

Вы можете настроить свою типографику, изменив значения по умолчанию TextStyle и свойства , связанные со шрифтом, такие как fontFamily и letterSpacing .

bodyLarge = TextStyle(
    fontWeight = FontWeight.Normal,
    fontFamily = FontFamily.SansSerif,
    fontStyle = FontStyle.Italic,
    fontSize = 16.sp,
    lineHeight = 24.sp,
    letterSpacing = 0.15.sp,
    baselineShift = BaselineShift.Subscript
),

После того, как вы определили свою Typography , передайте ее в MaterialTheme M3:

MaterialTheme(
    typography = replyTypography,
) {
    // M3 app Content
}

Используйте стили текста

Вы можете получить типографику, предоставленную для компоновки M3 MaterialTheme , с помощью MaterialTheme.typography :

Text(
    text = "Hello M3 theming",
    style = MaterialTheme.typography.titleLarge
)
Text(
    text = "you are learning typography",
    style = MaterialTheme.typography.bodyMedium
)

Вы можете прочитать больше о рекомендациях по применению типографики .

Формы

Поверхности материала могут отображаться в различных формах. Формы направляют внимание, определяют компоненты, сообщают о состоянии и выражают бренд.

Масштаб формы определяет стиль углов контейнера, предлагая диапазон закруглений от квадратного до полностью круглого.

Определение фигур

Compose предоставляет классу M3 Shapes расширенные параметры для поддержки новых фигур M3. Масштаб фигур M3 больше похож на масштаб текста , обеспечивая выразительный диапазон фигур в пользовательском интерфейсе.

Есть разные размеры фигур:

  • Очень маленький
  • Маленький
  • Середина
  • Большой
  • Очень большой

По умолчанию каждая фигура имеет значение по умолчанию, но вы можете переопределить его:

val replyShapes = Shapes(
    extraSmall = RoundedCornerShape(4.dp),
    small = RoundedCornerShape(8.dp),
    medium = RoundedCornerShape(12.dp),
    large = RoundedCornerShape(16.dp),
    extraLarge = RoundedCornerShape(24.dp)
)

После того, как вы определили свои Shapes , вы можете передать их в M3 MaterialTheme :

MaterialTheme(
    shapes = replyShapes,
) {
    // M3 app Content
}

Используйте фигуры

Вы можете настроить масштаб формы для всех компонентов в MaterialTheme или сделать это для каждого компонента отдельно.

Примените среднюю и большую фигуру со значениями по умолчанию:

Card(shape = MaterialTheme.shapes.medium) { /* card content */ }
FloatingActionButton(
    shape = MaterialTheme.shapes.large,
    onClick = {
    }
) {
    /* fab content */
}

Средняя форма для карточки и большая форма для плавающей кнопки действия в примере приложения «Ответить».
Рисунок 9 . Средняя форма для карточки и большая форма для плавающей кнопки действия в примере приложения «Ответить»

Есть еще две фигуры — RectangleShape и CircleShape , которые являются частью Compose. Прямоугольная форма не имеет радиуса границы, а форма круга показывает полностью закругленные края:

Card(shape = RectangleShape) { /* card content */ }
Card(shape = CircleShape) { /* card content */ }

В примерах ниже показаны некоторые компоненты, к которым применены значения формы по умолчанию:

Значения форм по умолчанию для всех компонентов Материала 3.
Рисунок 10 . Значения форм по умолчанию для всех компонентов Материала 3.

Вы можете прочитать больше о рекомендациях Material по применению формы .

Акцент

Акцент в М3 делается с помощью вариаций цвета и его цветовых сочетаний. В M3 есть два способа сделать акцент на вашем пользовательском интерфейсе:

  • Использование поверхности, варианта поверхности и фона наряду с цветами поверхности и вариантов поверхности из расширенной цветовой системы M3. Например, поверхность можно использовать с вариантом на поверхности, а вариант поверхности можно использовать с вариантом на поверхности, чтобы обеспечить разные уровни акцента.
Использование нейтральных цветовых сочетаний для акцента.
Рисунок 11 . Использование нейтральных цветовых сочетаний для акцента.
  • Использование разной толщины шрифта для текста. Выше вы видели, что вы можете задать собственный вес для нашей шкалы шрифтов, чтобы придать различный акцент.

bodyLarge = TextStyle(
    fontWeight = FontWeight.Bold
),
bodyMedium = TextStyle(
    fontWeight = FontWeight.Normal
)

Высота

Материал 3 представляет возвышение, в основном, с использованием наложений тонального цвета. Это новый способ отличить контейнеры и поверхности друг от друга — при увеличении высоты тона в дополнение к теням используется более заметный тон.

Тональное возвышение с возвышением тени
Рисунок 12 . Тональное возвышение с возвышением тениE

Наложения возвышений в темных темах также изменились на наложения тональных цветов в Материале 3. Цвет наложения берется из слота основного цвета.

Высота тени против высоты тона в Material Design 3
Рисунок 13 . Высота тени и высота тона в Material Design 3

Поверхность M3 — составная основа большинства компонентов M3 — включает поддержку как тонального, так и теневого возвышения:

Surface(
    modifier = Modifier,
    tonalElevation = /*...
    shadowElevation = /*...
) {
    Column(content = content)
}

Компоненты материала

Material Design поставляется с богатым набором компонентов Material (таких как кнопки, чипы, карточки, панель навигации), которые уже соответствуют Material Theming и помогают создавать красивые приложения Material Design. Вы можете начать использовать компоненты со свойствами по умолчанию прямо из коробки.

Button(onClick = { /*..*/ }) {
    Text(text = "My Button")
}

M3 предоставляет множество версий одних и тех же компонентов, которые можно использовать в разных ролях в зависимости от акцента и внимания.

Выделение кнопок от FAB, Primary до кнопки Text
Рисунок 14 . Выделение кнопки от FAB, основной до кнопки «Текст»
  • Расширенная плавающая кнопка действия для действия с наибольшим акцентом:

ExtendedFloatingActionButton(
    onClick = { /*..*/ },
    modifier = Modifier
) {
    Icon(
        imageVector = Icons.Default.Edit,
        contentDescription = stringResource(id = R.string.edit),
    )
    Text(
        text = stringResource(id = R.string.add_entry),
    )
}

  • Заполненная кнопка для действия с сильным акцентом:

Button(onClick = { /*..*/ }) {
    Text(text = stringResource(id = R.string.view_entry))
}

  • Текстовая кнопка для действия с низким выделением:

TextButton(onClick = { /*..*/ }) {
    Text(text = stringResource(id = R.string.replated_articles))
}

Подробнее о кнопках материалов и других компонентах можно прочитать здесь. Material 3 предоставляет широкий выбор наборов компонентов, таких как кнопки, панели приложений, компоненты навигации, которые специально разработаны для различных вариантов использования и размеров экрана.

Material также предоставляет несколько навигационных компонентов, которые помогут вам реализовать навигацию в зависимости от различных размеров и состояний экрана.

NavigationBar используется для компактных устройств, когда вы хотите настроить таргетинг на 5 или менее пунктов назначения:

NavigationBar(modifier = Modifier.fillMaxWidth()) {
    Destinations.entries.forEach { replyDestination ->
        NavigationBarItem(
            selected = selectedDestination == replyDestination,
            onClick = { },
            icon = { }
        )
    }
}

NavigationRail используется для планшетов или телефонов малого и среднего размера в ландшафтном режиме. Он обеспечивает эргономику пользователей и улучшает взаимодействие с этими устройствами.

NavigationRail(
    modifier = Modifier.fillMaxHeight(),
) {
    Destinations.entries.forEach { replyDestination ->
        NavigationRailItem(
            selected = selectedDestination == replyDestination,
            onClick = { },
            icon = { }
        )
    }
}

Демонстрация ответов BottomNavigationBar (слева) и NavigationRail (справа)
Рисунок 15 . Демонстрация ответов BottomNavigationBar (слева) и NavigationRail (справа)

Ответьте, используя обе темы по умолчанию, чтобы обеспечить захватывающий пользовательский интерфейс для устройств всех размеров.

NavigationDrawer используется для планшетов среднего и большого размера, где достаточно места для отображения деталей. Вы можете использовать как PermanentNavigationDrawer , так и ModalNavigationDrawer вместе с NavigationRail .

PermanentNavigationDrawer(modifier = Modifier.fillMaxHeight(), drawerContent = {
    Destinations.entries.forEach { replyDestination ->
        NavigationRailItem(
            selected = selectedDestination == replyDestination,
            onClick = { },
            icon = { },
            label = { }
        )
    }
}) {
}

Ответить Демонстрация постоянного навигационного ящика
Рисунок 16 . Ответная витрина постоянного ящика навигации

Возможности навигации повышают удобство использования, эргономику и доступность. Подробнее о компонентах навигации по материалам можно узнать в лаборатории адаптивного кода Compose .

Настройка темы компонента

M3 поощряет персонализацию и гибкость. Ко всем компонентам применены цвета по умолчанию, но при необходимости предоставляются гибкие API-интерфейсы для настройки их цветов.

Большинство компонентов, таких как карточки и кнопки, предоставляют объект по умолчанию, предоставляющий интерфейсы цвета и высоты, которые можно изменить для настройки вашего компонента:

val customCardColors = CardDefaults.cardColors(
    contentColor = MaterialTheme.colorScheme.primary,
    containerColor = MaterialTheme.colorScheme.primaryContainer,
    disabledContentColor = MaterialTheme.colorScheme.surface,
    disabledContainerColor = MaterialTheme.colorScheme.onSurface,
)
val customCardElevation = CardDefaults.cardElevation(
    defaultElevation = 8.dp,
    pressedElevation = 2.dp,
    focusedElevation = 4.dp
)
Card(
    colors = customCardColors,
    elevation = customCardElevation
) {
    // m3 card content
}

Подробнее о настройке Материала 3 можно прочитать.

Системный интерфейс

Некоторые аспекты Material You взяты из нового визуального стиля и системного пользовательского интерфейса на Android 12 и более поздних версиях. Двумя ключевыми областями, где происходят изменения, являются пульсация и чрезмерная прокрутка. Для реализации этих изменений не требуется никаких дополнительных действий.

Пульсация

Ripple теперь использует легкие блестки для освещения поверхностей при нажатии. Compose Material Ripple использует платформу RippleDrawable на Android, поэтому sparkle Ripple доступен на Android 12 и более поздних версиях для всех компонентов Material.

Пульсация в M2 против M3
Рисунок 17 . Пульсация на M2 и M3

Прокрутка

Overscroll теперь использует эффект растяжения по краям прокручиваемых контейнеров. Чрезмерная прокрутка растяжения включена по умолчанию в составных элементах контейнера с прокруткой — например, LazyColumn , LazyRow и LazyVerticalGrid — в Compose Foundation 1.1.0 и выше, независимо от уровня API.

Прокрутка с использованием эффекта растяжения на краю контейнера
Рисунок 18 . Прокрутка с использованием эффекта растяжения на краю контейнера

Доступность

Стандарты доступности, встроенные в компоненты Material, призваны обеспечить основу для инклюзивного дизайна продукта. Понимание доступности вашего продукта может повысить удобство использования для всех пользователей, включая людей с плохим зрением, слепотой, нарушениями слуха, когнитивными нарушениями, двигательными нарушениями или ситуативными нарушениями (например, сломанной рукой).

Доступность цвета

Динамический цвет разработан в соответствии со стандартами доступности для цветового контраста. Система тональных палитр имеет решающее значение для обеспечения доступности любой цветовой схемы по умолчанию.

Цветовая система материала обеспечивает стандартные значения тонов и измерения, которые можно использовать для достижения доступных коэффициентов контрастности.

Пример приложения для ответа: Первичные, вторичные и третичные тональные палитры (сверху вниз)
Рисунок 19 . Пример приложения-ответа: первичные, вторичные и третичные тональные палитры (сверху вниз)

Все компоненты Material и динамическая тематика уже используют указанные выше цветовые роли из набора тоновых палитр , выбранных с учетом требований доступности. Однако если вы настраиваете компоненты, обязательно используйте соответствующие цветовые роли и избегайте несоответствий.

Используйте on-primary поверх основного и on-primary-container поверх основного-контейнера, а также то же самое для других акцентных и нейтральных цветов, чтобы обеспечить пользователю доступный контраст.

Использование третичного контейнера поверх первичного дает пользователю кнопку с плохим контрастом:

// ✅ Button with sufficient contrast ratio
Button(
    onClick = { },
    colors = ButtonDefaults.buttonColors(
        containerColor = MaterialTheme.colorScheme.primary,
        contentColor = MaterialTheme.colorScheme.onPrimary
    )
) {
}

// ❌ Button with poor contrast ratio
Button(
    onClick = { },
    colors = ButtonDefaults.buttonColors(
        containerColor = MaterialTheme.colorScheme.tertiaryContainer,
        contentColor = MaterialTheme.colorScheme.primaryContainer
    )
) {
}

Достаточный контраст (слева) и плохой контраст (справа)
Рисунок 20 . Достаточный контраст (слева) и плохой контраст (справа)

Доступность типографики

Шкала типов M3 обновляет шкалу статических типов и значения, предлагая упрощенную, но динамичную структуру категорий размеров, которые масштабируются на разных устройствах.

Например, в M3 Display Small можно присваивать разные значения в зависимости от контекста устройства, например телефона или планшета.

Большие экраны

Материал содержит рекомендации по адаптивным макетам и складным устройствам, которые сделают ваши приложения доступными и улучшат эргономику пользователей, владеющих большими устройствами.

Material предоставляет различные виды навигации , которые помогут вам улучшить взаимодействие с пользователем на больших устройствах.

Вы можете узнать больше о рекомендациях по обеспечению качества приложений для больших экранов Android и просмотреть наш образец ответа на тему адаптивного и доступного дизайна.

Узнать больше

Чтобы узнать больше о темировании материалов в Compose, посетите следующие ресурсы:

Примеры приложений

Документы

Ссылка на API и исходный код

Видео

{% дословно %} {% дословно %} {% дословно %} {% endverbatim %} ,

Jetpack Compose предлагает реализацию Material Design 3 , следующую эволюцию Material Design. Material 3 включает обновленные темы, компоненты и функции персонализации Material You, такие как динамический цвет, и разработан с учетом нового визуального стиля и системного пользовательского интерфейса на Android 12 и более поздних версиях.

Ниже мы демонстрируем реализацию Material Design 3 на примере приложения «Ответ» . Образец ответа полностью основан на дизайне материала 3.

Образец ответа приложения с использованием дизайна материала 3
Рисунок 1 . Образец ответа приложения с использованием дизайна материала 3

Зависимость

Чтобы начать использование материала 3 в вашем приложении Compose, добавьте зависимость Compose 3 в файлы build.gradle :

implementation "androidx.compose.material3:material3:$material3_version"

После добавления зависимости вы можете начать добавлять системы проектирования материала, включая цвет, типографику и форму, в ваши приложения.

Экспериментальные API

Некоторые API M3 считаются экспериментальными. В таких случаях вам необходимо выбрать на уровне функции или файла, используя аннотацию ExperimentalMaterial3Api :

// import androidx.compose.material3.ExperimentalMaterial3Api
@Composable
fun AppComposable() {
    // M3 composables
}

Материальная тематическая тематическая

Тема M3 содержит следующие подсистемы: цветовая схема , типография и формы . Когда вы настраиваете эти значения, ваши изменения автоматически отражаются в компонентах M3, которые вы используете для создания вашего приложения.

Подсистемы дизайна материала: цвет, типография и формы
Рисунок 2 . Подсистемы дизайна материала: цвет, типография и формы

JetPack Compose реализует эти концепции с помощью MaterialTheme Composable:

MaterialTheme(
    colorScheme = /* ...
    typography = /* ...
    shapes = /* ...
) {
    // M3 app content
}

Чтобы предложить содержание вашего приложения, определите цветовую схему, типографику и формы, специфичные для вашего приложения.

Цветовая схема

Основой цветовой схемы является набор из пяти ключевых цветов. Каждый из этих цветов связан с тональной палитрой из 13 тонов, которые используются материалом 3 компонентов. Например, это цветовая схема для легкой темы для ответа :

Образец примера приложения светлая цветовая схема
Рисунок 3 . Образец примера приложения светлая цветовая схема

Узнайте больше о цветовой схеме и цветовых ролях .

Генерировать цветовые схемы

В то время как вы можете создать пользовательский ColorScheme вручную, часто бывает легче генерировать его, используя исходные цвета из вашего бренда. Инструмент «Строитель темы» позволяет вам сделать это, а также, опционально сочинять тематическое код. Создаются следующие файлы:

  • Color.kt содержит цвета вашей темы со всеми ролями, определенными как для светлых, так и для темных цветов темы.

val md_theme_light_primary = Color(0xFF476810)
val md_theme_light_onPrimary = Color(0xFFFFFFFF)
val md_theme_light_primaryContainer = Color(0xFFC7F089)
// ..
// ..

val md_theme_dark_primary = Color(0xFFACD370)
val md_theme_dark_onPrimary = Color(0xFF213600)
val md_theme_dark_primaryContainer = Color(0xFF324F00)
// ..
// ..

  • Theme.kt содержит настройку для схем света и темного цвета и тему приложения.

private val LightColorScheme = lightColorScheme(
    primary = md_theme_light_primary,
    onPrimary = md_theme_light_onPrimary,
    primaryContainer = md_theme_light_primaryContainer,
    // ..
)
private val DarkColorScheme = darkColorScheme(
    primary = md_theme_dark_primary,
    onPrimary = md_theme_dark_onPrimary,
    primaryContainer = md_theme_dark_primaryContainer,
    // ..
)

@Composable
fun ReplyTheme(
    darkTheme: Boolean = isSystemInDarkTheme(),
    content: @Composable () -> Unit
) {
    val colorScheme =
        if (!darkTheme) {
            LightColorScheme
        } else {
            DarkColorScheme
        }
    MaterialTheme(
        colorScheme = colorScheme,
        content = content
    )
}

Чтобы поддержать светлые и темные темы, используйте isSystemInDarkTheme() . На основе настройки системы определите, какую цветовую схему использовать: свет или темный.

Динамические цветовые схемы

Динамический цвет является ключевой частью материала, в котором алгоритм получает пользовательские цвета из обоев пользователя, которые будут применены к их приложениям и систему пользовательского интерфейса. Эта цветовая палитра используется в качестве отправной точки для генерации светлых и темных цветовых схем.

Ответ пример приложения Динамическая темация из обоев (слева) и тематического приложения по умолчанию (справа)
Рисунок 4 . Ответ пример приложения Динамическая темация из обоев (слева) и тематического приложения по умолчанию (справа)

Динамический цвет доступен на Android 12 и выше. Если динамический цвет доступен, вы можете настроить динамическую ColorScheme . Если нет, вы должны вернуться к использованию индивидуального света или темного ColorScheme .

ColorScheme обеспечивает функции строителя для создания динамического света или темной цветовой схемы:

// Dynamic color is available on Android 12+
val dynamicColor = Build.VERSION.SDK_INT >= Build.VERSION_CODES.S
val colors = when {
    dynamicColor && darkTheme -> dynamicDarkColorScheme(LocalContext.current)
    dynamicColor && !darkTheme -> dynamicLightColorScheme(LocalContext.current)
    darkTheme -> DarkColorScheme
    else -> LightColorScheme
}

Использование цвета

Вы можете получить доступ к цветам темы материала в вашем приложении через MaterialTheme.colorScheme :

Text(
    text = "Hello theming",
    color = MaterialTheme.colorScheme.primary
)

Каждая цветная роль может быть использована в различных местах в зависимости от состояния компонента, известности и акцента.

  • Первичным является основной цвет, используемый для основных компонентов, таких как выдающиеся кнопки, активные состояния и оттенок повышенных поверхностей.
  • Вторичный цвет ключа используется для менее заметных компонентов в пользовательском интерфейсе, таких как чипы фильтров, и расширяет возможность для выражения цвета.
  • Цвет третичного ключа используется для получения ролей контрастных акцентов, которые можно использовать для баланса первичных и вторичных цветов или привлечь внимание к элементу.

Образец приложения для ответа использует цвет на прайм-контентере в верхней части первичного контейнера, чтобы сделать акцент на выбранном элементе.

Основные контейнерные и текстовые поля с примирным цветом.
Рисунок 5 . Основные контейнерные и текстовые поля с примирным цветом.

Card(
    colors = CardDefaults.cardColors(
        containerColor =
        if (isSelected) MaterialTheme.colorScheme.primaryContainer
        else
            MaterialTheme.colorScheme.surfaceVariant
    )
) {
    Text(
        text = "Dinner club",
        style = MaterialTheme.typography.bodyLarge,
        color =
        if (isSelected) MaterialTheme.colorScheme.onPrimaryContainer
        else MaterialTheme.colorScheme.onSurface,
    )
}

Здесь вы можете увидеть в ящике для навигации ответа, как вторичные и третичные цвета контейнера используются в отличие от создания акцента и акцента.

Третичный контентер и комбинация в третичном контейнере для кнопки плавающего действия.
Рисунок 6 . Третичный контентер и комбинация в третичном контейнере для кнопки плавающего действия.

Типография

Дизайн материала 3 определяет шкалу типов , в том числе стили текста, которые были адаптированы из дизайна материала 2. Наименование и группировка были упрощены на: дисплей, заголовок, заголовок, кузов и метка, с большими, средними и небольшими размерами для каждого .

Шкала типографии по умолчанию для дизайна материала 3
Рисунок 7 . Шкала типографии по умолчанию для дизайна материала 3
М3 Размер шрифта по умолчанию/высота линии
displayLarge Roboto 57/64
displayMedium Roboto 45/52
displaySmall Roboto 36/44
headlineLarge Roboto 32/40
headlineMedium Roboto 28/36
headlineSmall Roboto 24/32
titleLarge New- Roboto Medium 22/28
titleMedium Roboto Medium 16/24
titleSmall Roboto Medium 14/20
bodyLarge Roboto 16/24
bodyMedium Roboto 14/20
bodySmall Roboto 12/16
labelLarge Roboto Medium 14/20
labelMedium Roboto Medium 12/16
labelSmall New Roboto Medium, 11/16

Определите типографику

Compose предоставляет класс Typography M3-наряду с существующими классами TextStyle и Font, связанным с моделированием шкалы типа Material 3. Конструктор Typography предлагает значения по умолчанию для каждого стиля, чтобы вы могли опустить любые параметры, которые вы не хотите настроить:

val replyTypography = Typography(
    titleLarge = TextStyle(
        fontWeight = FontWeight.SemiBold,
        fontSize = 22.sp,
        lineHeight = 28.sp,
        letterSpacing = 0.sp
    ),
    titleMedium = TextStyle(
        fontWeight = FontWeight.SemiBold,
        fontSize = 16.sp,
        lineHeight = 24.sp,
        letterSpacing = 0.15.sp
    ),
    // ..
)
// ..

Корпус большой, среду тела и маркировка среды для различного использования типографии.
Рисунок 8 . Тело большое, среду тела и маркировка среды для различного использования типографии.

Ваш продукт, скорее всего, не понадобится все 15 стилей по умолчанию из шкалы типа дизайна материала. В этом примере пять размеров выбираются для уменьшенного набора, в то время как остальные опущены.

Вы можете настроить свою типографику путем изменения значений по умолчанию в TextStyle и свойств , связанных с шрифтом, таких как fontFamily и letterSpacing .

bodyLarge = TextStyle(
    fontWeight = FontWeight.Normal,
    fontFamily = FontFamily.SansSerif,
    fontStyle = FontStyle.Italic,
    fontSize = 16.sp,
    lineHeight = 24.sp,
    letterSpacing = 0.15.sp,
    baselineShift = BaselineShift.Subscript
),

Как только вы определили свою Typography , передайте ее MaterialTheme M3:

MaterialTheme(
    typography = replyTypography,
) {
    // M3 app Content
}

Используйте текстовые стили

Вы можете получить типографику, предоставленную для композиции MaterialTheme M3 с использованием MaterialTheme.typography :

Text(
    text = "Hello M3 theming",
    style = MaterialTheme.typography.titleLarge
)
Text(
    text = "you are learning typography",
    style = MaterialTheme.typography.bodyMedium
)

Вы можете прочитать больше о материальных рекомендациях по применению типографии .

Формы

Поверхности материала могут отображаться в разных формах. Формы прямое внимание, выявлять компоненты, общаться с состоянием и выразить бренд.

Шкала формы определяет стиль углов контейнеров, предлагая диапазон округленности от квадрата до полностью круговой.

Определите формы

Compose предоставляет класс Shapes M3 с расширенными параметрами для поддержки новых форм M3. Шкала формы M3 больше похожа на шкалу типов , что позволяет выразить диапазон форм по всему пользовательскому интерфейсу.

Есть разные размеры форм:

  • Очень маленький
  • Маленький
  • Середина
  • Большой
  • Очень большой

По умолчанию каждая форма имеет значение по умолчанию, но вы можете переопределить их:

val replyShapes = Shapes(
    extraSmall = RoundedCornerShape(4.dp),
    small = RoundedCornerShape(8.dp),
    medium = RoundedCornerShape(12.dp),
    large = RoundedCornerShape(16.dp),
    extraLarge = RoundedCornerShape(24.dp)
)

После того, как вы определили свои Shapes , вы можете передать их MaterialTheme M3:

MaterialTheme(
    shapes = replyShapes,
) {
    // M3 app Content
}

Используйте формы

Вы можете настроить шкалу формы для всех компонентов в MaterialTheme , или вы можете сделать это на основе компонента.

Примените среднюю и большую форму со значениями по умолчанию:

Card(shape = MaterialTheme.shapes.medium) { /* card content */ }
FloatingActionButton(
    shape = MaterialTheme.shapes.large,
    onClick = {
    }
) {
    /* fab content */
}

Средняя форма для карты и большая форма для кнопки плавающего действия в приложении ответа.
Рисунок 9 . Средняя форма для карты и большой формы для кнопки плавающего действия в приложении ответа

Есть две другие формы - RectangleShape и CircleShape - которые являются частью Compose. Форма прямоугольника без радиуса границы, а форма круга показывает полную обводимую края:

Card(shape = RectangleShape) { /* card content */ }
Card(shape = CircleShape) { /* card content */ }

Примеры ниже демонстрируют некоторые компоненты со значениями формы по умолчанию, применяемыми к ним:

Значения форм по умолчанию для всех материалов 3 компонентов.
Рисунок 10 . Значения форм по умолчанию для всех материалов 3 компонентов.

Вы можете прочитать больше о материальных рекомендациях по применению формы .

Акцент

Акцент в M3 предоставляется с использованием вариаций цвета и его комбинаций на цвете. В M3 есть два способа добавить акцент на ваш пользовательский интерфейс:

  • Используя поверхностную, поверхностную вариант и фон вдоль поверхности, на поверхности, вариантские цвета из расширенной цветовой системы M3. Например, поверхность может использоваться с помощью на поверхности, и поверхностно-вариант может использоваться с на поверхности, чтобы обеспечить различные уровни акцента.
Использование нейтральных цветовых комбинаций для акцента.
Рисунок 11 . Использование нейтральных цветовых комбинаций для акцента.
  • Использование разных весов шрифта для текста. Выше вы видели, что вы можете предоставить пользовательские веса для нашего типа для обеспечения различного акцента.

bodyLarge = TextStyle(
    fontWeight = FontWeight.Bold
),
bodyMedium = TextStyle(
    fontWeight = FontWeight.Normal
)

Высота

Материал 3 представляет высоту в основном с использованием тональных цветовых наложений. Это новый способ дифференцировать контейнеры и поверхности друг от друга - увеличение тональной высоты использует более заметный тон - в дополнение к тени.

Тональная высота с высотой тенью
Рисунок 12 . Тональная высота с теневой эпохи

Высокие наложения в темные темы также изменились на тональные цвета в материале 3. Цвет наложения исходит из основного цветового слота.

Высота теневой высоты против тональной высоты в дизайне материала 3
Рисунок 13 . Высота теневой высоты в зависимости от тональной высоты в дизайне материала 3

Поверхность M3 - поддержанная композиция для большинства компонентов M3 - включает в себя поддержку как тональной, так и теневой высоты:

Surface(
    modifier = Modifier,
    tonalElevation = /*...
    shadowElevation = /*...
) {
    Column(content = content)
}

Материальные компоненты

Дизайн материала поставляется с богатым набором материала компонентов (таких как кнопки, чипсы, карты, навигационная панель), которые уже следуют тематике материала и помогают вам сделать красивые приложения для дизайна материала. Вы можете начать использовать компоненты со свойствами по умолчанию прямо из коробки.

Button(onClick = { /*..*/ }) {
    Text(text = "My Button")
}

M3 предоставляет много версий тех же компонентов, которые будут использоваться в разных ролях в соответствии с акцентом и вниманием.

Кнопка акцента от Fab, первичной к текстовой кнопке
Рисунок 14 . Кнопка акцента от Fab, первичной к текстовой кнопке
  • Расширенная кнопка с плавающим действием для самого высокого акцента:

ExtendedFloatingActionButton(
    onClick = { /*..*/ },
    modifier = Modifier
) {
    Icon(
        imageVector = Icons.Default.Edit,
        contentDescription = stringResource(id = R.string.edit),
    )
    Text(
        text = stringResource(id = R.string.add_entry),
    )
}

  • Заполненная кнопка для высокого акцента:

Button(onClick = { /*..*/ }) {
    Text(text = stringResource(id = R.string.view_entry))
}

  • Текстовая кнопка для низкого акцента:

TextButton(onClick = { /*..*/ }) {
    Text(text = stringResource(id = R.string.replated_articles))
}

Вы можете прочитать больше о кнопках материалов и других компонентах . Материал 3 предоставляет широкий спектр компонентов, таких как кнопки, панели приложений, навигационные компоненты, которые специально разработаны для различных вариантов использования и размеров экрана.

Материал также предоставляет несколько навигационных компонентов, которые помогают вам внедрить навигацию, в зависимости от различных размеров и состояний экрана.

NavigationBar используется для компактных устройств, когда вы хотите нацелиться на 5 или менее направления:

NavigationBar(modifier = Modifier.fillMaxWidth()) {
    Destinations.entries.forEach { replyDestination ->
        NavigationBarItem(
            selected = selectedDestination == replyDestination,
            onClick = { },
            icon = { }
        )
    }
}

NavigationRail используется для таблеток или телефонов размером с малого и среднего в режиме ландшафта. Он предоставляет эргономику пользователям и улучшает пользовательский опыт для этих устройств.

NavigationRail(
    modifier = Modifier.fillMaxHeight(),
) {
    Destinations.entries.forEach { replyDestination ->
        NavigationRailItem(
            selected = selectedDestination == replyDestination,
            onClick = { },
            icon = { }
        )
    }
}

Ответ демонстрация BottomNavigationBar (слева) и NavigationRail (справа)
Рисунок 15 . Ответ демонстрация BottomNavigationBar (слева) и NavigationRail (справа)

Ответьте, используя оба в тематике по умолчанию, чтобы обеспечить захватывающий пользовательский опыт для всех размеров устройства.

NavigationDrawer используется для планшетов среднего-большого размера, где у вас достаточно места, чтобы показать детали. Вы можете использовать как PermanentNavigationDrawer , так и ModalNavigationDrawer вместе с NavigationRail .

PermanentNavigationDrawer(modifier = Modifier.fillMaxHeight(), drawerContent = {
    Destinations.entries.forEach { replyDestination ->
        NavigationRailItem(
            selected = selectedDestination == replyDestination,
            onClick = { },
            icon = { },
            label = { }
        )
    }
}) {
}

Ответ демонстрация ящика для постоянной навигации
Рисунок 16 . Ответ демонстрация ящика для постоянной навигации

Параметры навигации улучшают пользовательский опыт, эргономику и достижимость. Вы можете узнать больше о компонентах навигации материала в Compose Adaptive CodeLab .

Настройте тематическую тематику компонента

M3 поощряет персонализацию и гибкость. Все компоненты имеют цвета по умолчанию, применяемые к ним, но обнажают гибкие API для настройки своих цветов, если это необходимо.

Большинство компонентов, такие как карты и кнопки, предоставляют объект по умолчанию, разоблачающий цвет и интерфейсы, которые можно изменить для настройки вашего компонента:

val customCardColors = CardDefaults.cardColors(
    contentColor = MaterialTheme.colorScheme.primary,
    containerColor = MaterialTheme.colorScheme.primaryContainer,
    disabledContentColor = MaterialTheme.colorScheme.surface,
    disabledContainerColor = MaterialTheme.colorScheme.onSurface,
)
val customCardElevation = CardDefaults.cardElevation(
    defaultElevation = 8.dp,
    pressedElevation = 2.dp,
    focusedElevation = 4.dp
)
Card(
    colors = customCardColors,
    elevation = customCardElevation
) {
    // m3 card content
}

Вы можете прочитать больше об настройке материала 3 .

Системный интерфейс

Некоторые аспекты материала вы поступаете из нового визуального стиля и системного пользовательского интерфейса на Android 12 и выше. Две ключевые области, где есть изменения, являются пульсированными и перегорочными. Для реализации этих изменений не требуется дополнительная работа.

Пульсация

Ripple теперь использует тонкую блеск для освещения поверхностей при нажатии. Compose Material Ripple использует платформу RippledRawable под капюшоном на Android, поэтому Sparkle Ripple доступна на Android 12 и выше для всех компонентов материала.

Ripple in M2 против M3
Рисунок 17 . Ripple in M2 против M3

Перевернуть

Overscroll теперь использует растяжку на краю контейнеров прокрутки. Stretch Ouppercroll по умолчанию в композитных контейнерах прокрутки - например, LazyColumn , LazyRow и LazyVerticalGrid - в Compose Foundation 1.1.0 и выше, независимо от уровня API.

Перепроверка с использованием эффекта растяжения на краю контейнера
Рисунок 18 . Перепроверка с использованием эффекта растяжения на краю контейнера

Доступность

Стандарты доступности, встроенные в материальные компоненты, предназначены для обеспечения основы для инклюзивного дизайна продукта. Понимание доступности вашего продукта может повысить удобство использования для всех пользователей, в том числе с низким зрением, слепотой, нарушениями слуха, когнитивными нарушениями, двигательными нарушениями или ситуационными нарушениями (например, сломанной рукой).

Доступность цвета

Динамический цвет предназначен для соответствия стандартам доступности для цветового контраста. Система тональных палитр имеет решающее значение для того, чтобы сделать любую цветовую схему доступной по умолчанию.

Цветовая система материала обеспечивает стандартные значения тона и измерения, которые можно использовать для удовлетворения доступных контрастных соотношений.

Приложение ответа: первичный, вторичный и третичный тональные поддоны (сверху вниз)
Рисунок 19 . Приложение ответа: первичная, вторичная и третичная тональные палитры (сверху вниз)

Все компоненты материала и динамические тематические темы уже используют вышеуказанные цветные роли из набора тональных палитров , выбранных для удовлетворения требований доступности. Однако, если вы настраиваете компоненты, обязательно используйте соответствующие цветовые роли и избегайте несоответствия.

Используйте на праймнее в верхней части первичного и начального контейнера в верхней части первичного контентара, и то же самое для других акцентов и нейтральных цветов, чтобы обеспечить доступный контраст с пользователем.

Использование третичного контейнера в верхней части первичного дает пользователю плохую контрастную кнопку:

// ✅ Button with sufficient contrast ratio
Button(
    onClick = { },
    colors = ButtonDefaults.buttonColors(
        containerColor = MaterialTheme.colorScheme.primary,
        contentColor = MaterialTheme.colorScheme.onPrimary
    )
) {
}

// ❌ Button with poor contrast ratio
Button(
    onClick = { },
    colors = ButtonDefaults.buttonColors(
        containerColor = MaterialTheme.colorScheme.tertiaryContainer,
        contentColor = MaterialTheme.colorScheme.primaryContainer
    )
) {
}

Достаточный контраст (слева) против плохого контраста (справа)
Рисунок 20 . Достаточный контраст (слева) по сравнению с плохим контрастом (справа)

Типография доступность

Шкала типа M3 обновляет рампу и значения статического типа, чтобы предложить упрощенную, но динамическую структуру категорий размеров, которые масштабируются по устройствам.

Например, в M3 отображение Small может быть назначено различными значениями в зависимости от контекста устройства, таких как телефон или планшет.

Большие экраны

Материал предоставляет рекомендации по адаптивным макетам и складным устройствам, чтобы сделать ваши приложения доступными и улучшить эргономику пользователей, держащих большие устройства.

Материал предоставляет различные виды навигации , чтобы помочь вам обеспечить лучшие пользовательские работы для больших устройств.

Вы можете узнать больше о рекомендациях Android с качеством приложений Android и посмотреть на наш образец ответа для адаптивного и доступного дизайна.

Узнать больше

Чтобы узнать больше о материальной темации в Compose, ознакомьтесь с следующими ресурсами:

Примеры приложений

Документы

Ссылка на API и исходный код

Видео

{% дословно %} {% дословно %} {% дословно %} {% endverbatim %} ,

JetPack Compose предлагает реализацию Material Design 3 , следующую эволюцию дизайна материала. Материал 3 включает в себя обновленную темацию, компоненты и материалы, которые вы персонализация, такие как динамический цвет, и предназначены для сплоченного с новым визуальным стилем и системным пользовательским интерфейсом на Android 12 и выше.

Ниже мы демонстрируем реализацию Material Design 3, используя приложение для ответов в качестве примера. Образец ответа полностью основан на дизайне материала 3.

Образец ответа приложения с использованием дизайна материала 3
Рисунок 1 . Образец ответа приложения с использованием дизайна материала 3

Зависимость

Чтобы начать использование материала 3 в вашем приложении Compose, добавьте зависимость Compose 3 в файлы build.gradle :

implementation "androidx.compose.material3:material3:$material3_version"

После добавления зависимости вы можете начать добавлять системы проектирования материала, включая цвет, типографику и форму, в ваши приложения.

Экспериментальные API

Некоторые API M3 считаются экспериментальными. В таких случаях вам необходимо выбрать на уровне функции или файла, используя аннотацию ExperimentalMaterial3Api :

// import androidx.compose.material3.ExperimentalMaterial3Api
@Composable
fun AppComposable() {
    // M3 composables
}

Материальная тематическая тематическая

Тема M3 содержит следующие подсистемы: цветовая схема , типография и формы . Когда вы настраиваете эти значения, ваши изменения автоматически отражаются в компонентах M3, которые вы используете для создания вашего приложения.

Подсистемы дизайна материала: цвет, типография и формы
Рисунок 2 . Подсистемы дизайна материала: цвет, типография и формы

JetPack Compose реализует эти концепции с помощью MaterialTheme Composable:

MaterialTheme(
    colorScheme = /* ...
    typography = /* ...
    shapes = /* ...
) {
    // M3 app content
}

Чтобы предложить содержание вашего приложения, определите цветовую схему, типографику и формы, специфичные для вашего приложения.

Цветовая схема

Основой цветовой схемы является набор из пяти ключевых цветов. Каждый из этих цветов связан с тональной палитрой из 13 тонов, которые используются материалом 3 компонентов. Например, это цветовая схема для легкой темы для ответа :

Образец примера приложения светлая цветовая схема
Рисунок 3 . Образец примера приложения светлая цветовая схема

Узнайте больше о цветовой схеме и цветовых ролях .

Генерировать цветовые схемы

В то время как вы можете создать пользовательский ColorScheme вручную, часто бывает легче генерировать его, используя исходные цвета из вашего бренда. Инструмент «Строитель темы» позволяет вам сделать это, а также, опционально сочинять тематическое код. Создаются следующие файлы:

  • Color.kt содержит цвета вашей темы со всеми ролями, определенными как для светлых, так и для темных цветов темы.

val md_theme_light_primary = Color(0xFF476810)
val md_theme_light_onPrimary = Color(0xFFFFFFFF)
val md_theme_light_primaryContainer = Color(0xFFC7F089)
// ..
// ..

val md_theme_dark_primary = Color(0xFFACD370)
val md_theme_dark_onPrimary = Color(0xFF213600)
val md_theme_dark_primaryContainer = Color(0xFF324F00)
// ..
// ..

  • Theme.kt содержит настройку для схем света и темного цвета и тему приложения.

private val LightColorScheme = lightColorScheme(
    primary = md_theme_light_primary,
    onPrimary = md_theme_light_onPrimary,
    primaryContainer = md_theme_light_primaryContainer,
    // ..
)
private val DarkColorScheme = darkColorScheme(
    primary = md_theme_dark_primary,
    onPrimary = md_theme_dark_onPrimary,
    primaryContainer = md_theme_dark_primaryContainer,
    // ..
)

@Composable
fun ReplyTheme(
    darkTheme: Boolean = isSystemInDarkTheme(),
    content: @Composable () -> Unit
) {
    val colorScheme =
        if (!darkTheme) {
            LightColorScheme
        } else {
            DarkColorScheme
        }
    MaterialTheme(
        colorScheme = colorScheme,
        content = content
    )
}

Чтобы поддержать светлые и темные темы, используйте isSystemInDarkTheme() . На основе настройки системы определите, какую цветовую схему использовать: свет или темный.

Динамические цветовые схемы

Динамический цвет является ключевой частью материала, в котором алгоритм получает пользовательские цвета из обоев пользователя, которые будут применены к их приложениям и систему пользовательского интерфейса. Эта цветовая палитра используется в качестве отправной точки для генерации светлых и темных цветовых схем.

Ответ пример приложения Динамическая темация из обоев (слева) и тематического приложения по умолчанию (справа)
Рисунок 4 . Ответ пример приложения Динамическая темация из обоев (слева) и тематического приложения по умолчанию (справа)

Динамический цвет доступен на Android 12 и выше. Если динамический цвет доступен, вы можете настроить динамическую ColorScheme . Если нет, вы должны вернуться к использованию индивидуального света или темного ColorScheme .

ColorScheme обеспечивает функции строителя для создания динамического света или темной цветовой схемы:

// Dynamic color is available on Android 12+
val dynamicColor = Build.VERSION.SDK_INT >= Build.VERSION_CODES.S
val colors = when {
    dynamicColor && darkTheme -> dynamicDarkColorScheme(LocalContext.current)
    dynamicColor && !darkTheme -> dynamicLightColorScheme(LocalContext.current)
    darkTheme -> DarkColorScheme
    else -> LightColorScheme
}

Использование цвета

Вы можете получить доступ к цветам темы материала в вашем приложении через MaterialTheme.colorScheme :

Text(
    text = "Hello theming",
    color = MaterialTheme.colorScheme.primary
)

Каждая цветная роль может быть использована в различных местах в зависимости от состояния компонента, известности и акцента.

  • Первичным является основной цвет, используемый для основных компонентов, таких как выдающиеся кнопки, активные состояния и оттенок повышенных поверхностей.
  • Вторичный цвет ключа используется для менее заметных компонентов в пользовательском интерфейсе, таких как чипы фильтров, и расширяет возможность для выражения цвета.
  • Цвет третичного ключа используется для получения ролей контрастных акцентов, которые можно использовать для баланса первичных и вторичных цветов или привлечь внимание к элементу.

Образец приложения для ответа использует цвет на прайм-контентере в верхней части первичного контейнера, чтобы сделать акцент на выбранном элементе.

Основные контейнерные и текстовые поля с примирным цветом.
Рисунок 5 . Основные контейнерные и текстовые поля с примирным цветом.

Card(
    colors = CardDefaults.cardColors(
        containerColor =
        if (isSelected) MaterialTheme.colorScheme.primaryContainer
        else
            MaterialTheme.colorScheme.surfaceVariant
    )
) {
    Text(
        text = "Dinner club",
        style = MaterialTheme.typography.bodyLarge,
        color =
        if (isSelected) MaterialTheme.colorScheme.onPrimaryContainer
        else MaterialTheme.colorScheme.onSurface,
    )
}

Здесь вы можете увидеть в ящике для навигации ответа, как вторичные и третичные цвета контейнера используются в отличие от создания акцента и акцента.

Третичный контентер и комбинация в третичном контейнере для кнопки плавающего действия.
Рисунок 6 . Третичный контентер и комбинация в третичном контейнере для кнопки плавающего действия.

Типография

Дизайн материала 3 определяет шкалу типов , в том числе стили текста, которые были адаптированы из дизайна материала 2. Наименование и группировка были упрощены на: дисплей, заголовок, заголовок, кузов и метка, с большими, средними и небольшими размерами для каждого .

Шкала типографии по умолчанию для дизайна материала 3
Рисунок 7 . Шкала типографии по умолчанию для дизайна материала 3
М3 Размер шрифта по умолчанию/высота линии
displayLarge Roboto 57/64
displayMedium Roboto 45/52
displaySmall Roboto 36/44
headlineLarge Roboto 32/40
headlineMedium Roboto 28/36
headlineSmall Roboto 24/32
titleLarge New- Roboto Medium 22/28
titleMedium Roboto Medium 16/24
titleSmall Roboto Medium 14/20
bodyLarge Roboto 16/24
bodyMedium Roboto 14/20
bodySmall Roboto 12/16
labelLarge Roboto Medium 14/20
labelMedium Roboto Medium 12/16
labelSmall New Roboto Medium, 11/16

Определите типографику

Compose предоставляет класс Typography M3-наряду с существующими классами TextStyle и Font, связанным с моделированием шкалы типа Material 3. Конструктор Typography предлагает значения по умолчанию для каждого стиля, чтобы вы могли опустить любые параметры, которые вы не хотите настроить:

val replyTypography = Typography(
    titleLarge = TextStyle(
        fontWeight = FontWeight.SemiBold,
        fontSize = 22.sp,
        lineHeight = 28.sp,
        letterSpacing = 0.sp
    ),
    titleMedium = TextStyle(
        fontWeight = FontWeight.SemiBold,
        fontSize = 16.sp,
        lineHeight = 24.sp,
        letterSpacing = 0.15.sp
    ),
    // ..
)
// ..

Корпус большой, среду тела и маркировка среды для различного использования типографии.
Рисунок 8 . Тело большое, среду тела и маркировка среды для различного использования типографии.

Ваш продукт, скорее всего, не понадобится все 15 стилей по умолчанию из шкалы типа дизайна материала. В этом примере пять размеров выбираются для уменьшенного набора, в то время как остальные опущены.

Вы можете настроить свою типографику путем изменения значений по умолчанию в TextStyle и свойств , связанных с шрифтом, таких как fontFamily и letterSpacing .

bodyLarge = TextStyle(
    fontWeight = FontWeight.Normal,
    fontFamily = FontFamily.SansSerif,
    fontStyle = FontStyle.Italic,
    fontSize = 16.sp,
    lineHeight = 24.sp,
    letterSpacing = 0.15.sp,
    baselineShift = BaselineShift.Subscript
),

Как только вы определили свою Typography , передайте ее MaterialTheme M3:

MaterialTheme(
    typography = replyTypography,
) {
    // M3 app Content
}

Используйте текстовые стили

Вы можете получить типографику, предоставленную для композиции MaterialTheme M3 с использованием MaterialTheme.typography :

Text(
    text = "Hello M3 theming",
    style = MaterialTheme.typography.titleLarge
)
Text(
    text = "you are learning typography",
    style = MaterialTheme.typography.bodyMedium
)

Вы можете прочитать больше о материальных рекомендациях по применению типографии .

Формы

Поверхности материала могут отображаться в разных формах. Формы прямое внимание, выявлять компоненты, общаться с состоянием и выразить бренд.

Шкала формы определяет стиль углов контейнеров, предлагая диапазон округленности от квадрата до полностью круговой.

Определите формы

Compose предоставляет класс Shapes M3 с расширенными параметрами для поддержки новых форм M3. Шкала формы M3 больше похожа на шкалу типов , что позволяет выразить диапазон форм по всему пользовательскому интерфейсу.

Есть разные размеры форм:

  • Очень маленький
  • Маленький
  • Середина
  • Большой
  • Очень большой

По умолчанию каждая форма имеет значение по умолчанию, но вы можете переопределить их:

val replyShapes = Shapes(
    extraSmall = RoundedCornerShape(4.dp),
    small = RoundedCornerShape(8.dp),
    medium = RoundedCornerShape(12.dp),
    large = RoundedCornerShape(16.dp),
    extraLarge = RoundedCornerShape(24.dp)
)

После того, как вы определили свои Shapes , вы можете передать их MaterialTheme M3:

MaterialTheme(
    shapes = replyShapes,
) {
    // M3 app Content
}

Используйте формы

Вы можете настроить шкалу формы для всех компонентов в MaterialTheme , или вы можете сделать это на основе компонента.

Примените среднюю и большую форму со значениями по умолчанию:

Card(shape = MaterialTheme.shapes.medium) { /* card content */ }
FloatingActionButton(
    shape = MaterialTheme.shapes.large,
    onClick = {
    }
) {
    /* fab content */
}

Средняя форма для карты и большая форма для кнопки плавающего действия в приложении ответа.
Рисунок 9 . Средняя форма для карты и большой формы для кнопки плавающего действия в приложении ответа

Есть две другие формы - RectangleShape и CircleShape - которые являются частью Compose. Форма прямоугольника без радиуса границы, а форма круга показывает полную обводимую края:

Card(shape = RectangleShape) { /* card content */ }
Card(shape = CircleShape) { /* card content */ }

Примеры ниже демонстрируют некоторые компоненты со значениями формы по умолчанию, применяемыми к ним:

Значения форм по умолчанию для всех материалов 3 компонентов.
Рисунок 10 . Значения форм по умолчанию для всех материалов 3 компонентов.

Вы можете прочитать больше о материальных рекомендациях по применению формы .

Акцент

Акцент в M3 предоставляется с использованием вариаций цвета и его комбинаций на цвете. В M3 есть два способа добавить акцент на ваш пользовательский интерфейс:

  • Используя поверхностную, поверхностную вариант и фон вдоль поверхности, на поверхности, вариантские цвета из расширенной цветовой системы M3. Например, поверхность может использоваться с помощью на поверхности, и поверхностно-вариант может использоваться с на поверхности, чтобы обеспечить различные уровни акцента.
Использование нейтральных цветовых комбинаций для акцента.
Рисунок 11 . Использование нейтральных цветовых комбинаций для акцента.
  • Использование разных весов шрифта для текста. Выше вы видели, что вы можете предоставить пользовательские веса для нашего типа для обеспечения различного акцента.

bodyLarge = TextStyle(
    fontWeight = FontWeight.Bold
),
bodyMedium = TextStyle(
    fontWeight = FontWeight.Normal
)

Высота

Материал 3 представляет высоту в основном с использованием тональных цветовых наложений. Это новый способ дифференцировать контейнеры и поверхности друг от друга - увеличение тональной высоты использует более заметный тон - в дополнение к тени.

Тональная высота с высотой тенью
Рисунок 12 . Тональная высота с теневой эпохи

Высокие наложения в темные темы также изменились на тональные цвета в материале 3. Цвет наложения исходит из основного цветового слота.

Высота теневой высоты против тональной высоты в дизайне материала 3
Рисунок 13 . Высота теневой высоты в зависимости от тональной высоты в дизайне материала 3

Поверхность M3 - поддержанная композиция для большинства компонентов M3 - включает в себя поддержку как тональной, так и теневой высоты:

Surface(
    modifier = Modifier,
    tonalElevation = /*...
    shadowElevation = /*...
) {
    Column(content = content)
}

Материальные компоненты

Дизайн материала поставляется с богатым набором материала компонентов (таких как кнопки, чипсы, карты, навигационная панель), которые уже следуют тематике материала и помогают вам сделать красивые приложения для дизайна материала. Вы можете начать использовать компоненты со свойствами по умолчанию прямо из коробки.

Button(onClick = { /*..*/ }) {
    Text(text = "My Button")
}

M3 предоставляет много версий тех же компонентов, которые будут использоваться в разных ролях в соответствии с акцентом и вниманием.

Кнопка акцента от Fab, первичной к текстовой кнопке
Рисунок 14 . Кнопка акцента от Fab, первичной к текстовой кнопке
  • Расширенная кнопка с плавающим действием для самого высокого акцента:

ExtendedFloatingActionButton(
    onClick = { /*..*/ },
    modifier = Modifier
) {
    Icon(
        imageVector = Icons.Default.Edit,
        contentDescription = stringResource(id = R.string.edit),
    )
    Text(
        text = stringResource(id = R.string.add_entry),
    )
}

  • Заполненная кнопка для высокого акцента:

Button(onClick = { /*..*/ }) {
    Text(text = stringResource(id = R.string.view_entry))
}

  • Текстовая кнопка для низкого акцента:

TextButton(onClick = { /*..*/ }) {
    Text(text = stringResource(id = R.string.replated_articles))
}

Вы можете прочитать больше о кнопках материалов и других компонентах . Материал 3 предоставляет широкий спектр компонентов, таких как кнопки, панели приложений, навигационные компоненты, которые специально разработаны для различных вариантов использования и размеров экрана.

Материал также предоставляет несколько навигационных компонентов, которые помогают вам внедрить навигацию, в зависимости от различных размеров и состояний экрана.

NavigationBar используется для компактных устройств, когда вы хотите нацелиться на 5 или менее направления:

NavigationBar(modifier = Modifier.fillMaxWidth()) {
    Destinations.entries.forEach { replyDestination ->
        NavigationBarItem(
            selected = selectedDestination == replyDestination,
            onClick = { },
            icon = { }
        )
    }
}

NavigationRail используется для таблеток или телефонов размером с малого и среднего в режиме ландшафта. Он предоставляет эргономику пользователям и улучшает пользовательский опыт для этих устройств.

NavigationRail(
    modifier = Modifier.fillMaxHeight(),
) {
    Destinations.entries.forEach { replyDestination ->
        NavigationRailItem(
            selected = selectedDestination == replyDestination,
            onClick = { },
            icon = { }
        )
    }
}

Ответ демонстрация BottomNavigationBar (слева) и NavigationRail (справа)
Рисунок 15 . Ответ демонстрация BottomNavigationBar (слева) и NavigationRail (справа)

Ответьте, используя оба в тематике по умолчанию, чтобы обеспечить захватывающий пользовательский опыт для всех размеров устройства.

NavigationDrawer используется для планшетов среднего-большого размера, где у вас достаточно места, чтобы показать детали. Вы можете использовать как PermanentNavigationDrawer , так и ModalNavigationDrawer вместе с NavigationRail .

PermanentNavigationDrawer(modifier = Modifier.fillMaxHeight(), drawerContent = {
    Destinations.entries.forEach { replyDestination ->
        NavigationRailItem(
            selected = selectedDestination == replyDestination,
            onClick = { },
            icon = { },
            label = { }
        )
    }
}) {
}

Ответ демонстрация ящика для постоянной навигации
Рисунок 16 . Ответ демонстрация ящика для постоянной навигации

Параметры навигации улучшают пользовательский опыт, эргономику и достижимость. Вы можете узнать больше о компонентах навигации материала в Compose Adaptive CodeLab .

Настройте тематическую тематику компонента

M3 поощряет персонализацию и гибкость. Все компоненты имеют цвета по умолчанию, применяемые к ним, но обнажают гибкие API для настройки своих цветов, если это необходимо.

Большинство компонентов, такие как карты и кнопки, предоставляют объект по умолчанию, разоблачающий цвет и интерфейсы, которые можно изменить для настройки вашего компонента:

val customCardColors = CardDefaults.cardColors(
    contentColor = MaterialTheme.colorScheme.primary,
    containerColor = MaterialTheme.colorScheme.primaryContainer,
    disabledContentColor = MaterialTheme.colorScheme.surface,
    disabledContainerColor = MaterialTheme.colorScheme.onSurface,
)
val customCardElevation = CardDefaults.cardElevation(
    defaultElevation = 8.dp,
    pressedElevation = 2.dp,
    focusedElevation = 4.dp
)
Card(
    colors = customCardColors,
    elevation = customCardElevation
) {
    // m3 card content
}

Вы можете прочитать больше об настройке материала 3 .

Системный интерфейс

Некоторые аспекты материала вы поступаете из нового визуального стиля и системного пользовательского интерфейса на Android 12 и выше. Две ключевые области, где есть изменения, являются пульсированными и перегорочными. Для реализации этих изменений не требуется дополнительная работа.

Пульсация

Ripple теперь использует тонкую блеск для освещения поверхностей при нажатии. Compose Material Ripple использует платформу RippledRawable под капюшоном на Android, поэтому Sparkle Ripple доступна на Android 12 и выше для всех компонентов материала.

Ripple in M2 против M3
Рисунок 17 . Ripple in M2 против M3

Перевернуть

Overscroll теперь использует растяжку на краю контейнеров прокрутки. Stretch Ouppercroll по умолчанию в композитных контейнерах прокрутки - например, LazyColumn , LazyRow и LazyVerticalGrid - в Compose Foundation 1.1.0 и выше, независимо от уровня API.

Перепроверка с использованием эффекта растяжения на краю контейнера
Рисунок 18 . Перепроверка с использованием эффекта растяжения на краю контейнера

Доступность

Стандарты доступности, встроенные в материальные компоненты, предназначены для обеспечения основы для инклюзивного дизайна продукта. Понимание доступности вашего продукта может повысить удобство использования для всех пользователей, в том числе с низким зрением, слепотой, нарушениями слуха, когнитивными нарушениями, двигательными нарушениями или ситуационными нарушениями (например, сломанной рукой).

Доступность цвета

Динамический цвет предназначен для соответствия стандартам доступности для цветового контраста. Система тональных палитр имеет решающее значение для того, чтобы сделать любую цветовую схему доступной по умолчанию.

Цветовая система материала обеспечивает стандартные значения тона и измерения, которые можно использовать для удовлетворения доступных контрастных соотношений.

Приложение ответа: первичный, вторичный и третичный тональные поддоны (сверху вниз)
Рисунок 19 . Приложение ответа: первичная, вторичная и третичная тональные палитры (сверху вниз)

Все компоненты материала и динамические тематические темы уже используют вышеуказанные цветные роли из набора тональных палитров , выбранных для удовлетворения требований доступности. Однако, если вы настраиваете компоненты, обязательно используйте соответствующие цветовые роли и избегайте несоответствия.

Используйте на праймнее в верхней части первичного и начального контейнера в верхней части первичного контентара, и то же самое для других акцентов и нейтральных цветов, чтобы обеспечить доступный контраст с пользователем.

Использование третичного контейнера в верхней части первичного дает пользователю плохую контрастную кнопку:

// ✅ Button with sufficient contrast ratio
Button(
    onClick = { },
    colors = ButtonDefaults.buttonColors(
        containerColor = MaterialTheme.colorScheme.primary,
        contentColor = MaterialTheme.colorScheme.onPrimary
    )
) {
}

// ❌ Button with poor contrast ratio
Button(
    onClick = { },
    colors = ButtonDefaults.buttonColors(
        containerColor = MaterialTheme.colorScheme.tertiaryContainer,
        contentColor = MaterialTheme.colorScheme.primaryContainer
    )
) {
}

Достаточный контраст (слева) против плохого контраста (справа)
Рисунок 20 . Достаточный контраст (слева) по сравнению с плохим контрастом (справа)

Типография доступность

Шкала типа M3 обновляет рампу и значения статического типа, чтобы предложить упрощенную, но динамическую структуру категорий размеров, которые масштабируются по устройствам.

Например, в M3 отображение Small может быть назначено различными значениями в зависимости от контекста устройства, таких как телефон или планшет.

Большие экраны

Материал предоставляет рекомендации по адаптивным макетам и складным устройствам, чтобы сделать ваши приложения доступными и улучшить эргономику пользователей, держащих большие устройства.

Материал предоставляет различные виды навигации , чтобы помочь вам обеспечить лучшие пользовательские работы для больших устройств.

Вы можете узнать больше о рекомендациях Android с качеством приложений Android и посмотреть на наш образец ответа для адаптивного и доступного дизайна.

Узнать больше

Чтобы узнать больше о материальной темации в Compose, ознакомьтесь с следующими ресурсами:

Примеры приложений

Документы

Ссылка на API и исходный код

Видео

{% дословно %} {% дословно %} {% дословно %} {% дословно %}