Уведомления о приложениях
Иллюстрации
Показать всеИзобретение относится к методам уведомления о приложениях. Технический результат - эффективное управление уведомлениями, связанными с приложениями. Способ управлениями уведомлениями, связанными с приложениями, реализуемый одним или более вычислительными устройствами, при этом способ содержит этапы, на которых: отображают представление приложения в пользовательском интерфейсе; принимают одно или более уведомлений, которые относятся к приложению, для их отображения в качестве части представления приложения в пользовательском интерфейсе; анализируют манифест приложения без исполнения приложения, чтобы найти критерии, задающие, как и когда должны отображаться упомянутые уведомления в качестве части представления приложения в пользовательском интерфейсе; и отображают представление приложения в пользовательском интерфейсе включающим в себя упомянутые одно или более уведомлений в пользовательском интерфейсе в соответствии с упомянутыми задающими критериями. 3 н. и 17 з.п. ф-лы, 12 ил.
Реферат
[0001] Распространенность вычислительных устройств постоянно растет. Например, пользователи могут взаимодействовать с традиционным настольным компьютером, планшетным компьютером, мобильным телефоном и т.д., чтобы получить доступ к различным функциональным возможностям для работы и личного использования. Кроме того, различные функциональные возможности, доступные для пользователей этих устройств, также продолжают возрастать.
[0002] Это особенно верно в случае приложений. Доступность приложений была традиционно ограничена, так как пользователи обычно приобретали приложения в "bricks and mortar" (традиционных, не связанных с Интернетом) магазинах. С появлением доступности приложений через Интернет количество приложений, которые становятся доступными для пользователя, выросло вместе с легкостью, с которой пользователь может получить доступ к этим приложениям. Соответственно пользователи могут выбирать и инсталлировать большое количество приложений на пользовательском вычислительном устройстве.
[0003] Однако взаимодействие пользователя с приложениями может быть затруднено количеством приложений, которые инсталлированы на вычислительном устройстве. Это может включать в себя поиск интересующего приложения, а также доступ к функциональности приложения. Например, пользователь может выбрать приложение «погода», чтобы получить информацию о погоде, затем взаимодействовать с приложением «новости», чтобы просмотреть последние новости, и так далее через ряд других приложений. Следовательно, навигация по этим приложениям, чтобы найти нужную информацию, может занять значительное количество времени, что может быть дополнительно осложнено количеством приложений, которые доступны на вычислительном устройстве.
СУЩНОСТЬ ИЗОБРЕТЕНИЯ
[0004] Описаны методики уведомления для приложений. Описаны реализации, в которых представление приложения может включать в себя уведомления, которые относятся к приложению. Далее описаны методики, которые могут быть использованы для управления уведомлениями, включая замену уведомлений, использование очередей, переопределения, выбор уведомлений на основе состояния исполнения приложения, циклирование отображения множества уведомлений (например, пользователем или автоматически с помощью вычислительного устройства), циклирование отображений различных подмножеств уведомлений, рассмотрение манифеста приложения, чтобы определять критерии, которые должны использоваться для отображения уведомлений, приоритет отображения уведомлений и так далее.
[0005] Это краткое изложение сущности изобретения предоставлено, чтобы ввести подборку концепций в упрощенной форме, которые дополнительно описаны ниже в подробном описании. Это краткое изложение сущности изобретения не предназначено ни для идентификации ключевых признаков или существенных признаков заявленного изобретения ни для использования в качестве помощи в определении объема заявленного изобретения.
КРАТКОЕ ОПИСАНИЕ ЧЕРТЕЖЕЙ
[0006] Подробное описание приведено со ссылками на прилагаемые чертежи. На чертежах самая(ые) левая(ые) цифра(ы) ссылочной позиции определяет(ют) фигуру, на которой ссылочная позиция появляется впервые. Использование одних и тех же ссылочных позиций в различных случаях в описании и на чертежах может указывать подобные или идентичные элементы.
[0007] Фиг. 1 является иллюстрацией среды в примерной реализации, которая выполнена с возможностью применять методики уведомления для приложений.
[0008] Фиг. 2 изображает систему в примерной реализации, в которой множество уведомлений отображается последовательно как часть представления приложения.
[0009] Фиг. 3 показывает систему, в которой используется тег для указания того, что соответствующее уведомление должно быть использовано для замены другого уведомления.
[0010] Фиг. 4 показывает блок-схему, изображающую процедуру примерной реализации, в которой используется очередь для управления уведомлениями для вывода в качестве части представления приложения.
[0011] Фиг. 5 показывает блок-схему, изображающую процедуру примерной реализации, в которой используются теги для управления заменой уведомлений для отображения в качестве части представления приложения.
[0012] Фиг. 6 показывает блок-схему, изображающую процедуру примерной реализации, в которой используется очередь для управления уведомлениями для отображения в качестве части представление приложения.
[0013] Фиг. 7 показывает блок-схему, изображающую процедуру примерной реализации, в которой состояние выполнения приложения используется в качестве основы для определения того, какие уведомления должны быть отображены в качестве части представления приложения.
[0014] Фиг. 8 показывает блок-схему, изображающую процедуру примерной реализации, в которой уведомления отображаются в представлениях приложений, которые могут быть выбраны, чтобы запустить приложение, причем отображение циклируется для последовательного отображения уведомлений.
[0015] Фиг. 9 показывает блок-схему, изображающую процедуру примерной реализации, в которой подмножества уведомлений циклируются для отображения в качестве части соответствующих представлений приложений.
[0016] Фиг. 10 показывает блок-схему, изображающую процедуру примерной реализации, в которой манифест приложения используется для указания критериев, которые должны использоваться для управления отображением уведомлений в качестве части представления приложения.
[0017] Фиг. 11 показывает блок-схему, изображающую процедуру примерной реализации, в которой веб-служба используется для управления предоставлением уведомлений на клиентском устройстве для отображения.
[0018] Фиг. 12 показывает блок-схему, изображающую процедуру примерной реализации, в которой уведомления приоритизируются для отображения в качестве части представления приложения.
ПОДРОБНОЕ ОПИСАНИЕ ОБЗОР[0019] Уведомления для приложений могут использоваться приложениями для отображения информации в представлении приложения (например, иконка, мозаика и т.д.) без того, что пользователь специально запускает приложение. Например, представление приложения «погода» может включать уведомление, которое описывает текущие погодные условия. Однако обычные методы, которые использовались для отображения уведомления, были часто статическими и поэтому не позволяли разработчикам управлять тем, каким образом уведомления отображались в качестве части представления.
[0020] Однако здесь описаны методики, которые могут быть использованы для управления уведомлениями. Кроме того, в одной или более реализаций эти методики могут быть выполнены без исполнения соответствующего приложения, сохраняя тем самым срок службы аккумулятора и повышая производительность вычислительных устройств, которые выполняют эти методики. В следующих разделах описаны примеры множества различных методик, которые относятся к уведомлениям для приложений, например замена уведомлений, использование очередей, переопределения, выбор уведомления на основе состояния выполнения приложения, циклирование отображения множества уведомлений, циклирование отображения различных подмножеств уведомлений, рассмотрение манифеста приложения, чтобы определить критерии, которые будут использоваться для отображения уведомлений, отображение приоритета уведомлений и так далее. Дальнейшее обсуждение этих методов и другого может быть найдено в следующих разделах.
[0021] В последующем обсуждении сначала описывается иллюстративная среда, которая может использовать методики, описанные в данном документе. Затем описываются процедуры, которые могут быть выполнены в иллюстративной среде, а также в других средах. Следовательно, выполнение иллюстративных процедур не ограничивается иллюстративной средой, и иллюстративная среда не ограничивается выполнением иллюстративных процедур.
ИЛЛЮСТРАТИВНАЯ СРЕДА
[0022] Фиг. 1 является иллюстрацией среды 100 в иллюстративной реализации, которая выполнена с возможностью использования методов, описанных в данном документе. Иллюстративная среда 100 включает в себя веб-службу 102 и клиентское устройство 104, которые коммуникативно связаны через сеть 106. Веб-служба 102 и клиентское устройство 104 могут быть реализованы посредством широкого диапазона вычислительных устройств.
[0023] Например, вычислительное устройство может быть сконфигурировано как компьютер, который способен осуществлять связь по сети 106, такой как настольный компьютер, мобильная станция, развлекательное устройство, телеприставка, коммуникативно-соединенная с устройством отображения, мобильное устройство связи (например, беспроводной телефон, как показано для клиентского устройства 104), игровая консоль и так далее. Таким образом, вычислительное устройство может варьироваться от полноресурсного устройства с существенными ресурсами памяти и процессора (например, персональные компьютеры, игровые консоли) до малоресурсного устройства с ограниченной памятью и/или ресурсами обработки (например, традиционные телевизионные приставки, портативные игровые консоли). Кроме того, вычислительное устройство может быть представителем множества различных устройств, таких как несколько серверов, используемых в бизнесе для выполнения операций, комбинация пульта дистанционного управления и приставки, устройство захвата изображения и игровая консоль, конфигурированные для захвата (съемки) жестов и так далее.
[0024] Хотя сеть 106 проиллюстрирована как Интернет, сеть может принимать широкое разнообразие конфигураций. Например, сеть 106 может включать в себя глобальную сеть (WAN), локальную сеть (LAN), беспроводную сеть, телефонную сеть общего пользования, интранет и так далее. Кроме того, хотя показана одиночная сеть 106, сеть 106 может быть сконфигурирована, чтобы включать в себя несколько сетей.
[0025] Клиентское устройство 104 дополнительно проиллюстрировано как включающее в себя операционную систему 108. Операционная система 108 сконфигурирована, чтобы абстрагировать базовую функциональность клиента 104 от приложений 110, которые выполняются на клиентском устройстве 104. Например, операционная система 108 может абстрагировать обработку, память, сеть и/или функциональные возможности отображения клиентского устройства 104, так что приложения 110 могут быть записаны, не зная, "как" эта базовая функциональность реализована. Приложение 110, например, может предоставить операционной системе 108 данные, подлежащие воспроизведению и отображению устройством 112 отображения, без понимания того, как это воспроизведение будет выполняться.
[0026] Операционная система 108 может также представлять многообразие другой функциональности, такой как управление файловой системой и пользовательский интерфейс, который обеспечивает выполнение поиска и просмотра пользователем клиентского устройства 104. Пример этого показан в виде запускающего модуля приложения (например, рабочего стола), который отображается на устройстве 112 отображения клиентского устройства 104. Рабочий стол включает представления множества приложений 110, такие как иконки, мозаика, текстовые описания и так далее. Рабочий стол может рассматриваться как корневой уровень иерархической файловой структуры. Представления, показанные в приведенном примере, могут выбираться для запуска соответствующего одного из приложений 110 для выполнения на клиентском устройстве 104. Таким образом, пользователь может легко перемещаться по файловой структуре и инициировать выполнение приложения, представляющего интерес.
[0027] Операционная система 108 также показана как включающая в себя модуль 114 уведомлений. Модуль 114 уведомлений представляет функциональность для управления уведомлениями 116, которые должны быть отображены как часть представлений приложений. Например, представление 118 приложения «погода» иллюстрируется как включающее в себя уведомление, которое указывает название и текущие погодные условия, например "Сиэтл 65°/облачно". Кроме того, представление 120 для приложения «путешествия» иллюстрируется как включающее в себя уведомление, которое указывает, что текущий статус полета - "задержан". Таким образом, пользователь может легко просмотреть информацию, относящуюся к приложениям 110, без запуска и навигации по каждому из приложений. Хотя показаны представления конкретных приложений, другие представления приложений также рассматриваются, такие как представление приложения, которое ссылается на причастность пользователя к службе, например друг в службе социальной сети.
[0028] В одной или нескольких реализациях уведомлениями 116 можно управлять без выполнения соответствующего приложения 110. Например, модуль 114 уведомлений может получать уведомления 116 из множества различных источников, например из программного обеспечения (например, других приложений, выполняемых клиентским устройством 104), из веб-службы 102 через сеть 106 и так далее. Модуль 114 уведомлений может тогда управлять тем, каким образом уведомления 116 отображаются в качестве части представлений без исполнения приложений 110. Это может быть использовано для улучшения срока службы аккумулятора и производительности клиентского устройства 104 за счет невыполнения каждого из приложений 110 для вывода уведомления 116.
[0029] Кроме того, модуль 114 уведомления может поддерживать методы, чтобы позволять разработчикам соответствующих приложений 110 указывать, каким образом уведомления 116 должны быть отображены как часть представления приложений 110. Например, модуль 114 уведомлений может рассмотреть манифест 122 приложения 110, например манифест установки, используемый для установки приложения 110, во время исполнения, используя системный вызов, и так далее. Манифест 110 может описывать, как и когда уведомления 116 должны отображаться, а также то, каким образом уведомления 116 подлежат регулированию, чтобы определить, какие уведомления 116 должны отображаться.
[0030] Модуль 114 уведомлений также может использовать различные другие методы, чтобы дать возможность разработчику или другому объекту определить, каким образом уведомления 116 должны отображаться и управляться. Например, уведомления 116 могут быть переданы вместе с соответствующими тегами, которые определяют, каким образом уведомления 116 должны отображаться и/или управляться. Таким образом, инициатор (отправитель, источник) тегов может указать, каким образом соответствующие уведомления 116 должны отображаться или управляться. Это может быть выполнено, чтобы запускать многообразие различных функциональностей, как дополнительно описано в следующих разделах.
[0031] Хотя в этом обсуждении описывалось включение модуля 114 уведомлений на клиенте, функциональность модуля 114 уведомлений может быть реализована в различных формах. Например, функциональность модуля 124 уведомлений может быть включена в веб-службу 102 полностью или частично. Модуль 124 уведомлений, например, может обрабатывать уведомления, полученные от других веб-служб, и управлять уведомлениями для распределения на клиентское устройство 104 через сеть 106.
[0032] Многообразие различных методов может быть использовано модулем 124 уведомлений, например, для обработки уведомлений в соответствии с методами, которые будут использоваться самим клиентским устройством 104, например, для рассмотрения манифеста, обработки тегов в ответ на сообщение, полученное от клиентского устройства 104, которое задает критерии для управления уведомлениями 116, и так далее. Кроме того, эта обработка может быть выполнена в случаях, когда клиентское устройство 104 недоступно, например, из-за отсутствия соединения сети 106. Таким образом, веб-служба 102 может эффективно использовать пространство хранения и пропускную способность сети 106. Другие примеры также рассматриваются, такие как распределение функциональных возможностей модуля 114 уведомлений между клиентским устройством 104 и веб-службой 102, включение службы третьей стороны и так далее.
[0033] Как правило, любая из функций, описанных здесь, может быть реализована с использованием программного обеспечения, микропрограммного обеспечения, аппаратных средств (например, фиксированных логических схем) или комбинации этих реализаций. Термины "модуль", "функциональность" и "логика", используемые здесь, как правило, представляют программное обеспечение, микропрограммное обеспечение, аппаратные средства или их сочетание. В случае программной реализации модуль, функциональность или логика представляет программный код, который выполняет определенные задачи при исполнении на процессоре (например, центральном процессоре (CPU) или центральных процессорах). Программный код может храниться в одном или более машиночитаемых запоминающих устройств. Особенности методов, описанных ниже, являются независимыми от платформы, а это означает, что способы могут быть реализованы на различных коммерческих вычислительных платформах, имеющих различные процессоры.
[0034] Например, вычислительное устройство может также включать в себя объект (например, программное обеспечение), который вызывает выполнение операций аппаратными средствами вычислительного устройства, например процессорами, функциональными блоками и так далее. Например, вычислительное устройство может включать в себя машиночитаемый носитель, который может быть выполнен с возможностью поддержания инструкций, которые побуждают вычислительное устройство, более конкретно аппаратные средства вычислительного устройства к выполнению операций. Таким образом, инструкции функционируют, чтобы конфигурировать аппаратные средства выполнять операции, и, таким образом, приводят в результате к трансформации аппаратных средств для выполнения функций. Инструкции могут быть предоставлены машиночитаемым носителем вычислительному устройству через множество различных конфигураций.
[0035] Одной такой конфигурацией считываемого компьютером носителя является среда, несущая сигнал и, следовательно, конфигурированная для передачи инструкций (например, в виде несущей волны) к аппаратным средствам вычислительного устройства, например через сеть. Считываемый компьютером носитель также может быть сконфигурирован как считываемый компьютером запоминающий носитель и, таким образом, не среда, несущая сигнал. Примеры считываемого компьютером запоминающего носителя включают в себя оперативное запоминающее устройство (RAM), постоянное запоминающее устройство (ROM), оптический диск, флэш-память, память на жестком диске и другие устройства памяти, которые могут использовать магнитные, оптические и другие методы для хранения инструкций и других данных.
[0036] На фиг. 2 изображена система 200 в иллюстративной реализации, в которой множество уведомлений последовательно отображаются как часть представления приложения. Система 200 проиллюстрирована посредством использования первого, второго и третьего этапов 202, 204, 206. Уведомления 116 могут принимать различные формы и упорядочиваться различными способами для отображения в пределах представления 118.
[0037] Как иллюстрируется на фиг. 2, например, показано уведомление 208, имеющее множество фреймов 210, 212. На первом этапе 202 первый 210 из фреймов уведомления 208 используется для отображения графического изображения облака и текста "Сиэтл" для представления приложения погода.
[0038] На втором этапе 204 второй 212 из фреймов уведомления 208 используется для отображения текста "Сиэтл" и текста "65°/облачно", чтобы описать дополнительные текущие погодные условия в Сиэтле. Таким образом, уведомление 208 может быть сконфигурировано, чтобы включать в себя фреймы 210, 212, которые должны отображаться последовательно как часть представления 118.
[0039] Дополнительные уведомления также могут быть отображены в последовательности как часть представления 118. Как показано на третьем этапе 206, например, уведомление 214 используется для отображения графики и текста из солнца и текущих погодных условий для "Спокан, 52°". Таким образом, в этом примере системы 200 модуль 114 уведомлений может быть использован для циклического переключения между уведомлениями 208, 214 для отображения в качестве части представления 118 приложения 110. Как отмечалось ранее, управление уведомлениями 116 может быть выполнено с использованием различных методов, пример которых с использованием тегов описан со ссылками на следующий чертеж.
[0040] На фиг. 3 изображена система 300, в которой тег используется для указания того, что соответствующее уведомление должно быть использовано для замены другого уведомления. Веб-служба 102 показана как коммуникативно связанная с клиентским устройством 104 через сеть 106, как описано выше со ссылкой на фиг. 1. В этом примере веб-служба 102 передает уведомление 302 и соответствующий тег 304 на клиентское устройство 104.
[0041] При получении уведомления 302 модуль 114 уведомлений может определить, что имеется соответствующий тег 304. В соответствии с этим модуль 114 уведомлений может проверить память, которая является локальной для клиентского устройства 104, чтобы определить, имеет ли другое уведомление 306 совпадающий тег.
[0042] В показанном примере уведомление 306 включает в себя тег 304, который совпадает с тегом 304 принятого уведомления 302. Соответственно модуль 114 уведомления может заменить уведомление 306 последним принятым уведомлением 302. Таким образом, инициатор (отправитель) тега 302 может легко заменить одно уведомление на другое через использование тегов.
[0043] Тег 304 может быть задан в различных формах. Например, тег 304 может быть сконфигурирован таким образом, что значение тега 304 может быть назначено инициатором тега из любого значения. Таким образом, в этом примере модуль 114 уведомления может управлять заменой уведомлений без "знания" того, что соответствующие теги "означают". Множество других примеров также могут учитываться, например, путем указания конкретного сегмента в очереди, пример которого описан со ссылкой на следующий чертеж. Хотя эта функциональность была описана со ссылкой на модуль 114 уведомления клиентского устройства 104, как указывалось ранее, эта функциональность может быть реализована с использованием разнообразия различных устройств, пример которых показан модулем 124 уведомлений веб-сайта 102.
[0044] На фиг. 4 изображена система 400 в примере реализации, в котором очередь используется для управления уведомлениями 116 для вывода в качестве части представления приложения. Как и прежде, клиентское устройство 104 коммуникативно связано с веб-службой 102 через сеть 106. Клиентское устройство 104 включает в себя модуль 114 уведомлений, который в этом случае иллюстрируется как часть операционной системы 108.
[0045] Клиентское устройство 104 также показано как включающее в себя очередь 402, которая сконфигурирована для хранения уведомлений 116 для соответствующих приложений 404. Очередь 402, например, может быть сконфигурирована для хранения максимального количества уведомлений 116 для конкретных приложений и, таким образом, иллюстрируется на чертеже как "внутри" приложения 404 в очереди 402. Однако должно быть очевидно, что очередь 402 может быть сконфигурирована в различных формах.
[0046] Модуль 114 уведомления может управлять уведомлениями 116 с использованием очереди 402 различными способами. Например, уведомление может использовать метод "первым вошел/первым обслужен" (FIFO) для управления уведомлениями 116, метод "последним вошел/первым обслужен" и так далее. Например, модуль 114 уведомления может получить уведомление 406, которое указывает конкретный сегмент в очереди 402. Сегменты, например, могут описывать приоритет, с которым уведомления 116 должны отображаться как часть представления. Дополнительные методы управления могут использовать эту спецификацию, например, для перемещения предыдущих уведомлений 116 "вниз" по приоритету, так что уведомление, имеющее самый низкий приоритет, удаляется, чтобы заменить уведомление 408 в сегменте принятым уведомлением 406 и сохранить порядок в остальном, и так далее. Другие методы также возможны, например использование команды переопределения, как дополнительно описано в иллюстративных процедурах.
ИЛЛЮСТРАТИВНЫЕ ПРОЦЕДУРЫ
[0047] Следующее обсуждение описывает методы уведомления, которые могут быть реализованы с использованием ранее описанных систем и устройств. Аспекты каждой из процедур могут быть реализованы в аппаратных средствах, встроенном программном обеспечении или программном обеспечении или их комбинации. Процедуры представлены в виде набора блоков, которые определяют операции, выполняемые одним или несколькими устройствами, и не обязательно ограничиваются порядком, показанным для выполнения операций соответствующими блоками. В частях последующего описания будут делаться ссылки на иллюстративную среду.
[0048] На фиг. 5 изображена процедура 500 в иллюстративной реализации, в которой теги используются для управления заменой уведомлений для отображения как части представления приложения. Принимается уведомление, которое должно быть отображено как часть представления приложения в пользовательском интерфейсе, причем уведомление связано с тегом (блок 502). Например, уведомление может быть принято в модуле 114 уведомлений клиентского устройства 104 из приложения, выполняемого на клиентском устройстве 104, из веб-службы и так далее. В другом примере модуль 124 уведомления веб-службы 102 может принимать уведомление из другой веб-службы и управлять хранением и распределением уведомления на клиентское устройство 104. Также возможно использование множества других примеров.
[0049] Тег уведомления сравнивается с одним или несколькими другими тегами, ассоциированными с одним или несколькими другими уведомлениями (блок 504). Модуль 114 уведомлений, например, может сравнить тег для уведомления для приложения к тегам других уведомлений для этого приложения, чтобы найти соответствие.
[0050] В ответ на определение того, что принятый тег соответствует по меньшей мере одному из других тегов, другое уведомление, ассоциированное с по меньшей мере одним из других тегов, заменяется принятым уведомлением для отображения как часть представления приложения в пользовательском интерфейсе (блок 506). Например, модуль 114 уведомления может сравнивать текстовые строки тегов в соответствующих уведомлениях, чтобы определить, совпадают ли они. Таким образом, в этом примере текстовые строки не должны быть "известными" в отношении того, "что они делают или представляют", модулю 114 уведомлений, чтобы содействовать функциональности замены. Таким образом, модуль 114 уведомлений может поддерживать разнообразные определения и идентификаторы тегов и при этом поддерживать функциональность замены, описанную в данном документе.
[0051] Принятое уведомление может затем отображаться в пользовательском интерфейсе клиентского устройства как часть представления приложения (этап 508). Отображение может быть выполнено в различных формах, таких как часть циклического отображения, как описано со ссылкой на фиг. 2, статическое отображение, отображение представление, которое может выбираться для запуска представляемого приложения (например, элемент мозаики в запускающем модуле приложения, выводимый посредством операционной системы 108) и так далее.
[0052] Кроме того, уведомление может быть использовано для запуска соответствующего приложения в контексте уведомления. Например, если пользователь устанавливает приложение «новости», выбор представления приложения будет запускать приложение в «домашнее» или «по умолчанию» состояние приложения. В примере приложения «новости» - на переднюю полосу газеты. Однако если приложение «новости» получает уведомление о землетрясении и пользователь выбирает это уведомление, то приложение «новости» может затем запускаться в контексте этого уведомления. Например, приложение «новости» может быть запущено непосредственно со статьи о землетрясении, а передняя полоса «пропускается». Также возможно множество других примеров.
[0053] На фиг. 6 изображена процедура 600 в примере реализации, в котором используется очередь для управления уведомлениями для отображения как части представления приложения. Принимается множество уведомлений, которые должны быть отображены как часть представления приложений в пользовательском интерфейсе (блок 602). Как и прежде, уведомление может приниматься в модуле 114 уведомлений клиентского устройства 104 из приложения, выполняемого на клиентском устройстве 104, из веб-службы и так далее. В другом примере модуль 124 уведомлений веб-службы 102 может принимать уведомления из другой веб-службы и управлять хранением и распределением уведомления на клиентское устройство 104. Также возможно множество других примеров.
[0054] Одно или более уведомлений управляются с использованием очереди, которая конфигурирована, чтобы хранить до заданного количества уведомлений, которые должны быть сделаны доступными для отображения как часть представления приложения (этап 604). Уведомления, сохраненные в очереди, затем побуждаются для отображения как часть представления приложения в пользовательском интерфейсе (блок 606). Установленное количество, например, может устанавливаться разработчиком приложения 110, может устанавливаться инициатором уведомления 116, может предварительно определяться самим модулем 114 и так далее.
[0055] Модуль 114 уведомлений может использовать очередь 402, которая указывает объект, который используется для сбора уведомлений, в различных формах, например с использованием метода "первым вошел/первым обслужен", с использованием тегов, которые задают конкретные сегменты в очереди 402, и так далее. В дополнительных примерах очередь 402 может использовать методы установления приоритетов, например указание конкретного порядка, в котором уведомления 116 должны циклироваться на дисплее, и так далее, как описано со ссылкой на фиг. 12. Таким образом, очередь 402 может использоваться для управления количеством уведомлений, которые должны быть использованы для отображения как часть представления приложения, а также порядком, в котором отображаются уведомления.
[0056] Как отмечалось ранее, хотя эта функциональность описана как реализованная на клиенте, эта функциональность также может быть реализована с помощью различных других объектов, таких как модуль 124 уведомлений веб-службы 102, распределенных между модулями 114, 124 уведомлений, и так далее. Кроме того, эта функциональность может быть реализована модулем 114 уведомлений без выполнения представляемого приложения 110, тем самым сохраняя ресурсы обработки и батареи питания.
[0057] Фиг. 7 изображает процедуру 700 в иллюстративной реализации, в которой состояние выполнения приложения используется в качестве основы для определения того, какие уведомления должны быть отображены как часть представления приложения. Определяется состояние выполнения приложения, которое выполняется на клиентском устройстве (этап 702). Например, модуль 114 уведомлений может контролировать приложение 110, которое сконфигурировано для воспроизведения контента, например для приложения проигрывания музыки. Модуль 114 уведомлений может затем определить, что приложение 110 выполняется, чтобы воспроизводить конкретный элемент контента, например конкретную песню.
[0058] Выбирается уведомление для отображения как часть представления приложения в пользовательском интерфейсе клиентского устройства (блок 704). Уведомление отображается как часть представления приложения в пользовательском интерфейсе (блок 706). Продолжая предыдущий пример, модуль 114 уведомлений может определить название конкретного элемента контента, который выполняется. Это название затем может отображаться как часть представления приложения, например как представление приложения, которые можно выбрать, чтобы запустить приложение.
[0059] Например, пользователь может выбрать список исполняемых произведений в приложении воспроизведения музыки клиентского устройства 104 и затем перейти из приложения, чтобы найти другие приложения, представляющие интерес. Приложение воспроизведения музыки может продолжать воспроизводить контент, например определенную песню, когда пользователь выполняет этот поиск. Чтобы обеспечить контекст для пользователя о состоянии приложения, уведомление может описывать это состояние выполнения, которое в данном случае может включать в себя воспроизводимый контент, например название, исполнитель, альбом и так далее. Также может использоваться множество других примеров, которые связаны с отображением уведомлений в течение представления приложений, которые описывают состояние выполнения приложения, и представление может выбираться для вывода пользовательского интерфейса этого приложения, например окна, которое включает в себя пользовательский интерфейс, переносимый «на передний план», так что пользователь может взаимодействовать с приложением.
[0060] Фиг. 8 изображает процедуру 800 в примере реализации, в которой уведомления отображаются в представлениях приложений, которые могут быть выбраны, чтобы запустить приложение, причем отображение циклируется, чтобы последовательно отображать уведомления. Принимается множество уведомлений, которые должны отображаться как часть представления приложения в пользовательском интерфейсе (блок 802). Как и прежде, уведомление может приниматься в модуле 114 уведомлений клиентского устройства 104 из приложения, выполняемого на клиентском устройстве 104, из веб-службы и так далее. В другом примере модуль 124 уведомлений веб-службы 102 может принимать уведомление из другой веб-службы и управлять хранением и распределением уведомления на клиентское устройство 104. Также возможно множество других примеров.
[0061] Отображение циклируется по множеству уведомлений как часть представления приложения в пользовательском интерфейсе, так что уведомления отображаются в последовательности (блок 804). Как описано выше со ссылкой на фиг. 2, например изображение 118 может отображаться, чтобы включать в себя уведомления, которые последовательно циклируются, одно за другим, для отображения разнообразной информации.
[0062] Таким образом, уведомления могут расширить объем информации, который может быть отображен без навигации "внутри" выполнения приложения. Как описано выше, это также может выполняться модулем 114 уведомлений без запуска приложения 110, тем самым сохраняя ресурсы батареи питания и/или обработки клиентского устройства 104, серверов веб-службы 102, вычислительных устройств третьих сторон и т.д.
[0063] В одной или более реализаций циклирование отображения множества уведомлений как части представления приложения в пользовательском интерфейсе приостанавливается в ответ на обнаружение ввода, который указывает взаимодействие с представлением приложения (блок 806), например, с самим приложением и/или другими приложениями, которые отображаются "вблизи". Например, отображение уведомлений может быть сконфигурировано для автоматического циклирования модулем 114 уведомлений без вмешательства пользователя.
[0064] Однако если обнаружен ввод, что предполагает вероятность взаимодействия с представлением, такой как жест, выбор с использованием устройства управления курсором и так далее, циклирование может быть приостановлено. Также возможны различные другие реализации, например циклирование в ответ на обнаружение ввода (например, "зависание" курсора, жест и так далее), который указывает вероятное желание вызвать циклирование, которое может затем приостанавливается, когда обнаружено прекращение ввода. В другом примере обнаружение ввода (например, жест) может быть использовано для отображения каждого из уведомлений одновременно в пользовательском интерфейсе.
[0065] Фиг. 9 изображает процедуру 900 в иллюстративной реализации, в которой подмножества уведомления циклируются для отображения как часть соответствующих представлений приложений. Принимается множество уведомлений, которые должны отображаться как часть соответствующих представлений из множества приложений в пользовательском интерфейсе (блок 902). Как и прежде, этот прием может быть выполнен различными объектами, и уведомления могут приниматься из различных источников, например приниматься модулем 114 уведомлений клиентского устройства 104.
[0066] Множеств