оконный менеджер

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

Просмотрщик WindowManager Winscope отображает эту информацию как для трассировок, так и для дампов.

Дополнительную информацию о сборе трассировок см. в разделе WindowManager.

windowmanager

Рисунок 1. Анализ трассировки WindowManager.

В левой части экрана представлен 3D-вид окон. Прямоугольный вид учитывает границы окон, z-порядок и непрозрачность.

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

  • V: Определяет видимые окна.

В правой части экрана отображается proto dump всех доступных свойств. Для получения дополнительной информации о функциях раздела proto dump см. Properties .

@IntDef перевод

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

Ниже приведен пример использования @IntDef:

/**
  * The modes to control how root task is moved to the front when calling {@link Task#reparent}.
 */
@Retention(RetentionPolicy.SOURCE)
@IntDef({
  REPARENT_MOVE_ROOT_TASK_TO_FRONT,
  REPARENT_KEEP_ROOT_TASK_AT_FRONT,
  REPARENT_LEAVE_ROOT_TASK_IN_PLACE
})
@interface ReparentMoveRootTaskMode {}

// Moves the root task to the front if it was not at the front
static final int REPARENT_MOVE_ROOT_TASK_TO_FRONT = 0;
// Only moves the root task to the front if it was focused or frontmost already
static final int REPARENT_KEEP_ROOT_TASK_AT_FRONT = 1;
// Do not move the root task as a part of reparenting
static final int REPARENT_LEAVE_ROOT_TASK_IN_PLACE = 2;

Флаги хранятся как целые числа , а не как значения, понятные человеку, что может быть сложно интерпретировать. Winscope преобразует эти флаги в понятные человеку значения с помощью определений @IntDef . Во время компиляции Winscope собирает словарь значений @IntDef и использует этот список для декодирования экземпляров @IntDef в понятный человеку формат во время выполнения. Например, активность с activityType 2 преобразуется в activityType ACTIVITY_TYPE_HOME . Аналогично, окно с flags=2173763840 преобразуется в Winscope как:

flags=FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS | FLAG_HARDWARE_ACCELERATED | FLAG_SPLIT_TOUCH | FLAG_SHOW_WALLPAPER | FLAG_LAYOUT_INSET_DECOR | FLAG_LAYOUT_IN_SCREEN

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