В Android N добавлена поддержка отображения нескольких приложений одновременно. На мобильных устройствах два приложения могут быть запущены рядом или друг над другом в режиме разделения экрана . На телевизорах приложения могут использовать режим "картинка в картинке" , чтобы воспроизводить видео, пока пользователи работают с другим приложением.
Если вы создаете приложение с использованием N Preview SDK, вы можете указать, как оно будет действовать в многооконном режиме. Например, можно задать минимальные допустимые размеры окна приложения. Также можно отключить многооконный режим для приложения, чтобы оно отображалось только в полноэкранном режиме.
В Android N несколько приложений могут одновременно находиться на экране. Например, пользователь может разделить экран, чтобы просматривать веб-страницу слева и писать сообщение электронной почты справа. Возможности пользователя зависят от устройства.
Рис. 1. Два приложения отображаются рядом в режиме разделения экрана.
Пользователь может перейти в многооконный режим следующими способами.
В этом режиме в каждый момент времени активной является только последняя операция, с которой взаимодействовал пользователь. Такая операция считается самой верхней . Все другие операции приостановлены, даже если они отображаются. Однако система отдает приостановленным, но видимым операциям более высокий приоритет, чем невидимым. Если пользователь взаимодействует с одной из приостановленных операций, она возобновляется, а прежняя самая верхняя операция приостанавливается.
Примечание. В многооконном режиме приложение может быть приостановлено и по-прежнему видимо для пользователя. Приложению может потребоваться продолжать свои операции, даже если оно приостановлено. Например, видимое приостановленное приложение, воспроизводящее видео, будет по-прежнему показывать видео. Поэтому мы не рекомендуем приостанавливать воспроизведение в обработчиках таких приложений. Вместо этого следует приостановить видео в и возобновить воспроизведение в .
Если пользователь переводит приложение в многооконный режим, система уведомляет операцию об изменении конфигурации, как указано в документе . По сути это изменение так же действует на жизненный цикл операции, как уведомление приложения системой о переходе устройства из вертикальной ориентации в горизонтальную, только изменяются размеры экрана, а не ориентация. Как описано в документе , операция может обработать изменение конфигурации самостоятельно или может позволить системе удалить окно операции и создать его заново с новыми размерами.
Если пользователь увеличивает одну из сторон окна, система меняет размер окна операции в соответствии с действием пользователя и применяет по мере необходимости. Если приложение не успевает отрисовать новые области, система временно заполняет их цветом, заданным атрибутом или атрибутом стиля windowBackgroundFallback по умолчанию.
Если ваше приложение предназначено для Android N, вы можете указать, каким образом поддерживают (и поддерживают ли) операции вашего приложения многооконный режим. Атрибуты управления размером и макетом устанавливаются в манифесте. Настройки атрибутов корневой операции применяются ко всем операциям в ее стеке задач.
Примечание. Если приложение с поддержкой различной ориентации было создано с версией SDK, более ранней, чем Android N, и пользователь запустит это приложение в многооконном режиме, система принудительно изменит размер приложения. Система отображает диалоговое окно с предупреждением о том, что приложение может работать непредвиденным образом. Система не меняет размер окна для приложений с фиксированной ориентацией. Если пользователь попытается открыть такое приложение в многооконном режиме, оно займет весь экран.
Android:resizeableActivity=["true" | "false"]
Если для этого атрибута задано значение true, операцию можно запускать в режимах разделения экрана и произвольной формы. Если для атрибута задано значение false, операция не поддерживает многооконный режим. Если значение равно false и пользователь пытается запустить операцию в многооконном режиме, она занимает весь экран.
Если приложение предназначено для Android N, но значение для этого атрибута не было указано, то по умолчанию используется значение true.
Установите этот атрибут в узле
Android:supportsPictureInPicture=["true" | "false"]
В Android N элемент манифеста
Android:defaultWidth Ширина окна операции по умолчанию в режиме произвольной формы. android:defaultHeight Высота окна операции по умолчанию в режиме произвольной формы. android:gravity Начальная позиция окна операции в режиме произвольной формы. Допустимые значения см. в описании класса . android:minimalSize Минимальные значения высоты и ширины окна операции в режимах разделения экрана и произвольной формы. Если пользователь перемещает разделительную линию в режиме разделения экрана, чтобы сделать размер окна операции меньше указанного минимума, система обрезает его до запрошенного пользователем размера.
В следующем примере кода показано, как задать размер и позицию окна операции по умолчанию, а также ее минимальный размер в режиме произвольной формы:
Android N предоставляет новые возможности для поддержки приложений в многооконном режиме.
Некоторые возможности отключены или игнорируются в многооконном режиме, потому что они не имеют смысла для операции, которая отображается на экране устройства одновременно с другими операциями или приложениями. Ниже приведены примеры таких возможностей.
Примечание. Режим "картинка в картинке" - это частный случай многооконного режима. Если метод myActivity.inPictureInPicture() возвращает значение true, myActivity.inMultiWindow() также возвращает true.
Activity.onMultiWindowChanged() Система вызывает этот метод, когда операция переходит в многооконный режим или выходит из него. Система передает методу значение true, если операция входит в многооконный режим, и значение false, если она выходит из него. Activity.onPictureInPictureChanged() Система вызывает этот метод, когда операция переходит в режим "картинка в картинке". Система передает методу значение true, если операция входит в режим "картинка в картинке", и значение false, если она выходит из него.
При запуске новой операции можно сообщить системе, что окно новой операции следует показать рядом с текущим, если это возможно. Для этого используйте флаг Intent.FLAG_ACTIVITY_LAUNCH_TO_ADJACENT . Этот флаг запрашивает следующее поведение.
Если при запуске новой операции устройство находится в режиме произвольной формы, вы можете задать размеры и позицию окна новой операции, вызвав метод ActivityOptions.setLaunchBounds() . Этот метод игнорируется, если устройство не находится в многооконном режиме.
Примечание. Если запустить операцию в стеке задач, она заменит операцию на экране, унаследовав все ее свойства многооконного режима. Чтобы запустить новую операцию в отдельном окне в многооконном режиме, ее следует запустить в новом стеке задач.
Независимо от того, обновляете ли вы свое приложение для Android N, вам необходимо подтвердить его поведение в многооконном режиме на тот случай, если пользователь попытается запустить его в этом режиме на устройстве с Android N.
Если установить Android N на устройстве, режим разделения экрана будет поддерживаться автоматически.
Если вы не применяли N Preview SDK для создания приложения и пользователь попытается запустить его в многооконном режиме, система принудительно изменит размер окна приложения, если его ориентация не зафиксирована.
Если для приложения не задана фиксированная ориентация, вам следует запустить его на устройстве с Android N и попытаться перевести его в режим разделения экрана. Убедитесь, что приложение работает нормально после принудительного изменения размера.
Если для приложения задана фиксированная ориентация, попытайтесь перевести его в многооконный режим. Убедитесь, что при этом приложение остается в полноэкранном режиме.
Если вы использовали N Preview SDK для создания приложения и не отключили поддержку многооконного режима, проверьте работу приложения, как описано далее, в режимах разделения экрана и произвольной формы.
Для проверки производительности приложения в многооконном режиме выполните следующие операции. Попытайтесь выполнить их в режиме разделения экрана и в многооконном режиме, если не указано иное.
Если вы отключили поддержку многооконного режима, установив атрибут android:resizableActivity="false" , запустите приложение на устройстве с Android N и попытайтесь перевести его в режимы произвольной формы и разделения экрана. Убедитесь, что при этом приложение остается в полноэкранном режиме.
Каждый, кто работал в многооконном режиме на Android-устройстве, может подтвердить, что в определенных ситуациях это очень удобно. Простой пример: чтение электронной книги с электронным же словарём. Особенно – на смартфоне или планшете с достаточно большим экраном.
Если пользователю придётся выбирать между двумя приложениями, схожими практически во всём, но различающимися поддержкой одновременной работы с несколькими окнами, неудивительно, что выберет он то, что такую поддержку обеспечивает.
Из статьи вы узнаете о многооконном режиме в Android, и о том, как использовать эту возможность при построении собственных приложений.
В мае 2015-го года вышла Android M Developer Preview (сегодня, в июле, доступна уже Preview 2). Официальный релиз Android M (6.0) ожидается осенью 2015-го года. Кроме прочих новшеств Android M Preview 2 примечателен тем, что поддерживает многооконный режим.
Развитие решений для поддержки многозадачности в Android
Существуют два подхода к работе с несколькими окнами: это использование плавающих (floating) и закрепленных (docked) окон. Среди основных возможностей работы в многооконных режимах можно отметить открытие и закрытие окон (open/close), изменение их размера (resize) и взаимного расположения (swap). Открывая или закрывая окно, мы, соответственно, включаем или выключаем многооконный режим. Функция изменения размера предусматривает настройку размеров окон. Смена расположения окон – это действие, которое позволяет поменять их местами.
Режимы работы с несколькими окнами
В 2013-м году на рынке появилось множество решений, рассчитанных на работу с несколькими окнами. Они были разработаны OEM и ODM-производителями, независимыми поставщиками ПО и сообществом разработчиков программ с открытым исходным кодом. В таблице ниже вы можете найти сравнение различных технологий организации многооконной работы в среде Android.
Продукт | Cornerstone | Standout | Xposed | Tieto |
Описание |
Фреймворк для организации многозадачной работы в ОС Android |
Библиотека с открытым исходным кодом, которую можно использовать для создания приложений с плавающими окнами |
Многооконное приложение, которое поддерживает закрепленные окна |
Проект направлен на создание рабочей среды, напоминающей работу на настольном ПК |
Поддержка открытия, закрытия окон, изменения размера, раскрытия на весь экран |
Да |
Да |
Да |
Да |
Стиль окна |
Закрепленное |
Плавающее |
Закрепленное |
Закрепленное и плавающее |
Модификация кода |
На уровне платформы Android |
На уровне приложения |
На уровне платформы Android |
На уровне платформы Android |
Поддержка приложений |
Поддерживаются все приложения, однако, не доступна динамическая настройка SurfaceView. |
Некоторые вспомогательные приложения. Например – калькулятор. |
Совместимость и стабильность решения нуждается в улучшении. |
Поддерживает все приложения. |
Версия Android |
Android 4.1. – Android 4.4. |
Android 4.1. – Android 4.4. |
Android 4.4. |
Android 4.4 |
Официальный сайт |
Клик |
Клик |
Клик |
Клик |
В случае с Android 4.2 и Android 4.3., оболочка (launcher) и другие приложения при запуске размещаются в одном стеке, называемом «главный стек» («main stack»). Как известно, многооконный режим требует большего количества стеков для размещения в них нескольких окон. В результате, нужно модифицировать системный класс ActivityManagerService, добавив к нему интерфейс для создания стека и управления им. Для модификации класса платформы WIndowManagerService, который позволяет управлять графическими представлениями приложений, требуется изменить InputManager. Нужно это для того, чтобы он мог перенаправлять события касания соответствующим окнам.
С выходом Android 4.4 и Android 5.0 подход к управлению стеком значительно изменился. Оболочка и другие приложения могут запускаться в различных стеках. В систему была добавлена поддержка нескольких стеков и возможность управления ими. На рисунке ниже показаны отличия в работе со стеком в разных версиях Android.
Сравнение работы со стеком в Android 4.3 и Android 4.4
Теперь сосредоточимся на Android 5 (Lollipop). ОС Android использует механизмы обратного вызова для выполнения интерфейсных функций Activity. Однако управляющая функция реализована на уровне платформы. Поэтому сейчас мы рассмотрим два важных класса: ActivityManagerService и WindowManagerService.
Структура ПО платформы Lollipop
Процесс создания стека в Lollipop
Теперь посмотрим, как запустить Activity в стеке:
Запуск Activity в стеке
В Lollipop в утилиту ADB (Android Debug Bridge, отладочный мост Android) были добавлены следующие команды:
Роль WindowsManagerService в
графической архитектуре Android
Ещё одна проблема заключается в том, что некоторые приложения в многооконном режиме отображаются некорректно. На рисунке ниже вы можете видеть, что калькулятор в многооконном режиме отображается неправильно. Всё дело в макете приложения, который не рассчитан на подобные условия использования.
Для того чтобы увидеть этот режим в действии, достаточно создать новое виртуальное устройство с помощью средства AVD Manager, выбрав при этом в качестве системного образа один из доступных с API Level MNC. В нашем случае это был образ x86_64. Далее, надо запустить эмулятор, перейти в раздел настроек Для разработчика и включить там опцию Многооконный режим. Если такой опции найти не удаётся, взгляните на это руководство
Теперь самое интересное. Для начала можно запустить несколько приложений, всё будет как обычно. А вот если нажать на кнопку вызова списка недавно открытых приложений, в заголовках миниатюр окон появится новый значок. По умолчанию это – рамка, указывающая на то, что приложение запускается в полноэкранном режиме. Если на этот значок нажать, появится меню выбора макета расположения окон.
Будет ли доступна работа с несколькими окнами в официальном релизе Android M, пока неизвестно. Однако, например, системный калькулятор в этом режиме чувствует себя хорошо. В результате, у нас есть серьёзные основания полагать, что не за горами тот день, когда адаптация приложений для многооконного режима из конкурентного преимущества превратится в насущную необходимость.
Если же вы хотите оснастить свои приложения, рассчитанные на более ранние версии Android, поддержкой нескольких окон, самое время обратиться к решениям сторонних разработчиков, о которых речь шла выше. Например, к Cornerstone.
Модификации Cornerstone в Android Jelly Bean
В Android 6.0 спрятана экспериментальная опция, позволяющая использовать режим многооконности. Активировать ее относительно сложно, но если сделать все правильно, никаких трудностей с этим не должно возникнуть. В отличие от аналогичной функции на смартфонах Samsung, она работает со всеми приложениями.
Для того, чтобы на Android 6.0 появилась опция многооконности, нужно всего лишь отредактировать файл build.prop, указав в нем, что вы пользуетесь сборкой userdebug, а не user. Это можно сделать с помощью компьютера и кастомного рекавери, а если на устройстве получен root-доступ - обычным текстовым редактором.
Первый способ
1. Установите на устройство кастомное рекавери (например, TWRP). Для этого скачайте и установите ADB из Android SDK . Затем скачайте образ рекавери для своего устройства, переименуйте его в twrp.img и поместите папку ADB.
2. Подключите смартфон к компьютеру USB-кабелем, откройте командную строку и выполните три команды:
Adb reboot bootloader
fastboot flash recovery twrp.img
fastboot reboot
3. Выключите смартфон и зайдите в рекавери нажатием определенного сочетания клавиш (как правило, кнопка питания и кнопки прибавления и убавления громкости).
4. В рекавери выберите раздел Mounts и поставьте крестик напротив System.
5. Подключите смартфон к компьютеру кабелем и на компьютере в командной строке задайте следующую команду:
Adb pull /system/build.prop
6. На компьютер скачается файл build.prop. Откройте его в блокноте и замените строку «ro.build.type=user» на «ro.build.type=userdebug»
7. Загрузите файл build.prop обратно на смартфон, задав в командной строке команду:
Adb push build.prop /system/
8. Задайте еще три команды, которые нужны для того, чтобы сторонние приложения не могли модифицировать build.prop:
Adb shell
cd system
chmod 644 build.prop
9. Перезагрузите смартфон и активируйте многооконность в настройках для разработчиков.
Второй способ
На смартфонах с root-доступом отредактировать файл build.prop намного проще. Это можно сделать специальным приложением Build Prop Editor или с помощью текстового редактора, встроенного в файловый менеджер вроде Root Explorer или X-Plore. Файл расположен по адресу /system/build.prop, и в нем нужно заменить строку «ro.build.type=user» на «ro.build.type=userdebug».
Как активировать многооконность?
1. Откройте в системные настройки, перейдите в раздел «Об устройстве» и несколько раз нажмите на номер сборки Android.
2. В настройках появится раздел для разработчиков. Зайдите в него - вы увидите переключатель, позволяющий активировать многооконность.
3. Откройте экран многозадачности долгим нажатием на кнопку домашней страницы (или на виртуальную кнопку). Вы увидите новый значок на миниатюрах страниц приложений. После нажатия на него система предложит выбрать расположение приложения: на половине, одной четвертой экрана или на всем экране. Когда открыто несколько приложений, пропорции их окон можно менять.
Скорее всего, в будущем Google откроет доступ к этой функции Android всем пользователям. Как полагаете, она нужна смартфонам и планшетам или совершенно бесполезна?
Как мы уже знаем, версия Android Nougat располагает множеством функций, способных сделать работу пользователя максимально гладкой. Основные моменты новейшего обновления Android включают в себя улучшенную панель уведомлений, оптимизацию механизма передачи данных и энергосбережения, а также поддержку устройств виртуальной реальности. Одним из важнейших аспектов нововведений, завоевавшего немало фанатов (включая и нас), является набор опций управления задачами. Благодаря последнему обновлению Android 7.0 Nougat, теперь вы можете использовать два приложения одновременно в мультиоконном режиме.
Примечание
Мы хотим вам сообщить, что не все приложения одинаковы по своей сути,
и по этой причине вы обнаружите, что не все из них совместимы с мультиоконным режимом. Однако вам не следует волноваться – это не ваша вина, а вина разработчиков, так как им понадобиться еще какое-то время, чтобы создать очередное обновление, прежде чем другие приложения смогут работать в вышеуказанном режиме. На сегодняшний день есть способ, как обойти такую проблему. Вы можете запустить любое приложение в мультиоконном режиме из-под «Средства разработчика» в последней версии мобильной операционной системы от Google.
Для начала вам необходимо активировать пункт «Средства разработчика» на вашем телефоне. Для этого пройдите по схеме «Настройки > Средства разработчика > Об устройстве». Далее нажмите несколько раз на номер сборки, пока не увидите сообщение о том, что вы стали разработчиком.
Теперь снова вернитесь в меню настроек и откройте «Средства разработчика». Сделайте прокрутку страницы до самого низа и включите опцию «Принудительное изменение размеров операций». Когда вы сделаете это, вам надо будет перезагрузить ваш девайс, чтобы активировать данную опцию. После этого даже те приложения, которые не были совместимы с обновлением для Nougat, смогут работать в мультиоконном режиме.
И, наконец, чтобы воспользоваться многооконным режимом, откройте два приложения по вашему выбору, после чего нажмите и удерживайте клавишу многозадачности. Теперь оба этих приложения откроются в мультиоконном режиме.
По вашему мнению, мультиоконный режим будет полезен для ваших многозадачных нужд? Или вы будете придерживаться более традиционного однозадачного подхода на данный момент? Поделитесь с нами вашими соображениями в комментариях.
Внимание! В статье использованы скриншоты и опции из операционной системы Android 7.1. Хотя большинство описанных элементов должны присутствовать и в других версиях Android, автор этого не гарантирует.
Несмотря на то, что речь в статье пойдёт о настройках для разработчиков, не стоит пугаться этого названия. Некоторые из представленных в этом разделе опций пригодятся и обычным пользователям. По умолчанию они не отображаются в настройках, но это легко исправить.
Теперь давайте познакомимся с некоторыми из открывшихся нам возможностей.
Некоторые разработчики специально отключают в своих приложениях возможность установки на SD-карту. С помощью переключателя «Разрешить сохранение на внешние накопители» вы можете разрешить это независимо от желания разработчика.
Учтите, что у разработчика может быть веская причина для запрета установки на внешнюю карту. Некоторые программы жёстко привязаны к определённому месту и не будут работать, если они установлены не там, где планировал разработчик. Поэтому пользоваться этой функцией нужно с осторожностью.
Многооконный режим - это фишка последних версий операционных систем от компании Google. Однако для работы этой функции требуется не только правильная версия Android, но и поддержка в самих приложениях, о чём, к сожалению, позаботились далеко не все разработчики.
С помощью опции «Изменение размера в многооконном режиме» вы сможете использовать в данном режиме любые приложения.
Обычно смартфоны сами выключают экран во время бездействия для экономии заряда батареи. Однако в некоторых случаях эта функция не нужна. Например, если вы хотите использовать старый смартфон в виде настольных часов или в автомобиле в качестве навигатора.
Опция «Не выключать экран» позволит смартфону пребывать в активном режиме всё время, пока он подключён к зарядному устройству.
Это одна из самых полезных опций, позволяющая добиться значительного визуального ускорения работы Android. Дело в том, что некоторые производители в погоне за вау-эффектами слишком перегружают операционную систему красивой анимацией.
В этом разделе опций для разработчика вы сможете самостоятельно задать время их отображения или вообще отключить. В результате будет казаться, что система начала просто летать.
Если в вашем устройстве используется AMOLED-экран, то количество отображаемых цветов действительно имеет значение для экономии батареи. Чтобы протянуть ещё больше на остатках заряда, просто активируйте монохромный режим. Данная опция тоже скрывается в настройках для разработчика и называется «Имитировать аномалию».
А какие полезные опции для разработчиков используете вы?