Системные панели Android

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

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

Рисунок 1. Изображения за системными панелями

Вынос

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

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

  • Избегайте добавления жестов касания и перетаскивания целей под вставками жестов; они конфликтуют с сквозной навигацией и навигацией с помощью жестов.

Рисунок 2. Вставки системных жестов. Не размещайте цели касания под этими областями.

Нарисуйте свой контент за системными панелями

Функция «от края до края» позволяет Android размещать пользовательский интерфейс под системными панелями для создания эффекта погружения, что является частым запросом пользователей.

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

При проектировании сценариев использования от края до края помните о следующих типах вставок:

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

Строка состояния

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

Рис. 3. Область строки состояния, выделенная в верхней части верхней панели приложения.

Значки в строке состояния

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

Рисунок 4. Значки строки состояния в светлой и темной теме.

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

Рисунок 5. Значок уведомления в строке состояния

Установите стиль строки состояния

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

В Android 15 реализована сквозная технология, поэтому строка состояния по умолчанию прозрачна. Вызовите enableEdgeToEdge() для обратной совместимости.

Рисунок 6. Используйте все возможности для улучшения контента. Не используйте непрозрачные системные панели.

Android позволяет пользователям управлять навигацией с помощью элементов управления «Назад», «Домой» и «Обзор»:

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

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

Навигация с помощью жестов

Навигация с помощью жестов, представленная в Android 10 (уровень API 29), является рекомендуемым типом навигации, хотя вы не можете переопределить предпочтения пользователя. В навигации с помощью жестов не используются кнопки «Назад», «Домой» и «Обзор», вместо этого для удобства отображается один дескриптор жеста. Пользователи взаимодействуют, проводя пальцем от левого или правого края экрана, чтобы вернуться назад, и вверх снизу, чтобы вернуться домой. Смахивание вверх и удержание открывает обзор.

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

  • Поддержка сквозного контента.
  • Избегайте добавления взаимодействий или сенсорных целей под вставками навигации с помощью жестов.

Прочтите о реализации навигации с помощью жестов .

Рис. 7. Панель навигации с помощью жестов.

Трехкнопочная навигация

Трехкнопочная навигация обеспечивает три кнопки: «Назад», «Домой» и «Обзор».

Рисунок 8. Трехкнопочная панель навигации

Другие варианты панели навигации

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

Рисунок 9. Двухкнопочная панель навигации.

Установить стиль навигации

Убедитесь, что панель навигации прозрачна или полупрозрачна во всех версиях, вызвав enableEdgeToEdge() .

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

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

Android обеспечивает визуальную защиту пользовательского интерфейса в режиме навигации жестами и в режимах кнопок.

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

Рисунок 10. Динамическая адаптация цвета.

Режимы кнопок : система применяет полупрозрачную сетку за панелями навигации по кнопкам, которую можно удалить, установив для Window.setNavigationBarContrastEnforced() значение false .

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

Клавиатура и навигация

Рисунок 12. Экранная клавиатура с панелями навигации.

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

Вырезы для дисплея

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

Рисунок 13. Примеры вырезов дисплея

Вырезы на дисплее могут повлиять на внешний вид вашего пользовательского интерфейса. При настройке Android 15 (уровень API 35) или более поздней версии приложения по умолчанию отображаются в области выреза дисплея. Приложения должны обрабатывать вставки вырезов дисплея, чтобы важный пользовательский интерфейс не отображался под вырезом дисплея. Узнайте, как поддерживать вырезы дисплея .

Режим погружения

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

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