A system enables universal remote media control across multiple platforms, devices, and users. A protocol allows a cast controller to have access to media operations and a state(s) associated with media content. The system receives commands from a cast controller, provides the commands to a media player, loads new media content into the media player, based on the commands, and receives state notifications from the media player. Another cast controller can receive the state notifications from the media player and control the media player based on the media operations and state(s) associated with media content.
|
6. A system for providing remote media control, the system comprising:
a cast receiver included in a media player device that:
receives, from a first cast controller included in a first device, instructions to process a content item at the cast receiver, the content item being initiated by the first device including the first cast controller;
receives a command message to adjust a volume of the content item from a second cast controller included in a second device, wherein the cast receiver is configured to receive command messages from the first cast controller and the second cast controller;
changes the volume of the content item by the cast receiver upon receiving the command message from the second cast controller; and
sends a state notification to the first cast controller and the second cast controller upon changing the volume of the content item by the cast receiver, wherein: the state notification includes a volume status; and
the state notification triggers the first cast controller, the second cast controller, or both to update information presented.
11. A non-transitory computer-readable medium containing computer executable instructions that, when executed by a processor, cause the processor to perform a method for providing remote media control, the method comprising:
receiving, at a cast receiver included in a media player device from a first cast controller included in a first device, instructions to process a content item at the cast receiver, the content item being initiated by the first device including the first cast controller;
receiving a command message to adjust a volume of the content item from a second cast controller included in a second device, wherein the cast receiver is configured to receive command messages from the first cast controller and the second cast controller;
changing the volume of the content item by the cast receiver upon receiving the command message from the second cast controller; and
sending a state notification to the first cast controller, the second cast controller, or both upon changing the volume of the content item by the cast receiver, wherein: the state notification includes a volume status; and
the state notification triggers the first cast controller, the second cast controller, or both to update information presented.
1. A method for providing remote media control, the method comprising:
receiving, at a cast receiver included in a media player device from a first cast controller included in a first device, instructions to process a content item at the cast receiver, the content item being initiated by the first device including the first cast controller;
receiving, at the cast receiver included in the media player device, a command message from a second cast controller included in a second device, a command message to adjust a volume of the content item, wherein the cast receiver is configured to receive command messages from the first cast controller and the second cast controller;
changing the volume of the content item by the cast receiver included in the media player device upon receiving the command message from the second cast controller; and
sending, from the cast receiver included in the media player device, a state notification to the first cast controller and the second cast controller upon changing the volume of the content item by the cast receiver, wherein: the state notification is information related to the content item that includes a volume status of the content item; and
the state notification triggers the first cast controller and the second cast controller to update volume information presented.
4. The method of
5. The method of
7. The system of
9. The system of
10. The system of
12. The non-transitory computer-readable medium of
the method further comprises changing a playback position of the content item.
13. The non-transitory computer-readable medium of
the method further comprises pausing playback of the content item.
14. The non-transitory computer-readable medium of
15. The non-transitory computer-readable medium of
|
This application is a continuation of U.S. patent application Ser. No. 16/798,991, filed Feb. 24, 2021, which is a continuation of U.S. patent application Ser. No. 16/041,022, filed Jul. 20, 2018, which is a continuation of U.S. patent application Ser. No. 14/272,300, filed May 7, 2014, which claims the benefit of U.S. Patent Application No. 61/823,016, filed May 14, 2013, each of which is incorporated by reference herein in its entirety.
This disclosure generally relates to interactions between a first device such as a media player, and a controller device, and more particularly, to remote media control in a multi-user, multi-platform, multi-device environment.
Applications may display a user interface to allow a user to control and interact with a television screen when in the vicinity. Yet, establishing pairing between the two devices uses a registration process that requires the user to explicitly grant access to the control from the device, or add hardware extensions to the device to force the pairing over certain channels, requiring a one time pairing action. These techniques often require the user to be aware of the pairing and require coupling hardware that may not be inherent to either the television or the device. Additionally, distance and different forms of interference restrict performance, and the device interface may be tied to only one television.
According to one general aspect, a method for providing remote media control includes receiving at a media controller device from a media player, a set of available media operations for processing content. The method includes providing a user interface via a browser application or a mobile application on the media controller device, generating command messages from the media controller device using the user interface, the command messages based on the set of available media operations, providing the command messages to the media player, receiving state notifications from the media player, and sending additional command messages from the media controller device in response to the state notifications.
Implementations may include one or more of the following features, alone or in combination with each other. The method may include receiving the state notifications at a second media controller device, and sending new command messages for the media player from the second media controller device, wherein the command messages are input from the second media controller device using the user interface. The command messages may be defined based on a common protocol. The media player may be configured to output at least one specific type of content. The user interface may allow for a selection of the media player from a plurality of media players. The method may include receiving from the media player, content meta-data that defines how to represent the content. The user interface may allow for an input of another media player by a user. The command messages may be based on a set of operations supported by a particular type of the media player. The state notifications may include a volume status and a play status of the content. The command messages and the state notifications may include a namespace and a message payload represented as a two-element script array. The user interface may include options for controlling the content including stopping or pausing the content, increasing or decreasing volume of the content, seeking to a specific location within the content, navigating between items in a playback queue, changing audio tracks, or setting captions for the content.
In another general aspect, a method for employing remote media control includes receiving command messages from a media controller device via a service in a browser of a media player, rendering content in the media player, based on the command messages, while rendering the content, providing state notifications from the media player, and receiving additional command messages from the media controller device in response to the state notifications.
Implementations may include one or more of the following features, alone or in combination with each other. The command messages may be defined based on a common protocol. The method may include providing, via the media controller device, a user interface. The user interface may be independent of a platform-specific application installed on the media controller device. The user interface may allow for a selection of the media player from a plurality of media players. The method may include providing the user interface on a second media controller device. The method may include displaying options on the user interface for controlling the content.
Other implementations include corresponding systems, apparatus, and computer programs, configured to perform the actions of the methods, encoded on computer storage devices.
One or more of the implementations of the subject matter described herein may provide one or more of the following advantages. The system allows discovery and interactivity between any device (acting as a remote control) and a television device without the need for explicitly pairing the two devices, without platform-level or application-level required tools, and without being limited to a single-user or single device experience.
The details of one or more implementations are set forth in the accompanying drawings and the description below. Other features may be apparent from the description and drawings, and from the claims.
Like reference symbols in the various drawings indicate like elements.
Increasingly, users consume their content across a number of devices, such as smartphones, tablets, PCs, consoles/STBs, TVs, etc. Yet, there is a low level of integration in a user's experience across these devices. For most users, the experiences across device boundaries are entirely distinct. Certain solutions serve only the needs of a specific application. Other content providers cannot build on those types of solutions. Moreover, certain systems are platform specific. With many households having various types of devices each operating using a different platform, platform-specific solutions only allow a subset of the household to use the system. Further, those solutions are inherently single user, such that the user who initiates an action is the only one who is permitted to interact with the activity resulting from the action in a meaningful way. If someone plays content, another person may be unable to even pause that content (short of seizing the device used to initiate the interaction). Additionally, certain systems may be platform-level or application-level, with no co-operation between levels. If playback was initiated on TV by an application, the platform can offer no control or visibility into this. If one device initiates playback in an app, and runs out of battery, a user could not just pick up another device to control playback. Instead, the user would have to hope that the correct application is installed, locate the application, and load it.
Systems and methods described here enable remote media control across multiple users, platforms, and devices.
The media controller device 102A and the media controller device 102B may be a computer, a smart phone, a laptop, or a similar device that may execute a user interface, download and execute software applications, and communicate with the server 110 and the media player 130. The media controller device 102A and the media controller device 102B may include a display screen and an application such as a web browser application that may display the user interface. Various alternative and additional examples of devices that may operate as media controller devices are described in more detail below with respect to
Network 120 may be a single network or a combination of any type of computer network, such as a Local Area Network (LAN) or a Wide Area Network (WAN), a WIFI network, a BLUETOOTH network, or other network. In addition, network 120 may be a combination of public (e.g., Internet) and private networks.
Media player 130 is a computing device with an application and a display screen. As an example, media player 130 may be a television. Media player 130 may execute software applications and may communicate with the media controller device 102A, the media controller device 102B, and the server 110. Any number of alternative or additional networks, servers, services, mobile devices, or devices may be included in system 100.
The rendezvous service 242 may establish a connection between a first application, such as a web application, running on the device 102a, and a second application running on another device such as the media player 130. The second application running on the media player 130 may send a request to load a given web application for example in the content browser 240. The web application may register itself to a connection service 244 awaiting the second application's connection request. Upon the connection request, the connection service 244 sends information to create a transport connection 210 (such as a websocket connection or a custom transport implemented over TLS/TCP) between the first application and the second application. The web application and the second application open the transport connection 210 to the rendezvous service 242, which forwards data between them, using the transport connection 210. The web application and the second application send and receive media content using a protocol, using the transport connection 210.
The cast receiver script library 238 may be a script library, such as a JAVASCRIPT library or an OAuthService library, that interacts with the connection service 244. The cast receiver script library 238 creates new websocket connections to the rendezvous service 242 using a new connection request from the connection service 244. A namespace may operate as a collection of a set of identifiers. A namespace may provide a way to avoid element name conflicts. For example, when a namespace is defined for an element, all child elements with the same prefix are associated with the same namespace. The rendezvous service 242 can route traffic based on specific namespaces for handling by the cast receiver 230 itself, not by the script library 236 or the cast receiver script library 238. The cast receiver script library 238 may also combine or separate data according to namespace. If the namespace is a specific namespace, the cast receiver script library 238 may send the data to a content-specific script library such as the script library 236.
The script library 236 may be a JAVASCRIPT library that sends and receives data packets to and from media controllers via a connection provided by the underlying cast receiver script library 238. The data packets may be in compliance with a specific protocol. The data packets may include, for example, meta-data such as content meta-data that defines how to represent content visually. The script library 236 may also perform media actions according to data packets received. The script library 236 may also receive notifications from a web application and send the notification to a media controller such as the device 102. The notifications may include, for example, notifications about the visual content such as a pop-up window to display a notice for an upcoming media program. The content renderer 232 may handle media actions and encrypted media extensions.
As shown in
The media controller device may generate command messages using the common user interface (710). The process may include providing the command messages to a media player (712). In some implementations, the process may include loading media content into the media player based on the command messages (714).
The command messages are sent from the medial controller device to the media player. In some implementations, the command messages are in a JSON format. The messages generate responses from the media player, in some implementations, and responses are correlated to commands via the use of a cmd_id field. This id space may be managed by the media controller device. The media controller device may determine whether there are any duplicate outstanding cmd_id. If a command generates no responses, the cmd_id field may be set to 0.
The media controller device may receive state notifications from the media player (720). The state notifications are time-sensitive information related to the media content or related to meta-data associated with the content. The state notifications may, for example, include a current media status or media position, such as a volume status and a play status of the media content (722). In some implementations, the command messages and the state notifications include a namespace and a message payload represented as a two-element script array (724). The payload may be the actual data included in the message. When the actual data is represented as a two-element script array, it may be ordered in a particular arrangement, such as “[namespace], [message payload].” Other arrangements of the data are possible and additional data may also be included in various implementations. The media controller device may send additional command messages in response to the state notifications (730).
In some implementation media time synchronization between the media player and the media controller device may be achieved by the use of a STATUS message. When a controller receives a STATUS message with a valid current field, it adjusts the media time to match what is reported by the message. If a time_progress field in the message has the value of true, the local media time can be extrapolated using a time source on the media controller device.
Examples of command messages include casting media content (e.g., a movie) to a different available media player (e.g., a media play which may be in another room in a house), stopping or pausing the media content playing on a computer, increasing or decreasing volume of the media content, seeking to a specific location within the media, navigating between items in a playback queue, changing audio tracks, setting captions, etc. Examples of state notifications include a current media status or media position.
In some implementations, the process may include receiving the state notifications at a second media controller device, and sending new command messages for the media player from the second media controller device, wherein the command messages are input from the second media controller device using the common user interface.
In some implementations, the command messages use a common protocol. In some implementations, the common user interface allows for a selection of the media player from a plurality of media players. In some implementations, for example as shown above with respect to
In some implementations, media tracks in the current content are described using the following data structure. The data structure may include content meta-data that defines how to represent the content visually, as shown below, such as an “id”, “selected” “type” or other meta-data. The example discussed below may be implemented at least in part by, for example, the system of
An ID is unique within the scope of a single content. An ID does not change during the lifetime of a playback session.
Type: identifies the type of track. Supported types include subtitles, closed captions, audio, and video. If content contains only 1 track or types video and audio, i.e. if there are no user selections possible, then these tracks may not be returned.
Name: Human readable description of the track. This may be, for example, a description of an audio track or an alternate audio track. The name field may be the language specified in a lang field (the language of the track given in ISO-629 code).
Selected: indicates if the track is currently being used for playback by a media player device such as the media player 130 shown in
Player status is represented by the following JSON object which is used by various other messages:
The sequence number is used to identity the relative position of status events received from response to a set of available operations (LOAD, PLAY, etc.), and those received from unsolicited status updates. When a status event is received from the response of an operation, any status event received with sequence number less than that of the response can be ignored.
If player state is IDLE, then all fields except sequence and error can be ignored.
content_id: This is a service-specific identifier of content currently loaded by the media player, such as the media player 130 shown in
title: A descriptive title of the content. A media player, such as the media player 130 shown in
time_progress: Indicates whether the media time is progressing. If the value is false, the media controller device, such as the media controller device 102A, may stop extrapolating the media time. This is independent of the media player 130 state because the media time can stop in any state.
current_time: The current position of the media player 130 since the beginning of the content, in seconds. If this a live stream content, identified with null duration, then this field represent the time in seconds from the beginning of the event that can be known to the media player 130.
duration: This field represent the duration of the currently playing stream in seconds. If the stream is a live stream then this field is null.
volume: This field indicates the current volume level as a value between 0.0 and 1.0.
content_info: This field contains a service specific object which can be used to provide more in depth information about the content currently controlled by the media controller device 102A. The initial value of the field can be provided by the media controller device 102A in a LOAD message. Media players, such as the media player 130 shown in
error: The error object returns the last error encountered by the media player 130 since the last control operation. If no error has been encountered, it can be set to null.
Error Domain: Error domain to segregate errors, so that applications can return their own errors.
Error Code: error code specific to the domain
STATUS: This command requests the status of the content currently playing in the media player 130.
LOAD: This command is used to load new content into the media player 130.
The <content_id> field contains an identity of the content that needs to be loaded into the media player 130. The format of this field is defined by the application and the media player 130.
If the autoplay parameter is specified, the media player 130 may begin playing the content when it is loaded. Even if autoplay is not specified, the media player 130 implementation may choose to begin playback immediately. If playback is started, the player state in the response can be set to PLAYING, otherwise it can be set to STOPPED.
The title field optionally provides a user readable descriptive string for the content being loaded. If provided, the string may be used by the media player 130 as initial value for the title field of each STATUS object sent from the media player 130. Whether or not the title is provided in the LOAD message, the media player 130 can modify the title at any point based on logic of the media player 130.
The content_info field can contain a JSON object which give more in depth information about the content being loaded, e.g. id of a TV service, episode number etc. If provided, the content_info object may be used as the initial value of the content_info field of each STATUS message. The media player 130 is free to modify the content_info at any point.
PLAY: This begins playback of the content that was loaded with the load call or change the playback position of a currently loaded content. If the position field is not specified, then playback is continued from the current position. If position provided is outside the range of valid position of the current content, then the media player 130 may pick a valid position as closed to the requested position as possible.
The title field optionally provides a user readable descriptive string for the content being loaded. If provided, the string may be used by the media player 130 as initial value for the title field of each STATUS object sent from the media player 130. Whether or not the title is provided in the LOAD message, the media player 130 can modify the title at any point based on logic of the media player 130.
The content_info field can contain a JSON object which give more in depth information about the content being loaded, such as an ID of a TV service, episode number, or other information. If provided, the content_info object may be used as the initial value of the content_info field of each STATUS message. The media player 130 may be free to modify the content_info at any point.
PLAY: This begins playback of the content that was loaded with the load call or change the playback position of a currently loaded content. If the position field is not specified, then playback is continued from the current position. If position provided is outside the range of valid position of the current content, then the media player 130 may pick a valid position as close to the requested position as possible.
This halts playback of the current content. There is no distinction between stopping and pausing content.
Volume level can be changed even if mute is enabled. A new volume level may apply when mute is disabled.
Change in volume may trigger a STATUS event notification to all media controller devices, such as the media controller device 102A and the media controller device 102B.
SELECT_TRACKS: Selects the media tracks that the player should use.
The SELECT_TRACKS command is used to enable or disable media tracks. The tracks are identified by trackID obtained from the TRACKS data object. The media controller device 102A and the media controller device 102B checks the response from the media player 130 to determine if the requested tracks are actually enabled or disabled. In some instances, the media player 130 may be unable to enable a requested track because of local conditions, for example if the media player 130 does not support more than one audio stream at a time.
Modifying selected tracks may trigger a STATUS event notification to all media controller devices, such as the media controller device 102A and the media controller device 102B.
Player Status Events: The data of this event contains a play status event structure with the following data fields:
The media player 130 may send out a STATUS message whenever there is a state transition in the media player 130. In addition the media player 130 may send out periodic updates to synchronize states with second screen applications.
Media time may be extrapolated by the media controller device 102A from the last STATUS update based on a local clock. If the current_time reported by a STATUS message does not match what is locally extrapolated, the local media time is updated to the value in the STATUS message.
Media players, such as the media player 130 shown in
Player Key Request Events: To implement a license delegation protocol, the system may forward key requests coming from the CDM to the media controller device 102A to get a valid token. The token is returned to the media controller device 102A and may be passed when the license is requested. In alternative implementations, the system may return the license directly.
Computing device 800 includes a processor 802, memory 804, a storage device 806, a high-speed interface 808 connecting to memory 804 and high-speed expansion ports 810, and a low speed interface 812 connecting to low speed bus 814 and storage device 806. Each of the components 802, 804, 806, 808, 810, and 812, are interconnected using various busses, and may be mounted on a common motherboard or in other manners as appropriate. The processor 802 can process instructions for execution within the computing device 800, including instructions stored in the memory 804 or on the storage device 806 to display graphical information for a GUI on an external input/output device, such as display 816 coupled to high speed interface 808. In other implementations, multiple processors and/or multiple buses may be used, as appropriate, along with multiple memories and types of memory. Also, multiple computing devices may be connected, with each device providing portions of the necessary operations (e.g., as a server bank, a group of blade servers, or a multi-processor system).
The memory 804 stores information within the computing device 800. In one implementation, the memory 804 is a volatile memory unit or units. In another implementation, the memory 804 is a non-volatile memory unit or units. In some implementations, the memory includes a combination of volatile and non-volatile memory units, for example as described above with respect to
The storage device 806 is capable of providing mass storage for the computing device 800. In one implementation, the storage device 806 may be or contain a computer-readable medium, such as a floppy disk device, a hard disk device, an optical disk device, or a tape device, a flash memory or other similar solid state memory device, or an array of devices, including devices in a storage area network or other configurations. A computer program product can be tangibly embodied in an information carrier. The computer program product may also contain instructions that, when executed, perform one or more methods, such as those described above. The information carrier is a computer- or machine-readable medium, such as the memory 804, the storage device 806, or memory on processor 802.
The high speed controller 808 manages bandwidth-intensive operations for the computing device 800, while the low speed controller 812 manages lower bandwidth-intensive operations. Such allocation of functions is illustrative only. In one implementation, the high-speed controller 808 is coupled to memory 804, display 816 (e.g., through a graphics processor or accelerator), and to high-speed expansion ports 810, which may accept various expansion cards (not shown). In the implementation, low-speed controller 812 is coupled to storage device 806 and low-speed expansion bus 814. The low-speed expansion bus, which may include various communication ports (e.g., USB, BLUETOOTH, ETHERNET, wireless ETHERNET) may be coupled to one or more input/output devices, such as a keyboard, a pointing device, a scanner, or a networking device such as a switch or router, e.g., through a network adapter.
The computing device 800 may be implemented in a number of different forms, as shown in the figure. For example, it may be implemented as a standard server 820, or multiple times in a group of such servers. It may also be implemented as part of a rack server system 824. In addition, it may be implemented in a personal computer such as a laptop computer 822. Alternatively, components from computing device 800 may be combined with other components in a mobile device (not shown), such as device 850. Each of such devices may contain one or more of computing device 800, 850, and an entire system may be made up of multiple computing devices communicating with each other.
Computing device 850 includes a processor 852, memory 864, an input/output device such as a display 854, a communication interface 866, and a transceiver 868, among other components. The device 850 may also be provided with a storage device, such as a microdrive or other device, to provide additional storage. Each of the components 850, 852, 864, 854, 866, and 868, are interconnected using various buses, and several of the components may be mounted on a common motherboard or in other manners as appropriate.
The processor 852 can execute instructions within the computing device 850, including instructions stored in the memory 864. The processor may be implemented as a chipset of chips that include separate and multiple analog and digital processors. The processor may provide, for example, for coordination of the other components of the device 850, such as control of user interfaces, applications run by device 850, and wireless communication by device 850.
Processor 852 may communicate with a user through control interface 858 and display interface 856 coupled to a display 854. The display 854 may be, for example, a TFT LCD (Thin-Film-Transistor Liquid Crystal Display) or an OLED (Organic Light Emitting Diode) display, or other appropriate display technology. The display interface 856 may comprise appropriate circuitry for driving the display 854 to present graphical and other information to a user. The control interface 858 may receive commands from a user and convert them for submission to the processor 852. In addition, an external interface 862 may be provided in communication with processor 852, so as to enable near area communication of device 850 with other devices. External interface 862 may provide, for example, for wired communication in some implementations, or for wireless communication in other implementations, and multiple interfaces may also be used.
The memory 864 stores information within the computing device 850. The memory 864 can be implemented as one or more of a computer-readable medium or media, a volatile memory unit or units, or a non-volatile memory unit or units. Expansion memory 874 may also be provided and connected to device 850 through expansion interface 872, which may include, for example, a SIMM (Single In Line Memory Module) card interface. Such expansion memory 874 may provide extra storage space for device 850, or may also store applications or other information for device 850. Specifically, expansion memory 874 may include instructions to carry out or supplement the processes described above, and may include secure information also. Thus, for example, expansion memory 874 may be provided as a security module for device 850, and may be programmed with instructions that permit secure use of device 850. In addition, secure applications may be provided via the SIMM cards, along with additional information, such as placing identifying information on the SIMM card in a non-hackable manner.
The memory may include, for example, flash memory and/or NVRAM memory, as discussed below. In one implementation, a computer program product is tangibly embodied in an information carrier. The computer program product contains instructions that, when executed, perform one or more methods, such as those described above. The information carrier is a computer- or machine-readable medium, such as the memory 864, expansion memory 874, or memory on processor 852, which may be received, for example, over transceiver 868 or external interface 862.
Device 850 may communicate wirelessly through communication interface 866, which may include digital signal processing circuitry where necessary. Communication interface 866 may provide for communications under various modes or protocols, such as GSM voice calls, SMS, EMS, or MMS messaging, CDMA, TDMA, PDC, WCDMA, CDMA2000, or GPRS, among others. Such communication may occur, for example, through radio-frequency transceiver 868. In addition, short-range communication may occur, such as using a BLUETOOTH, WIFI, or other such transceiver (not shown). In addition, GPS (Global Positioning System) receiver module 870 may provide additional navigation- and location-related wireless data to device 850, which may be used as appropriate by applications running on device 850.
Device 850 may also communicate audibly using audio codec 860, which may receive spoken information from a user and convert it to usable digital information. Audio codec 860 may likewise generate audible sound for a user, such as through a speaker, e.g., in a handset of device 850. Such sound may include sound from voice telephone calls, may include recorded sound (e.g., voice messages, music files, etc.) and may also include sound generated by applications operating on device 850.
The computing device 850 may be implemented in a number of different forms, as shown in the figure. For example, it may be implemented as a cellular telephone 880. It may also be implemented as part of a smart phone 882, personal digital assistant, or other similar mobile device.
Various implementations of the systems and techniques described here can be realized in digital electronic circuitry, integrated circuitry, specially designed ASICs (application specific integrated circuits), computer hardware, firmware, software, and/or combinations thereof. These various implementations can include implementation in one or more computer programs that are executable and/or interpretable on a programmable system including at least one programmable processor, which may be special or general purpose, coupled to receive data and instructions from, and to transmit data and instructions to, a storage system, at least one input device, and at least one output device.
These computer programs (also known as programs, software, software applications or code) include machine instructions for a programmable processor, and can be implemented in a high-level procedural and/or object-oriented programming language, and/or in assembly/machine language. As used herein, the terms “machine-readable medium” “computer-readable medium” refers to any computer program product, apparatus and/or device (e.g., magnetic discs, optical disks, memory, Programmable Logic Devices (PLDs)) used to provide machine instructions and/or data to a programmable processor, including a machine-readable medium that receives machine instructions as a machine-readable signal. The term “machine-readable signal” refers to any signal used to provide machine instructions and/or data to a programmable processor.
To provide for interaction with a user, the systems and techniques described here can be implemented on a computer having a display device (e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor) for displaying information to the user and a keyboard and a pointing device (e.g., a mouse or a trackball) by which the user can provide input to the computer. Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback (e.g., visual feedback, auditory feedback, or tactile feedback); and input from the user can be received in any form, including acoustic, speech, or tactile input.
The systems and techniques described here can be implemented in a computing system that includes a back end component (e.g., as a data server), or that includes a middleware component (e.g., an application server), or that includes a front end component (e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation of the systems and techniques described here), or any combination of such back end, middleware, or front end components. The components of the system can be interconnected by any form or medium of digital data communication (e.g., a communication network). Examples of communication networks include a local area network (“LAN”), a wide area network (“WAN”), and the Internet.
The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
A number of embodiments have been described. Nevertheless, it may be understood that various modifications may be made without departing from the spirit and scope of the invention.
In addition, the logic flows depicted in the figures do not require the particular order shown, or sequential order, to achieve desirable results. In addition, other steps may be provided, or steps may be eliminated from the described flows, and other components may be added to, or removed from, the described systems. Accordingly, other embodiments are within the scope of the following claims.
Chen, Jennifer Shien-Ming, Scott, Mark David, Foltz, Mark Alan, Affaki, John, Bakar, Majd, Tsui, Francis
Patent | Priority | Assignee | Title |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Mar 18 2021 | GOOGLE LLC | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Mar 18 2021 | BIG: Entity status set to Undiscounted (note the period is included in the code). |
Date | Maintenance Schedule |
Apr 09 2027 | 4 years fee payment window open |
Oct 09 2027 | 6 months grace period start (w surcharge) |
Apr 09 2028 | patent expiry (for year 4) |
Apr 09 2030 | 2 years to revive unintentionally abandoned end. (for year 4) |
Apr 09 2031 | 8 years fee payment window open |
Oct 09 2031 | 6 months grace period start (w surcharge) |
Apr 09 2032 | patent expiry (for year 8) |
Apr 09 2034 | 2 years to revive unintentionally abandoned end. (for year 8) |
Apr 09 2035 | 12 years fee payment window open |
Oct 09 2035 | 6 months grace period start (w surcharge) |
Apr 09 2036 | patent expiry (for year 12) |
Apr 09 2038 | 2 years to revive unintentionally abandoned end. (for year 12) |