CONTENT OPTIMIZATIONS FOR A LOCK SCREEN

Information

  • Patent Application
  • 20170277361
  • Publication Number
    20170277361
  • Date Filed
    June 22, 2016
    8 years ago
  • Date Published
    September 28, 2017
    7 years ago
Abstract
Approaches are described for determining, updating, and displaying recommended content on a lock screen of a computing device. For example, a lock screen can include recommended content that can display user-specific offers and/or other information determined to be relevant to the user. One of a full-screen template, a banner template, or a notification template can include the recommended content. The recommended content can include selectable elements that, when selected, can cause the computing device to perform an action such as launching an application, providing additional displays, etc. The recommended content can be updated. For example, in response to a lock screen event, such as powering on and off the display screen, recommended content can be updated and provided for display the next time the display screen is powered on.
Description
BACKGROUND

Mobile electronic devices, such as smart phones, tablet computers, and wearable computing devices (e.g., watches, glasses, among others) are becoming more ubiquitous. People are increasingly using their mobile devices to obtain the information for going about their everyday lives. As people spend a greater amount of their time on these devices, it can be helpful to people if their devices offered suggestions of media content or physical items that might be of interest. Discussed herein are technical solutions to provide improved systems for displaying suggestions to people.





BRIEF DESCRIPTION OF THE DRAWINGS

Various embodiments in accordance with the present disclosure will be described with reference to the drawings, in which:



FIGS. 1A and 1B illustrate an example implementation where a user is interacting with a lock screen of a computing device in accordance with various embodiments;



FIGS. 2A, 2B, and 2C illustrate example templates to display recommended content that can be displayed on a lock screen of a computing device in accordance with various embodiments;



FIGS. 3A, 3B, and 3C illustrate example systems for displaying recommended content on a lock screen of a computing device in accordance with various embodiments;



FIGS. 4A, 4B, 4C illustrate an example process for displaying and updating recommended content on a lock screen of a computing device in accordance with various embodiments;



FIG. 5 illustrates an example portable computing device that can be used in accordance with various embodiments;



FIG. 6 illustrates an example set of basic components of a portable computing device, such as the device described with respect to FIG. 5; and



FIG. 7 illustrates an example of an environment for implementing aspects in accordance with various embodiments.





DETAILED DESCRIPTION

Systems and methods in accordance with various embodiments of the present disclosure may overcome one or more of the foregoing or other deficiencies experienced in conventional approaches for presenting content data, such as recommended content, via an electronic device. In particular, various embodiments provide for determining, displaying, and updating content data anywhere messages and/or notifications may be presented to a user on a computing device. This can include displaying content data on a lock screen of a computing device, on a background image of a home screen of a computing device, as in-app content, in a notification area of a computing device, among other such areas messages and/or notifications may be presented. For example, a lock screen can include content data that can include advertisements and/or other such information. The content data can be displayed in one of a number of templates (e.g., a full-screen template or a non-full-screen template). Each type of template can include selectable elements (e.g., at least a portion of the template relative to what is displayed on the screen) that, when selected, can cause the computing device to perform an action such as launch an application, provide additional content displays, etc. The content data can be updated. For example, in response to a lock screen event, such as powering off the display screen, the content data can be updated and provided for display the next time the display screen is powered on.


In various embodiments, display instructions, content data, and/or templates to display the content data can be associated with a content provider and stored on a computing device. An example of content data includes recommend content. The recommended content can be tailored to a user of the computing device. For example, as will be described further herein, the recommended content inserted into the templates can be based on the geographic location of the computing device, usage data as relating to social media applications associated with the user of the computing device, web applications, and various other applications, search queries, purchase history, among other types of information. The display instructions can be executed by the computing device to determine a display schedule, whereby the display schedule can be used to determine whether to update the recommended content, to set a frequency at which the recommended content is displayed, a time at which the recommended content is displayed, the type of template used to express the recommended content, placement of the recommended content on a display screen, among other such display options.


The recommended content can be updated in response to detecting a lock screen event. Lock screen events include, for example, swiping away a lock screen where no security pin is required to access a home screen or other user interface of the computing device, changing a user's enrollment status in receiving recommended content from a content provider, updating a user profile with a content provider, swiping away a lock screen where a security pin is required to access a home screen or other user interface of the computing device, dismissing a security lock guard (e.g., pin entry, biometric entry, etc.) and returning to a lock screen, displaying a notification pane, launching or dismissing a camera application over a lock screen, dismissing a non-full-screen template that includes recommended content, displaying a notification overflow window, dismissing a notification overflow window, receiving a notification when a full-screen template that includes recommended content is being displayed, dismissing all notifications displayed on top of a full-screen template that includes recommended content, launching a dialer application over the lock screen, dismissing a dialer application from the lock screen, launching a voice assist application over the lock screen, dismissing a voice assist from the lock screen, powering on a display screen, powering off a display screen, activating a security key guard, activating a phone dialer application, detecting a reboot intent of the computing device, determining, while a display screen of a computing device is in a powered off state, that the computing device transitions from a state where no notifications are visible to where at least one notification would be visible or the computing device transitions from a state where notifications are visible to a state where no notifications are visible, among other such examples.


The lock screen events can be generated in response to, for example, detecting a user interaction with a display screen of the computing device, detecting a physical button of a computing device being pressed a predetermined number of times, detecting a graphical button of a computing device being contacted a predetermined number of times, detecting a time out event, detecting particular movement of the computing device, receiving an input from a different computing device (e.g., a smart watch), receiving input from an object (e.g., a cover of the computing device with a magnet that causes the display screen to power on/off), etc.


In accordance with various embodiments, as the user interacts with the recommended content (e.g., selects the recommended content) and/or computing device, a user profile that includes usage information can be created and/or updated, and the user profile can be used to update the display schedule such that recommended content is provided in accordance with the updated display schedule. In response to a selection of the recommended content, the computing device can perform at least one action, such as launching a web browser to view a product listing of an item or service represented in the recommended content, navigating to a particular web site, launching an application, or performing some other action.


Various other functions and advantages are described and suggested below as may be provided in accordance with the various embodiments.



FIG. 1A illustrates an example implementation 100 where a user 102 is interacting with a computing device 104, in accordance with various embodiments. Although a portable computing device (e.g., an electronic book reader, smart phone, or table computer) is shown, it should be understood that any electronic device capable of receiving, determining, and/or processing input can be used in accordance with various embodiments discussed herein, where the devices can include, for example, desktop computers, notebook computers, personal data assistants, video gaming consoles, television set top boxes, smart televisions, wearable computers (e.g., watches, glasses, etc.) and portable players, among others. In this example, the computing device can have executing thereon a content rendering service that can determine, display, and update content data on a lock screen of a touch-sensitive computing device 104. An example of content data includes recommend content, which can include, for example, rich media content, advertisements, graphics, text, selectable elements, etc. It should be noted, however, that embodiments described herein provide for determining, displaying, and updating recommended content anywhere messages and/or notifications may be presented to a user on a computing device. This can include displaying recommended content on a background of a home screen of a computing device, as in-app content, in a notification area of a computing device, among other such areas messages and/or notifications may be presented. The a home screen of a computing device can include, for example, the visual interface from which a user is able to access particular functions. Home screens are not identical as users can arrange interface elements (e.g., icons representing applications) as desired, and home screens can differ across operating systems. The home screen can display links or other selectable elements to applications, settings, and notifications. In accordance with various embodiments, a home screen can include, for example, a grid of application links or shortcuts that can be arranged over multiple pages, and serve as a method of accessing functions of the computing device. A home screen can include a background image. The background image can be a digital image (photo, drawing etc.) used as a decorative background of a graphical user interface on the home screen of the computing device. Displaying recommended content as in-app content can include, for example, displaying recommended content within an application, such as banners at the top, bottom, or other location in the application. The notification area of a computing device can display, for example, system and application notifications, as well as user selectable elements to access system settings and applications. It should be noted that notification areas are not identical and can differ across operating systems. The notification area can be displayed, for example, by dragging down from a top of a display screen of a computing device, selecting a button (physical or graphical), etc. Notifications may be selected, which can redirect the user to the application where the notification was initially created, and marking that alert as read. Once a notification is read, it is removed from the notification area. Users may also remove notifications without reading them by deleting individual notifications.


In accordance with various embodiments, a lock screen is a type of graphical user interface (GUI) that is displayed on a touch-sensitive display screen when the display screen is “locked,” or programmed to restrict access to aspects of the computing device. For example, the lock screen can regulate immediate access to the computing device by requiring a certain action in order to receive access: such as entering a password as part of authenticating a security key guard, using a certain button combination as part of authenticating a security key guard, or by performing a certain gesture using a device's touchscreen as part of authenticating a security key guard. Functionality of the computing device and private data is limited to pre-configured access settings that are determined either by default or when the computing device is unlocked.


The lock screen can be displayed upon detecting an input that “wakes” the display screen. An example input can include pressing a physical button such as a home button (see 134 of FIG. 1B), a voice input, movement of the computing device, an input from a different computing device (e.g., a smart watch), an input with an object (e.g., a magnet of a cover used to cover the computing device), etc. Example physical buttons include a home button (see reference 134 of FIG. 1B and 534 of FIG. 5), a power button (see reference 501 of FIG. 5), a volume button (see reference 503 of FIG. 5), etc. In accordance with an embodiment, a home button can be a physical button that when pressed can cause a display screen of a computing device to power on, close an active application, navigate to a home screen, or perform any one of a number of functions based on a number of times the home button is pressed, how long the home button is held after being pressed, etc. In accordance with an embodiment, the power button can be a physical button that when pressed can sleep/wake a computing device, power on/off a computing device, or perform any one of a number of functions based on a number of times the power button is pressed, how long the power button is held after being pressed, etc. In accordance with an embodiment, the volume button can be a physical button that when pressed can control a volume of a computing device or perform any one of a number of functions based on a number of times the volume button is pressed, how long the button is held after being pressed, etc. In various embodiments, the buttons (e.g., the home button, the power button, and the volume button) can be pressed in one or more combinations and/or sequences to perform any one of a number of functions based on a number of times each button is pressed, how long each button is held after being pressed, etc. It should be noted that in various embodiments, the buttons can be graphical buttons or a combination of physical buttons and graphical buttons.


In accordance with certain embodiments, once the lock screen is displayed, the lock screen can be unlocked to enable certain computing device settings and other computing device functionality. In various embodiments, however, the lock screen does not have to be unlocked to utilize computing device functionality. For example, pressing a physical button a predetermined number of times may launch a camera application that can be used to capture image data (e.g., a still image, video, etc.) In another example, pressing a physical button can wake a display screen of a computing device and the user can perform a gesture (e.g., swipe) to launch or display graphical elements that when selected can launch one of a number of applications executing on the computing device. In the situation where the computing device is unlocked to access private data and/or additional functionality, the unlock process can include, for example, verifying the user's identification with a passcode as part of authenticating a security key guard, using facial identification approaches to verify the user's identity as part of authenticating a security key guard, using fingerprint recognition approaches to verify the user's identity as part of authenticating a security key guard, using voice identification approaches to verify the user's identity as part of authenticating a security key guard, etc.


Example 120 of FIG. 1B illustrates an example lock screen in accordance with various embodiments. The lock screen can be displayed in response to detecting a wake event to power on the display screen. The lock screen can display, for example, the time and date 122, notifications for various applications executing on the computing device such as missed text notifications 124, missed call notifications 126, calendar event notifications 128, etc.; a background image (i.e., wallpaper); interactive elements 130 that can include a call icon to launch a phone application, an unlock icon to launch a security key guard, a camera icon to launch a camera application, status elements that indicate a Wi-Fi connection, telecomm connection, battery level, etc., among other types of information. In accordance with various embodiments, the lock screen can additionally be utilized to display recommended content in templates. The recommended content can be displayed instead of (or addition to) the background image of the lock screen. The recommended content can include, for example, text, images, audio, animation, video, interactive content, rich media content, advertisements, and other content a user or other object can interact with. Content can be, for example, information provided through text, images, audio, animation, video, interactive content, rich media content, etc. The content can be recommended content because, for example, the content is personalized based on user information associated with a user as may include a user's demographic information, such as gender, age, marital status, occupation, income level, etc., information indicating usage patterns of a computing device, information indicating applications executing on the computing device, a physical location of the computing device, a network provider (Wi-Fi and/or telecom) of the computing device, etc. The recommended content can include a hypertext link or other selectable element that can enable the computing device to launch a web browser, navigate to a particular web site, launch an application, or perform some other function. The web site can be a product page that displays information associated with the recommended content as well as provide the ability to purchase an item represented on the product page.


As will be described further herein, the recommended content can be determined, displayed, and updated in accordance with display instructions. As described herein, the display instructions can be periodically and automatically updated. For example, a service (e.g., an update service) can provide updated display instructions as such instructions become available, at determined times, or as otherwise appropriate. In accordance with various embodiments, the display instructions can be used to cause the computing device to determine, display, and update the recommended content at specific times, under specific conditions, and/or in response to a particular lock screen event. For example, the computing device can determine that a current time of day is within a determined time segment specified by a display schedule of the display instructions and can enable recommended content to be displayed. In other examples, the computing device can determine, display, and/or update recommended content in response to a lock screen event. Example lock screen events include swiping away a lock screen where no security pin is required to access a home screen or other user interface of the computing device, changing a user's enrollment status in receiving recommended content from a content provider, updating a user profile with a content provider, swiping away a lock screen where a security pin is required to access a home screen or other user interface of the computing device, dismissing a security lock guard (e.g., pin entry, biometric entry, etc.) and returning to a lock screen, displaying a notification pane, launching or dismissing a camera application over a lock screen, dismissing a non-full-screen template that includes recommended content, displaying a notification overflow window, dismissing a notification overflow window, receiving a notification when a full-screen template that includes recommended content is being displayed, dismissing all notifications displayed on top of a full-screen template that includes recommended content, launching a dialer application over the lock screen, dismissing a dialer application from the lock screen, launching a voice assist application over the lock screen, dismissing a voice assist from the lock screen, powering on a display screen, powering off a display screen, activating a security key guard, activating a phone dialer application, detecting a reboot intent of the computing device, determining, while a display screen of a computing device is in a powered off state, that the computing device transitions from a state where no notifications are visible to where at least one notification would be visible or the computing device transitions from a state where notifications are visible to a state where no notifications are visible, among other such examples.


Example situations where recommended content is determined, displayed, and/or updated can occur when returning from an application launched over the lock screen, where in this situation any recommended content displayed in a full-screen template is cleared and any recommended content displayed in a non-full-screen template remains displayed. In another situation where the computing device is returning from a camera application that was launched by pressing a power button (or other such button) a predetermined number of times, the recommended content displayed in a full-screen template can be updated and any recommended content displayed in a non-full-screen template can remain unchanged. In yet another situation where a security key guard or other such security interface that requires an input to access a home screen of the computing device is dismissed, recommended content can be cleared. In another situation where a computing device shut down process is initiated, recommended content can be cleared. In yet another situation, recommended content displayed in a full-screen template can be cleared when an application is launched over the lock screen. In another situation, recommended content displayed in a non-full-screen template can cleared when that recommended content is cleared via a swiping gesture. It should be noted that other lock screen events can cause a computing device to determine, display, and/or update recommended content as will be obvious to one of ordinary skill in the art.


As described, the computing device can cause the recommended content to be displayed on the lock screen in one or more of a number of different visual representations. FIG. 2A illustrates an example 200 of a full-screen template that includes content data that can be displayed on a lock screen of a computing device 104. As described, an example of content data includes recommend content. In this example, the background image portion 204 of the lock screen has been replaced with full-screen template 206 that includes recommend content, which in this example includes a display of a shoe, text, and an interactive element 208. The background image portion 204 can be a digital image (photo, drawing etc.) used as a decorative background of a graphical user interface on the lock screen of the computing device 104 or other electronic device. It should be noted that although most devices come with a default background, users or other processes can change the background. As described, the recommended content can be inserted in one of a number of templates (e.g., full-screen template, notification template, or banner template) and the recommended content can be displayed on the lock screen of the computing device. A template can be used to provide a standard layout and look and feel within content regions of the lock screen or other display areas. The layout can include regions or areas, and content can be inserted into those regions. Inserting content can include referencing particular content to be displayed in the regions of the template.


The interactive element 208, when selected, can cause the computing device to perform one of a number of actions. Example actions include launching an application such as a web browser to view a webpage, a marketplace application to download an application, among others. In this example, the interactive element can cause a mobile shopping app to launch, wherein a product page for the shoe as well as any additional or related information can be displayed. In the situation where the user has a passcode or other security measure securing the computing device, the user would first have to provide the necessary passcode before viewing the product page. On the product page, the user can purchase the product, search additional products, or resume operation of the computing device. It should be noted that although the recommended content in the full-screen template is shown in this example, it will be appreciated that the visual representation of the recommended content is not limited to the full-screen template. For example, the recommended content can be displayed in a non-full-screen template which includes but is not limited to a banner template, a notification template, or any other template that utilizes substantially less than all of the pixels of the display screen when rendered. In various embodiments, the display screen can include other displays coupled and/or otherwise in communication with the computing device. For example, the displays can include a secondary screen such as an e-ink screen, LCD screen, LED screen, etc. Additionally or alternatively, the display can be a display screen of a device in communication with the computing device such as a smart watch, smart glasses, mobile phone, automobile display, television, electronic book reader, portable media player, among others. As will be appreciated by one of ordinary skill in the art, a product or other content to be represented in recommended content can be a tangible item, a virtual item, a service, or a combination thereof.



FIG. 2B illustrates example 220 of notification template 222 that includes recommended content that can be displayed on a lock screen of the computing device. In this example, the notification template is intended to match a style of the notifications used by the computing device. As shown, the recommended content is displayed with a text message 222 and appears as though it could be another text message displayed along with the text message. Although the recommended contented is displayed with a text message notification, notification template 224 can be the only notification displayed, or displayed with one or more other notifications, as may include missed call notifications, missed text message notifications, calendar event notifications, etc. Notification template 224 includes recommended content which may include a graphical representation of an advertisement, a description associated with the advertisement, and any other appropriate information such as a label distinguishing the provided advertisement from other device generated notifications. In this example, recommended content in the notification template includes an image of a shoe with information indicating that the product is on sale. A user can interact with the recommended content. For example, the user can tap, select, swipe, or otherwise interact with the recommended content in a same or similar manner as with other notifications. Selecting the recommended content can cause the computing device to display additional information, launch an application, or perform some other action.


In another example, a banner template 242 can include recommended content as shown in example 240 of FIG. 2C. Although the recommended content displayed in a banner template is displayed with a text message 220, the recommended content can be displayed with any number of types of notifications. Further, like the recommended content displayed in a notification template, the recommended content can be displayed after all other notifications, before all other notifications, or somewhere mixed in with any other notifications. The visual representation of banner template 242 generally utilizes a larger area of the lock screen and is emphasized with respect to other displayed notifications. For example, the banner template 242 can appear on the lock screen in the form of a bar, column, or box and may utilize, for example, up to twice the viewable area of a notification generated by the operating system. As shown, the recommended content in the banner template includes information such as an image of an advertisement (e.g., shoes), a description associated with the advertisement (e.g., price and advertising phrase), and any other appropriate information. The size and appearance (e.g., banner style, bold lines, etc.) can visually distinguish the banner template from other notifications. As with the other templates, a user can interact with the recommended content in the banner template. For example, the user can tap, select, or swipe the recommended content in the banner template, wherein such interaction can cause the computing device to display additional information, launch an application, or some other action.


The template used to display the recommended can be based on the presence of any notifications on the lock screen. For example, in the situation where at least one notification is being displayed on the lock screen, the recommended content can be generated in one of a banner template or a notification template. In the situation where no or zero notifications are being displayed on the lock screen, the recommended content can be generated in a full-screen template. In the situation where there are a few notifications being displayed (e.g., three or less), the recommended content can be generated in a banner template. In the situation where three or more notifications are being displayed on the lock screen, the recommended content can be generated in a notification template. In the situation where ten or more notifications are being displayed, no recommendations may be displayed. It should be noted that other events can trigger the use of one visualization style over another visualization style. It should further be noted that these events may also be used to determine whether recommended content should be displayed.


For example, many operating systems include predefined notification categories to specify the type of notification object being displayed. Example notification categories include alarms and timers, calendar events, incoming direct messages (SMS, instant message, etc.) In accordance with various embodiments, the notification categories can be leveraged to determine a time to display the recommended content. For example, it may not be desirable to display recommended content when a user is responding to a calendar event, as the user has a specific intent in mind. Instead, the recommended content might be displayed some amount of time after the calendar event. As an example, if the time between when a notification is detected and when a user waking the display screen is less than, for example, fifteen seconds, then recommended content is not displayed.


In another example, operating systems may assign a notification priority to a notification. These priorities can influence ‘how’ and ‘when’ notifications should be displayed on a display screen. For example, a priority of “MAX” may be used for a critical or time-sensitive notification. In this example, if the time between a notification being displayed with a “MAX” priority and the user waking the display screen is less than, for example, fifteen seconds, then recommended content is not displayed. In yet another example, the total number of notifications displayed on a lock screen can be used to determine whether to display recommended content. For example, in the situation where, for example, ten or more notifications are present on the lock screen when the display screen is turned on, then recommended content may not be displayed at that time.


In accordance with various embodiments, the advertisements, content, or other information inserted into the template can be tailored for a user of the computing device. This can include tailoring the frequency at which recommended content is displayed (i.e., the rate at which content is displayed or otherwise provided) on the lock screen, the placement of the recommended content on the lock screen, when the recommended content is displayed on the lock screen, and/or the visualization of the recommended content. For example, the time of day to which the recommended content is displayed on the lock screen can be selected to minimize distraction and increase viewership of the recommended content. For example, in the situation where a user utilizes the computing device for a brief period of time in the morning, and more so in the evening, it might be beneficial to increase the display of recommended content on the lock screen at a time the computing device is most likely to be used and/or checked (i.e., in the evening). Providing recommended content during a time the user is infrequently unlocking the computing device or otherwise is attempting to briefly use the device can be distracting and may lead to an unsatisfactory experience.


In various embodiments, the recommended content inserted into the templates can be tailored based on user information as may include the user's demographic information, such as gender, age, marital status, occupation, income level, etc., information indicating usage patterns of the computing device, information indicating applications on the computing device, a physical location of the computing device, a network provider (Wi-Fi and/or telecom) of the computing device, etc. For example, the name of the carrier network used by the computing device can be determined and recommended content can determined based on the carrier network name can be inserted in the template. For example, if the user's carrier is identified, content can be included in the template for a competing carrier. In another example, the computing devices Wi-Fi and/or GPS setting can be determined to tailor content included in the template based on the computing devices physical location. For example, in the situation where the Wi-Fi network is identified with a particular restaurant, recommended content for that restaurant can be inserted into a template and displayed on the lock screen of the computing device. In yet another example, application activity on the computing device can be monitored, where the activity can include notifications, the time of those notifications, etc. The activity can be used to determine a time to display recommended content. For example, the fact that a user is accessing social media websites and/or applications, might indicate that a user of the computing device available to receive content, which can then be displayed on the lock screen of the computing device.


In accordance with various embodiments, other factors can cause the frequency, placement, and/or appearance of advertisements to be adjusted or otherwise modified. For example, if a complaint or other indication is received that indicates that the user is not satisfied with the frequency, placement, and/or appearance of the advertisements, the frequency, placement, and/or appearance at which the advertisements are displayed to the user can be decreased or otherwise modified. In this way, feedback received from the user can be used to adjust the rate at which and/or the placement of the displayed advertisements. Additionally, how often a user clicks, selects and/or otherwise interacts with an advertisement (such as the user's clickthrough rate), and/or any other number of customer behaviors can be used to adjust the advertising frequency (and/or placement and appearance of the advertisements). For example, advertisement frequency can be decreased, and/or placement and/or appearance of advertisements made less intrusive if a user selects or otherwise interacts with the displayed advertisements to increase a clickthrough rate.



FIG. 3A illustrates an example configuration of a system 300 for determining, displaying, and updating content data in accordance with various embodiments. As described, an example of content data includes recommend content. In this example, a client computing device 302 (e.g., similar to computing device 104 in FIG. 1A) is able to receive recommended content across at least one network 304 from an appropriate content provider environment 306. The client computing device 302 can generally include a content manager 332, a content renderer 354, a content display service 350, a content refresh service 352, user data store 334, log data store 336, and client content data store 338. In certain embodiments, the client can include a security component to detect and combat programmatic circumvention of determining, displaying, and updating the recommended content. For example, the security component listens to various system events and infers circumvention based on the sequence of received events. A countermeasure phases includes two stages: a preventive stage and a reactive stage. The preventive stage can be triggered when the screen is in a powered off state (i.e., not displaying content). The reactive stage can be triggered when the display screen is displaying content, and when the preventative state is detected when the screen is off. In the preventative stage, when the display screen is not displaying content, the security component triggers a method call (e.g., PhoneStatusBar.showKeyguard( )) to show the security key guard. This allows recommended content to show up on top of third party lock screens executing software to stop the client computing device from entering a sleep or lower power mode. In the reactive state, if circumvention is detected, the security component triggers a method call (e.g., PhoneStatusBar.showKeyguard( )) to show the security keyguard when the display screen has a display. This is used to prevent third party lock screens that use certain methods calls that can alter flags indicating when the lock screen is locked, dismissed, etc.


The client content data store 338 can store a local copy of the recommended content, display instructions for displaying the recommended content, as well as other information. As described, the display instructions can be provided by a content provider environment 306 or other such environment and can be used to determine a display schedule by which to display and update the recommended content on the client computing device's lock screen. For example, the display instructions can instruct the client computing device to listen for any notifications to be displayed on the lock screen or other events, and based on the presence on any notifications, the time of day, user information, lock screen events, and any other appropriate information, the client device 302 can determine a template to display the recommended content on the lock screen and/or whether to update the recommended content to be inserted in the template. As described herein, the display instructions can be periodically and automatically updated. For example, the content provider environment can include a service (e.g., an update service) operable to generate updates to the display instructions and can propagated the updates to the client computing device 302, where when installed, can be used to determine a template to display the recommended content, display and/or update the recommended content, or perform some other function described herein.


The recommended content can include, for example, rich media content, advertisements, graphics, text, selectable elements, etc. The recommended content can be personalized based on user information associated with a user of the client computing device and can be formatted for optimal display on the client computing device, taking into consideration various specifications of the client computing device (e.g., screen size, screen resolution, etc.) The recommended content can be provided by a content provider of the content provider environment. In accordance with various embodiments, the recommended content can be provided to the content provider environment from a third party content provider 324 or other such entity.


The user data store 334 can include usage information pertaining to the client computing device 302 as may include application usage, client computing device settings (e.g., cellular network provider, etc.), as well as user information (e.g., user preferences, unlock log, etc.). The at least one network 304 can include any appropriate network, such as may include the Internet, an Intranet, a local area network (LAN), a cellular network, and the like.


The content manager 332 can be used for rendering and updating recommended content. For example, the content manager 332 can receive a refresh notification or other such event/instruction from the content refresh service 352. The refresh notification can be generated in response to detecting a particular lock screen event. In response to receiving the refresh notification, the content manager can cause the content renderer 354 to initiate a content rendering process to generate recommended content to be displayed using content display service 350. In accordance with various embodiments, whether a refresh notification is generated can be based on the occurrence of one or more lock screen events. As described, example lock screen events include swiping away a lock screen where no security pin is required to access a home screen or other user interface of the client computing device, changing a user's enrollment status in receiving recommended content from a content provider, updating a user profile with a content provider, swiping away a lock screen where a security pin is required to access a home screen or other user interface of the client computing device, dismissing a security lock guard (e.g., pin entry, biometric entry, etc.) and returning to a lock screen, displaying a notification pane, launching or dismissing a camera application over a lock screen, dismissing a non-full-screen template that includes recommended content, displaying a notification overflow window, dismissing a notification overflow window, receiving a notification when a full-screen template that includes recommended content is being displayed, dismissing all notifications displayed on top of a full-screen template that includes recommended content, launching a dialer application over the lock screen, dismissing a dialer application from the lock screen, launching a voice assist application over the lock screen, dismissing a voice assist from the lock screen, powering on a display screen, powering off a display screen, activating a security key guard, activating a phone dialer application, detecting a reboot intent of the client computing device, determining, while a display screen of a client computing device is in a powered off state (i.e., the display screen is not displaying content), that the client computing device transitions from a state where no notifications are visible to where at least one notification would be visible or the client computing device transitions from a state where notifications are visible to a state where no notifications are visible, among other such examples. The lock screen events can be generated in response to, for example, a user interaction with a display screen of the client computing device, pressing a physical button on a client computing device a predetermined number of times, contacting a graphical button on a client computing device a predetermined number of times, detecting a time out event, detecting predetermined movement of a client computing device, receiving an input from a different client computing device (e.g., a smart watch), receiving input from an object (e.g., a cover of a client computing device with a magnet that causes the display screen to power on/off), etc.


The content refresh service 352 can monitor for lock screen events and in the situation where a particular one of the lock screen events is detected, content refresh service 352 can notify the content manager 332 to initiate content selection, rendering, and display logic. For example, in the situation where the content refresh service 352 detects a power button (or other such button) being pressed to cause a display screen of the client computing device to enter a powered off state (i.e., the display screen is not displaying content), the content refresh service 352 can notify the content manager 332 of the lock screen event. The content manager 332 can notify the content renderer 354, which can initiate content selection logic to determine recommended content to be displayed by the content display service 350.


In another example, in the situation where the content refresh service 352 detects the power button (or other such button) being pressed a predetermined number of times to activate an application (e.g., a camera application, a voice assistant application, etc.), the content refresh service 352 can notify the content manager 332 of the lock screen event. The content manager 332 can notify the content renderer 354, which can initiate content selection logic to determine recommended content to be displayed by the content display service 350. The content renderer 354 can execute content selection logic for recommended content to be displayed in a full-screen template (recommended content for non-full-screen templates remain unchanged). As such, recommended content to be displayed in a full-screen template is cleared while recommended content to be displayed in a non-full-screen template remains the same. The cleared recommended content can be temporarily stored or otherwise persisted to cache or another memory component such as client content data store 338. The content renderer 354 can then initiate content render logic. In the situation where the render logic does not complete before the display screen is in a powered on state, the content display service 350 retrieves the cached recommended content and displays the cached recommended content by inserting the cached recommended content in the full-screen template. In the situation where the content render logic completes before the display screen is in a powered on state, the content display service 350 displays updated recommended content by inserting the updated recommended content in the full-screen template.


In yet another example, in the situation where the content refresh service 352 detects a reboot of the client computing device, the content refresh service 352 can notify the content manager 332 of the reboot (i.e., the lock screen event.) The content manager 332 can notify the content renderer 354, which can initiate content selection logic to determine recommended content to display and can cache the determined recommended content for use when the client computing device reboots. During a boot process, when it is determined that at least a predetermined portion of components of the client computing device are executing, the appropriate software is loaded, and that the display screen is in a powered off state (i.e., the display screen is not displaying content), the content renderer 354 can cause the content display service 350 to display the recommended content on the lock screen when the display screen is in a powered on state.


In yet another example, in the situation where the content refresh service 352 detects that the display screen is in a powered off state and the client computing device transitions from a lock screen state where no notifications are visible to a lock screen state where at least one notification would be visible, or the display screen is in a powered off state and the client computing device transitions from a state where at least one notification would be visible to a state where no notifications would be visible, the content refresh service 352 can notify the content manager 332 of the lock screen event. The content manager 332 can notify the content renderer 354, which can initiate content selection logic to determine recommended content to be displayed by the content display service 350. For example, in the situation where the client computing device transitions from a state where at least one notification would be visible to a state where no notifications will be visible, content selection for recommended content to be displayed in a full-screen template is initiated. In this example, the content renderer 354 can initiate selection and render logic. In the situation where the render logic does not complete before the display screen is in a powered on state, the content display service 350 retrieves previously cached recommended content used in a full-screen template and displays the cached recommended content on the lock screen in the full-screen template. In the situation where the render logic completes before the display screen is in a powered on state, the content display service 350 enables for display updated recommended content. In the situation where the client computing device transitions from a lock screen state where zero notifications will be visible to a state where at least one notification is to be visible, content selection for recommended content to be displayed in a non-full-screen template is initiated. For example, the content renderer 354 initiates content selection and render logic. In the situation where the render logic does not complete before the display screen is in a powered on state, the content display service 350 attempts to render the recommended content in a non-full-screen template while the display screen is in the powered on state.


In accordance with various embodiments, other lock screen events can be determined and based on these determined lock screen events a determination can be made whether to update and/or display recommended content. For example, when returning from an application launched over the lock screen, the client computing device can delete recommended content displayed in a full-screen template and continue to display recommended content displayed in a non-full-screen template. In another example, when a security key guard or other such security interface requiring an input to access the home screen of the client computing device is dismissed, recommended content is deleted. In another example, when the display screen is caused to be in a powered off state, content selection logic, content rendering logic, and content display logic can be executed and updated recommended content can be provided for display the next time the display screen is powered on. In various embodiments, powering off the display screen and/or computing device triggers the content selection logic and content rendering logic.


In accordance with certain embodiments, recommended content may not be updated when the display screen is in a powered on state. This can include situations where the lock screen is visible and/or the user is in a full-screen application and a notification is received. In this example, any recommended content currently being displayed may not be updated at that time. Rather, content selection and rendering logic can be executed when the display screen is in a powered off state. As described above, a possible exception to this situation is where a home button or other such button is pressed a predetermined number of times. In this example, recommended content in a full-screen template is updated.


In accordance with various embodiments, as relating to retrieving recommended content and/or display instructions, a request can be received to a network interface layer 308 of the content provider environment 306 for the recommended content and/or the display instructions. The network interface layer can include any appropriate components known or used to receive requests from across a network, such as may include one or more application programming interfaces (APIs) or other such interfaces for receiving such requests. The network interface layer 308 might be owned and operated by the provider, or leveraged by the provider as part of a shared resource or “cloud” offering. The network interface layer can receive and analyze the request from the client computing device 302, and cause at least a portion of the information in the request to be directed to an appropriate system or service, such as a server 310 (e.g., a Web server or application server), among other such options. At least one server 310 might be used to generate the display instructions and send the recommended content for rendering on the lock screen. To generate the display instructions and the recommended content, the servers or other components of the environment might access one or more data stores, such as a user data store 318 that contains information about the various users, and one or more server content data stores 320 storing recommended content able to be served to those users. The user data store 318 can include, for example, purchase history; customer behavior such as application or service usage; user responsiveness to advertisements such as clickthrough rate; social media information; service and/or displayed advertisements; and/or any other information that can be used to indicate user preference to a type of advertisement and/or recommended content.


A content request service 312 can be configured to provide information to include in the recommended content, and can include certain parameters regarding presenting recommended content. For instance, the content request service 312 can specify rules that affect a frequency at which the recommended content is displayed, the types of notifications the recommended content is displayed with, lock screen events that trigger an update of recommended content, etc. Once the appropriate components of the content provider environment 306 have determined the appropriate information, a response can be returned to the client computing device 302 over the network. This can include any recommended content and the display instructions for determining, rendering, and updating the recommended content.


In various embodiments, the third party content provider 324 can be, a social media network, news network, an ad network (e.g., a company that connects advertisers to publishers, such as websites or application developers, that host ads), an ad mediator (e.g., an ad tracking platform that enables the allocation of advertising inventory across multiple ad networks), an ad exchange (e.g., a technology platform that facilitates automated auction-based pricing and buying in real-time between advertiser demand and publisher ad supply), or the like. The third party content provider 324 can include or at least be in communication with an advertising manager, the content request service, or other appropriate service, which can include any combination of devices and/or processes operable to encompass, monitor, and/or control a number of different algorithms and components for selecting recommended content. In accordance with an embodiment, the recommended content can be provided to the content provider environment from the third party content provider 324, and the content provider environment can provide the recommended content to the client computing device. For example, the content renderer, or other component on the client computing device 302 can submit a request for recommended content. The request can be received by the content provider and the content provider can submit a request for the appropriate content to the third party content provider. The request from the content provider to the third party content provider can include any appropriate information for determining, recommended content. For example, the information can include usage profile and user information (such as demographic information), log information for a frequency of displayed recommended content, the placement of displayed recommended content, and/or the appearance of displayed recommended content, among other information.


In accordance with an embodiment, when the recommended content is loaded on the lock screen, the display instructions executing on the client computing device 302 can analyze the properties of the recommended content displayed to determine whether the user has viewed or otherwise interacted with the recommended content. The user interaction with the recommended content (e.g., selecting the recommended content), the downloaded advertisements, the advertisements view, the template used to display the recommended content (e.g., full screen template, notification template, and banner template), and other information can be stored in log data store 336. The information can be provided to the content provider environment, third party content provider, a logging service, or some other entity.


For example, the client computing device 302 can then cause at least one call or request to be submitted to a least one logging service 314, within or outside the provider environment 306, where the call or request can include information about the visibility of the advertising, interaction metrics (e.g., a time of day, template to display the recommended content, etc.), among other such options. The information can then be stored to log database 315 or similar location for subsequent analysis. In some cases, the information in the log database 315 will periodically be pulled and transformed to a format that can be stored to a table in the user data store 318, or other data repository or log data store 322, for reporting or statistical analysis with other data, enabling various types of reporting and analysis to be performed across various types of data.



FIG. 3B illustrates an example system 359 for obtaining recommended content for use in accordance with various embodiments. In this example, a content refresh service 352 operating on a client computing device (e.g., client computing device 302) detects an event to retrieve display instructions and recommended content to be displayed on the client computing device. Instructions to update recommended content can be received at the content refresh service in response to, for example, the client computing device connecting to the internet, after a predetermined period of time elapses from a previous time display instructions and/or recommended content is retrieved, after a predetermined event occurs (e.g., the client computing device is powered on), or some other event. The display instructions can include a manifest or other information specifying recommended content to retrieve, display instructions, and any other information used to determine, display, and/or update the recommended content stored on the client computing device. Once the instruction to “update recommend content” is received at the content refresh service 352, the content refresh service 352 can instruct the content manager 332 to “update display instructions.” This can include, for example, the content manager communicating a request to “retrieve display instructions” to the content provider 306, where the content provider can provide the display instructions to the content manager 332 over at least one network. Additionally or alternatively, the content manager 332 can communicate with the content provider 306 to request information associated for the display of recommended content from previous display instructions as well as any other information. Once the content manager 332 receives the display instructions, the content manager 332 can use the retrieved display instructions to update or replace previous display instructions stored in client content data store 338. This can include, for example, deleting recommended content and/or other data from client content data store 338 specified in the display instructions. Once the recommended content and other data is removed from the client content data store 338, the content manager 332 can request recommended content specified in the display instructions that is not stored in the client content data store 338 from server content data store 320. As described, server content data store 320 is associated with content provider 306. Thereafter, content manager 332 can update client content data store 338 with the recommended content obtained from server content data store 320.



FIG. 3C illustrates an example system 369 to provide for display recommended content in accordance with various embodiments. A lock screen event is detected. In this example, the lock screen event corresponds to a display screen of the client computing device transitioning to a powered off state. The lock screen event is detected by the content display service 350. For example, in accordance with various embodiments, the content display service can monitor for particular lock screen events and an indication of the occurrence of the lock screen event can be communicated to the content display service 350. The content display service 350 sends a request to “get recommended content” to the content manager 332. The content manager 332 can obtain or otherwise access display instructions from client content data store 338. Once the display instructions are obtained and/or otherwise accessed, the content manager 332 can initiate content selection logic 355. The content selection logic can select the appropriate recommended content. As described, the content selection logic can be a java script file or other software that can be used to select recommended content in accordance with the various embodiments described herein. In this example, the content selection logic 355 can select the recommended content and can instruct content manager 332 to retrieve the selected recommended content from client content data store 338. The retrieved recommended content can be provided to content display service 350. This can include providing instructions to content display service 350 on which recommended content to display and under what conditions respective recommended content is to be displayed. Thereafter, the content display service 350 can enable the recommended content for display. For example, the content display service can instruct an interface 370 (e.g., a security interface or other such interface) to display the recommended content in one of a full-screen template or a non-full-screen template on a lock screen in response to a lock screen event, such as powering on the display screen. The content display service can enable action links 372 or other user-selectable elements associated with the recommended content. The action links, when selected, can cause the computing device to perform an action such as launch an application, provide additional content displays, provide information associated with the recommended content, etc.



FIG. 4A illustrates an example process 400 for displaying content data on a lock screen of a computing device in accordance with various embodiments. It should be understood that, for any process described herein, that there can be additional or fewer steps performed in similar or alternative orders, or in parallel, within the scope of the various embodiments unless otherwise stated. In this example, a component operating on a computing device or other software code or application, can be used to determine content data that includes advertisements, user selectable elements, display information, and/or other content to display with a lock screen of a computing device. As described, an example of content data includes recommend content, which can be provided by a content provider or other such entity. In this example, the content provider is associated with a cloud-based recommendation service that generates recommended content based at least in part on a customer profile associated with the computing device. The customer profile can be associated with at least one of customer preferences, customer purchase history, customer search history, customer media consumption history, geographic location of the computing device, customer physical activity data, limited time discounts provided by the first content provider, customer wish list with the first content provider.


In this example, recommended content is received 402 for display on a lock screen of a computing device. The recommended content can include, for example, rich media content, advertisements, and other content a user or other object can interact with. The recommended content as well as any advertisements and/or other information (e.g., advertisement images, advertisement description, etc.) can be stored on the computing device. Display instructions can be received 404. The display instructions can be used by the computing device to determine a template to display the recommended content and a display schedule by which the recommended content is to be displayed. For example, the display instructions can be used to cause the computing device to display recommended content at specific times, under specific conditions, and/or in response to particular event (e.g., lock screen events). As described herein, a content provider or other entity can provide such recommended content, advertisement and/or other information, display instructions to the computing device.


The display screen of the computing device is determined at 406 to be in a powered off state. In a powered off state, the lock screen cannot be accessed until the display screen is powered on. As described, a lock screen is a type of graphical user interface (GUI) that is displayed on a display screen when the display screen is “locked,” or programmed not to respond to most touches on the display screen. The lock screen can be displayed upon detecting an input that “wakes” the display screen. An example input can be a selection of a physical button, a voice input, movement of the computing device, system notifications being displayed by the computing device, etc. Upon waking the device, the display screen is powered on and the lock screen is displayed. The presence of a notification to be displayed on the lock screen is determined 408. While the display screen is off, the determination can be repeated at a predetermined interval and for each interval the presence of a notification to be displayed can be determined. For example, in certain situations, a notification might be displayed on the display screen for a first interval but for a second interval (or some other interval) the notification might have been cleared by the computing device. In this example, for the first interval, the recommended content can be generated in a full-screen template. However, once the notification was cleared and now that there are no notifications to be displayed on the lock screen, the recommended content can be generated in one of a banner template or a notification template on the lock screen. Example notifications include missed text message notifications, missed call notifications, calendar event notifications, operating system notifications, network notifications, among others. In the situation where zero notifications are determined to be displayed on the lock screen, the recommended content can be generated 410 by inserting the recommended content into a full-screen template for display on the lock screen. In response to detecting 412 a wake event that causes the display screen to power on, the recommended content is displayed 414 in the full-screen template on the lock screen. In the situation where at least one notification is determined to be displayed on the lock screen, then the recommended content is generated 416 in a non-full-screen template (e.g., one of a banner template or a notification template) by inserting the recommended content into the non-full-screen template. Whether the banner template or the notification template is used can be based on, for example, the number of notifications to be displayed on the display screen. For example, in the situation where there are a few notifications being displayed (e.g., three or less), the recommended content can be generated in a banner template. In the situation where three or more notifications are being displayed on the lock screen, the recommended content can be generated in a notification template. In the situation where ten or more notifications are being displayed, no recommendations may be displayed. Other factors can include the time of day, the number of lock screens per day, computing device usage information, etc. In response to detecting 418 a wake event that causes the display screen to power on, the recommended content is displayed 420 in one of the non-full-screen template (e.g., the banner template or the notification template.) As described, a user can interact with the recommended content. For example, the user can tap, select, swipe, or otherwise interact with the recommended content in a same or similar manner as with other notifications. Selecting the recommended notification can cause the computing device to display additional information, launch an application, or some other action associated with the recommended content.



FIG. 4B illustrates an example process 430 for updating recommended content on the lock screen of the computing device in accordance with various embodiments. In this example, the component operating on the computing device or other software code or application, can be used to update recommended content (e.g., advertisements, user selectable elements, display information, etc.) for display in response to a lock screen event. As described in FIG. 4A, recommended content for display on the lock screen of the computing device is received 402. Display instructions and other information can also be received 404. As described, the display instructions can be used to determine a template (e.g., full-screen template or non-full-screen template) to display the recommended content and a display schedule by which the recommended content is to be displayed and updated. For example, display instructions can be used to cause the computing device to display and/or update the recommended content at specific times, under specific conditions, and/or in response to a specific event. In this example, the display screen of the computing device is determined 406 to be in a powered off state. Once the display screen is determined to be in a powered off state, the presence of a notification to be displayed on the lock screen is determined 408. In the situation where zero notifications are determined to be displayed on the lock screen, first lock screen content can be generated 432 by inserting first recommended content into a full-screen template for display on the lock screen. A lock screen event can be detected. In this example, detecting the lock screen event corresponds to detecting 434 a camera activation event that activates a camera application in response to a power button (or other such button) being pressed a predetermined number of times. Once the camera application is active, second lock screen content can be generated 436 by inserting second recommended content into the full-screen template, where the second recommended content can be different from the first recommended content. In response to detecting 438 an event that exits the camera application and displays the lock screen, the second recommended content can be displayed 440 in the full-screen template on the lock screen. For example, an input such as pressing a home button or other such button can exit the camera application and display the lock screen. In the situation where at least one notification is determined to be displayed on the lock screen, lock screen content can be generated 442 by inserting the first recommended content in a non-full-screen template (e.g., one of a banner template or a notification template). A camera activation event can be detected 444 by detecting a power button (or other such button) being pressed the predetermined number of times. In response to detecting 446 an event that exits the camera application and displays the lock screen, the lock screen content can be displayed 448 by inserting the first recommended content in the non-full-screen template (e.g., the banner template or the notification template.)



FIG. 4C illustrates an example process 450 for updating recommended content on the lock screen of the computing device in accordance with various embodiments. As described, the component operating on the computing device or other software code or application, can be used to update recommended content that includes advertisements, user selectable elements, and/or other content to display on the lock screen of the computing device. As described in FIGS. 4A and 4B, recommended content is obtained 402 for display on the lock screen of the computing device. Display instructions and other information can also be received 404. In this example, the display screen of the computing device is determined 406 to be in a powered off state. Once the display screen is determined to be in a powered off state, first lock screen content can be generated 452 for display on the lock screen by inserting first recommended content into a full-screen template. A lock screen event can be detected. In this example, detecting the lock screen event corresponds to detecting 454 a camera activation event that activates a camera application in response to a power button (or other such button) being pressed a predetermined number of times. Once the camera application is active, second lock screen content can be generated 456 for display on the lock screen by inserting second recommended content into the full-screen template. The first lock screen content can be persisted 458 to a client content data store (e.g., client content data store 338). An event that exits the camera application and displays the lock screen can be detected 460. In response to displaying the lock screen, a determination 461 can be made whether the second recommended content has completed rendering in the full-screen template. In the situation where the second recommended content has not completed rendering in the full-screen template, the first lock screen content is retrieved 462 from the client data store and displayed 464 in the full-screen template on the lock screen. In the situation where the second recommended content has completed rendering in the full-screen template, the second lock screen content can be displayed 466 in the full-screen template on the lock screen.



FIG. 5 illustrates an example computing device 500 (e.g., similar to computing device 104 and client computing device 302) that can be used in accordance with various embodiments. Although a portable computing device (e.g., a smart phone, an electronic book reader, or tablet computer) is shown, it should be understood that any device capable of receiving and processing input can be used in accordance with various embodiments discussed herein. The devices can include, for example, desktop computers, notebook computers, electronic book readers, personal data assistants, cellular phones, video gaming consoles or controllers, wearable computers (e.g., smart watches or glasses), automobile displays, televisions and/or devices that connect to them (e.g., set top boxes), and portable media players, among others. In this example, the computing device 500 has a display screen 504 and an outer casing 502. The display screen under normal operation will display information to a user (or viewer) facing the display screen (e.g., on the same side of the computing device as the display screen). For example, the display screen can display a lock screen in response to pressing a power button 501, a home button 534, a volume button 503, or in response to another input. In accordance with various embodiments, the home button 534 can be a physical button that when pressed can cause the display screen 504 of computing device 500 to power on, close an active application, navigate to a home screen, or perform any one of a number of functions based on a number of times the button is pressed, how long the button is held after being pressed, etc. The power button 501 can be a physical button that when pressed can sleep/wake the computing device 500, power on/off the computing device 500, or perform any one of a number of functions based on a number of times the button is pressed, how long the button is held after being pressed, etc. The volume button 503 can be a physical button that when pressed can control a volume of the computing device 500, or perform any one of a number of functions based on a number of times the button is pressed, how long the button is held after being pressed, etc. As discussed herein, the device can include one or more communication components 506, such as may include a cellular communications subsystem, Wi-Fi communications subsystem, BLUETOOTH communication subsystem, near field communication (NFC) subsystem, and the like. FIG. 6 illustrates a set of basic components of a computing device 600 such as the device 502 described with respect to FIG. 5, device 104 described with respect to FIG. 1, and/or device 302 described with respect to FIG. 3. In this example, the device includes at least one processor 602 for executing instructions that can be stored in a memory device or element 604. As would be apparent to one of ordinary skill in the art, the device can include many types of memory, data storage or computer-readable media, such as a first data storage for program instructions for execution by the at least one processor 602, the same or separate storage (e.g., client data store 338) can be used for display instructions, recommended content, images or data, a removable memory can be available for sharing information with other devices, and any number of communication approaches can be available for sharing with other devices. The devices can include a number of sensors, as may include a proximity sensor operable to detect the presence of nearby object without any physical contact, an ambient light sensor for ambient light sensing, a digital compass, among other such sensors. The device typically will include at least one type of display element 606, such as a touch screen, electronic ink (e-ink), organic light emitting diode (OLED) or liquid crystal display (LCD), although devices such as portable media players might convey information via other means, such as through audio speakers. The device can include at least one communication component 608, as may enabled wired and/or wireless communication of voice and/or data signals, for example, over a network such as the Internet, a cellular network, a Wi-Fi network, BLUETOOTH, and the like. The device can include at least one additional input device 610 able to receive conventional input from a user. This conventional input can include, for example, magnetic input from a case, input from a different computing device (e.g., a smart watch), a push button, touch pad, touch screen, wheel, joystick, keyboard, mouse, trackball, camera, microphone, keypad or any other such device or element whereby a user can input a command to the device. These I/O devices could even be connected by a wireless infrared or Bluetooth or other link as well in some embodiments. In some embodiments, however, such a device might not include any buttons at all and might be controlled only through a combination of visual and audio commands such that a user can control the device without having to be in contact with the device.


As discussed, different approaches can be implemented in various environments in accordance with the described embodiments. For example, FIG. 7 illustrates an example of an environment 700 for implementing aspects in accordance with various embodiments. As will be appreciated, although a Web-based environment is used for purposes of explanation, different environments may be used, as appropriate, to implement various embodiments. The system includes an electronic client devices 702 (e.g., similar to computing device 104 in FIG. 1A), which can include any appropriate device operable to send and receive requests, messages or information over an appropriate network 704 (e.g., similar to network 304 of FIG. 3) and convey information back to a user of the device. Examples of such client devices include personal computers, cell phones, handheld messaging devices, laptop computers, set-top boxes, personal data assistants, electronic book readers and the like. The network can include any appropriate network, including an intranet, the Internet, a cellular network, a local area network or any other such network or combination thereof. Components used for such a system can depend at least in part upon the type of network and/or environment selected. Protocols and components for communicating via such a network are well known and will not be discussed herein in detail. Communication over the network can be enabled via wired or wireless connections and combinations thereof. In this example, the network includes the Internet, as the environment includes a Web server 706 for receiving requests and serving content in response thereto, although for other networks, an alternative device serving a similar purpose could be used, as would be apparent to one of ordinary skill in the art.


The illustrative environment includes at least one application server 708 and a data store 710 (data store 710 can include, e.g., user data 318, server content 320, log 322, as well as other data.) It should be understood that there can be several application servers, layers or other elements, processes or components, which may be chained or otherwise configured, which can interact to perform tasks such as obtaining data from an appropriate data store. It should be further understood that functions of Web server 706 and application server 708 (similar to server(s) 310 of FIG. 3A) can be performed by the same computing device, distributed across multiple computing devices, or any other such arrangement. As used herein, the term “data store” refers to any device or combination of devices capable of storing, accessing and retrieving data, which may include any combination and number of data servers, databases, data storage devices and data storage media, in any standard, distributed or clustered environment. The application server 708 can include any appropriate hardware and software for integrating with the data store 710 as needed to execute aspects of one or more applications for the client device and handling a majority of the data access and business logic for an application. The application server provides access control services in cooperation with the data store and is able to generate content such as text, graphics, audio and/or video to be transferred to the user, which may be served to the user by the Web server 706 in the form of HTML, XML or another appropriate structured language in this example. The handling of all requests and responses, as well as the delivery of content between the client device 702 and the application server 708, can be handled by the Web server 706. It should be understood that the Web and application servers are not required and are merely example components, as structured code discussed herein can be executed on any appropriate device or host machine as discussed elsewhere herein.


The data store 710 can include several separate data tables, databases or other data storage mechanisms and media for storing data relating to a particular aspect. For example, the data store illustrated includes mechanisms for storing content (e.g., production data) 712 and user information 716 (e.g., similar to user data 318 of FIG. 3A) which can be used to serve content for the production side. The data store is also shown to include a mechanism for storing log or session data 714 (e.g., similar to log 322 of FIG. 3A.) It should be understood that there can be many other aspects that may need to be stored in the data store, such as page image information and access rights information, server content information (e.g., similar to server content 320 of FIG. 3A) which can be stored in any of the above listed mechanisms as appropriate or in additional mechanisms in the data store 710. The data store 710 is operable, through logic associated therewith, to receive instructions from the application server 708 and obtain, update or otherwise process data in response thereto.


Each server typically will include an operating system that provides executable program instructions for the general administration and operation of that server and typically will include computer-readable medium storing instructions that, when executed by a processor of the server, allow the server to perform its intended functions. Suitable implementations for the operating system and general functionality of the servers are known or commercially available and are readily implemented by persons having ordinary skill in the art, particularly in light of the disclosure herein.


The environment in one embodiment is a distributed computing environment utilizing several computer systems and components that are interconnected via communication links, using one or more computer networks or direct connections. The environment can be similar to the environment described with respect to reference 300 of FIG. 3A. In this example, content provider environment 306 can include at least Web server 706, application server 708, and data store 710. However, it will be appreciated by those of ordinary skill in the art that such a system could operate equally well in a system having fewer or a greater number of components than are illustrated in FIG. 7. Thus, the depiction of the system 700 in FIG. 7 should be taken as being illustrative in nature and not limiting to the scope of the disclosure.


The various embodiments can be further implemented in a wide variety of operating environments, which in some cases can include one or more user computers or computing devices which can be used to operate any of a number of applications. User or client devices can include any of a number of general purpose personal computers, such as desktop or laptop computers running a standard operating system, as well as cellular, wireless and handheld devices running mobile software and capable of supporting a number of networking and messaging protocols. Such a system can also include a number of workstations running any of a variety of commercially-available operating systems and other known applications for purposes such as development and database management. These devices can also include other electronic devices, such as dummy terminals, thin-clients, gaming systems and other devices capable of communicating via a network.


Most embodiments utilize at least one network that would be familiar to those skilled in the art for supporting communications using any of a variety of commercially-available protocols, such as TCP/IP, FTP, UPnP, NFS, and CIFS. The network can be, for example, a local area network, a wide-area network, a virtual private network, the Internet, an intranet, an extranet, a public switched telephone network, an infrared network, a wireless network and any combination thereof.


In embodiments utilizing a Web server, the Web server can run any of a variety of server or mid-tier applications, including HTTP servers, FTP servers, CGI servers, data servers, Java servers and business application servers. The server(s) may also be capable of executing programs or scripts in response requests from user devices, such as by executing one or more Web applications that may be implemented as one or more scripts or programs written in any programming language, such as Java, C, C# or C++ or any scripting language, such as Perl, Python or TCL, as well as combinations thereof. The server(s) may also include database servers, including without limitation those commercially available from Oracle, Microsoft, Sybase and IBM.


The environment can include a variety of data stores and other memory and storage media as discussed above. These can reside in a variety of locations, such as on a storage medium local to (and/or resident in) one or more of the computers or remote from any or all of the computers across the network. In a particular set of embodiments, the information may reside in a storage-area network (SAN) familiar to those skilled in the art. Similarly, any necessary files for performing the functions attributed to the computers, servers or other network devices may be stored locally and/or remotely, as appropriate. Where a system includes computerized devices, each such device can include hardware elements that may be electrically coupled via a bus, the elements including, for example, at least one central processing unit (CPU), at least one input device (e.g., a mouse, keyboard, controller, touch-sensitive display element or keypad) and at least one output device (e.g., a display device, printer or speaker). Such a system may also include one or more storage devices, such as disk drives, optical storage devices and solid-state storage devices such as random access memory (RAM) or read-only memory (ROM), as well as removable media devices, memory cards, flash cards, etc.


Such devices can also include a computer-readable storage media reader, a communications device (e.g., a modem, a network card (wireless or wired), an infrared communication device) and working memory as described above. The computer-readable storage media reader can be connected with, or configured to receive, a computer-readable storage medium representing remote, local, fixed and/or removable storage devices as well as storage media for temporarily and/or more permanently containing, storing, transmitting and retrieving computer-readable information. The system and various devices also typically will include a number of software applications, modules, services or other elements located within at least one working memory device, including an operating system and application programs such as a client application or Web browser. It should be appreciated that alternate embodiments may have numerous variations from that described above. For example, customized hardware might also be used and/or particular elements might be implemented in hardware, software (including portable software, such as applets) or both. Further, connection to other computing devices such as network input/output devices may be employed.


Storage media and other non-transitory computer readable media for containing code, or portions of code, can include any appropriate media known or used in the art, such as but not limited to volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data, including RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disk (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices or any other medium which can be used to store the desired information and which can be accessed by a system device. Based on the disclosure and teachings provided herein, a person of ordinary skill in the art will appreciate other ways and/or methods to implement the various embodiments.


The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. It will, however, be evident that various modifications and changes may be made thereunto without departing from the broader spirit and scope of the invention as set forth in the claims.

Claims
  • 1. A computer implemented method, the method comprising: receiving recommended content for display on a display screen of a computing device that is locked, the recommended content associated with a content provider;receiving display instructions used to manage display of the recommended content in one of a full-screen template or a non-full-screen template;generating first lock screen content by inserting first recommended content into the full-screen template;receiving a selection of a physical button of the computing device a number of times;causing a camera application to launch;generating second lock screen content by inserting second recommended content in the full-screen template, the first recommended content being different from the second recommended content;persisting the first lock screen content to a data store;detecting an event that exists the camera application and causes the display screen to present a display; anddisplaying the second lock screen content in the full-screen template.
  • 2. The computer implemented method of claim 1, further comprising: determining that the display screen is locked;generating third lock screen content by inserting third recommended content into the full-screen template, the third recommended content being different from the first recommended content and the second recommended content;detecting a wake event that causes the display screen to present the display; anddisplaying the third lock screen content.
  • 3. The computer implemented method of claim 1, further comprising: determining that the display screen is locked;generating third lock screen content by inserting third recommended content into the full-screen template, the third recommended content being different from the first recommended content and the second recommended content;receiving a notification that includes non-recommended content to be displayed while the computing device is locked;generating fourth lock screen content by inserting fourth recommended content in a non-full-screen template, the fourth recommended content being different from the first recommended content, the second recommended content, and the third recommended content;deleting the third lock screen content;detecting a wake event that causes the display screen to present the display;displaying the fourth lock screen content; anddisplaying the notification while displaying the fourth lock screen content.
  • 4. The computer implemented method of claim 1, further comprising: determining that the display screen is locked;determining a notification that includes non-recommended content to be displayed while the computing device is locked;generating third lock screen content by inserting additional recommended content into a non-full-screen template;receiving the selection of the physical button of the computing device the number of times;causing the camera application to launch;displaying a user interface associated with the camera application; anddeleting the third lock screen content.
  • 5. A computer implemented method, comprising: receiving content data for display on a display screen of a computing device that is locked, the content data associated with an entity;determining a template to present the content data based at least in part on a number of notifications associated with other entities to be displayed on the display screen while the computing device is locked;determining a lock screen event that at least causes the display screen to present a display; andenabling lock screen content for display based at least in part on the template and the lock screen event.
  • 6. The computer implemented method of claim 5, further comprising: determining that the number of notifications is below a first threshold;generating the lock screen content by inserting the content data in a full-screen template;receiving a selection of a physical button of the computing device a number of times;causing an application to launch;display a user interface associated with the application;initiating a content rendering process to generate updated lock screen content based at least in part on the full-screen template, the updated lock screen content being different from the lock screen content; andpersisting the lock screen content in a data store.
  • 7. The computer implemented method of claim 6, further comprising: detecting an event that exits the application; anddisplaying the updated lock screen content.
  • 8. The computer implemented method of claim 6, further comprising: detecting an event that exits the application and causes the display screen to present the display;determining that the content rendering process did not complete;retrieving the lock screen content from the data store; anddisplaying the lock screen content.
  • 9. The computer implemented method of claim 5, further comprising: determining that the number of notifications is below a threshold;generating the lock screen content by inserting the content data in a full-screen template;receiving an interaction with the computing device to cause a full-screen application to launch; anddeleting the lock screen content.
  • 10. The computer implemented method of claim 5, further includes: determining that the number of notifications meets a threshold;generating the lock screen content by inserting the content data in a non-full-screen template;detecting a first interaction with the computing device to cause a full-screen application to launch;persisting the lock screen content in a data store;detecting a second interaction with the computing device to cause the display screen to present the display;retrieving the lock screen content from the data store; anddisplaying the lock screen content.
  • 11. The computer implemented method of claim 5, further includes: detecting a reboot event, the reboot event indicating that the computing device is to reboot;initiating a content selection process to select updated content data to be displayed; andpersisting the updated content data in a data store.
  • 12. The computer implemented method of claim 11, further includes: detecting a boot event;retrieving the updated content data from the data store while the computing device is locked;determining that the number of notifications is below a first threshold;generating the lock screen content by inserting the updated content data in a full-screen template;detecting the lock screen event that causes the display screen to present the display; anddisplaying the lock screen content.
  • 13. The computer implemented method of claim 5, further includes: determining that the number of notifications is below a first threshold;generating the lock screen content by inserting the content data in a full-screen template;detecting the lock screen event that causes the display screen to present the display, the display including a security interface to prevent access to functionality of the computing device;receiving authentication credentials to the security interface to authenticate the security interface; anddeleting the lock screen content.
  • 14. The computer implemented method of claim 5, further comprising: determining that the number of notifications is below a threshold;generating first lock screen content by inserting the content data in a full-screen template;receiving a notification that includes non-content data to be displayed on the display screen while the computing device is locked;deleting the first lock screen content;determining updated content data; andgenerating second lock screen content by inserting the updated content data in a non-full-screen template.
  • 15. The computer implemented method of claim 5, further includes: determining that the number of notifications meets a threshold;generating first lock screen content by inserting the content data in a non-full-screen template;determining that the number of notifications is below the threshold;deleting the first lock screen content;determining updated content data; andgenerating second lock screen content by inserting the updated content data in a full-screen template.
  • 16. The computer implemented method of claim 5, wherein the entity is associated with a cloud-based recommendation service that generates content data based at least in part on a customer profile associated with the computing device, the customer profile associated with at least one of customer preferences, customer purchase history, customer search history, customer media consumption history, geographic location of the computing device, customer physical activity data, limited time discounts provided by the entity, customer wish list with the entity, and wherein the other entities are associated with non-content data that includes at least one of calendar events, missed call alerts, missed text message alerts, or system alerts.
  • 17. A computing system, comprising: at least one processor; andmemory including instructions that, when executed by the processor, enable the computing system to: receive content data for display on a display screen of a computing device that is locked, the content data associated with an entity;determine a template to present the content data based at least in part on a number of notifications associated with other entities to be displayed on the display screen while the computing device is locked;determine a lock screen event that at least causes the display screen to present a display; andenable lock screen content for display based at least in part on the template and the lock screen event.
  • 18. The computing system of claim 17, wherein the instructions, when executed further enable the computing system to: determine that the number of notifications is below a first threshold;generate the lock screen content by inserting the content data in a full-screen template;receive a selection of a physical button of the computing device a number of times;cause an application to launch;initiate a content rendering process to generate updated lock screen content by inserting updated content data into the full-screen template, the content data being different from the updated content data; andpersist the lock screen content in a data store.
  • 19. The computing system of claim 18, wherein the application includes one of a camera application, a dialer application, a voice assistant application, or a phone dialer application.
  • 20. The computing system of claim 18, wherein the instructions, when executed further enable the computing system to: determine that the number of notifications is below a threshold;generate the lock screen content by inserting the content data in a full-screen template;receive an interaction with the computing device to cause a full-screen application to launch; anddelete the lock screen content.
Provisional Applications (1)
Number Date Country
62313614 Mar 2016 US