The present invention relates to processing media data. Specifically, the invention relates to wireless media streaming.
The approaches described in this section are approaches that could be pursued, but not necessarily approaches that have been previously conceived or pursued. Therefore, unless otherwise indicated, it should not be assumed that any of the approaches described in this section qualify as prior art merely by virtue of their inclusion in this section.
Media devices used at homes or other locations may be used for different purposes. For example, multiple digital video recorders may be used to receive programs from over-the-air broadcasts, satellite broadcasts, cable channels, internet-based video downloads, stored shows, etc. Personal computing devices such as smartphones, tablet computers, laptops, desktops, etc., may be used to perform internet downloading and playing, social networking, word processing, emailing, etc. It is often difficult for a user to use one device to access media programs on a different device, even though both devices may be connected in close proximity at the same location or over networks more or less controlled by the same user. Additionally, since many media programs are not copyright free and are subject to various legal restrictions regarding digital media playing, recording and distributing, etc., it is often difficult for such media programs to be accessed and enjoyed using familiar menu interfaces in a consistent manner that protects underlying digital rights of the media programs.
The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:
In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, that the present invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to avoid unnecessarily obscuring the present invention.
Several features are described hereafter that can each be used independently of one another or with any combination of the other features. However, any individual feature might not address any of the problems discussed above or might only address one of the problems discussed above. Some of the problems discussed above might not be fully addressed by any of the features described herein. Although headings are provided, information related to a particular heading, but not found in the section having that heading, may also be found elsewhere in the specification.
Example features are described according to the following outline:
Techniques for gesture-based wireless media streaming as described herein may be implemented in software components, hardware components, or a combination of software and hardware components.
A variety of media devices may be available for playing media content/programs. A user may use a tablet computer to access internet media content; use a digital video recorder (DVR) to record and playback internet and broadcast programs; use a PC to store videos, photos, music, etc.; use a high-end home theater system to play/render media content with superior audiovisual characteristics; etc.
These and other available devices may be connected via one or more routers, access points, etc., over one or more of local networks, wide area networks, combinations of local networks or WANs, etc. A media streaming device may be used to allow a media device to act as a client device to access and play media programs that are available to another media device.
Two or more media devices may be configured with techniques as described herein to support seamless playing of a media program among these media devices. One or more media devices may be configured with gesture input interfaces to detect gestures of users. Examples of gestures to be detected by the gesture input interfaces include but are not limited to: flick motions (e.g., moving a finger to induce capacitance changes, resistance changes, other physical property changes, etc.), hovering motions (e.g., moving a finger or a hand to induce capacitance changes, other detectable physical property changes, etc.), device motions (e.g., using gloves whose motions may be detected by device motion detectors), eye movements (e.g., looking at a different device or display, etc.), face movements (e.g., facing a different device or display, etc.), body motions (e.g., walking from one room to another room, etc.), etc.
For the purpose of illustration only, in discussing gesture-based playing of a media program among two or more media devices, reference may be made to a client device equipped with a touch screen interface that is configured to detect flick motions by a user. For the purpose of the invention, any of other types of gestures may be used in place of, or in conjunction with, a flick motion type of gesture.
In some embodiments, while a user is watching or playing a media program on the client device (e.g., a handheld device with reasonable but not necessarily high-end media rendering capabilities, etc.), the user may decide to watch the media program on a second client device (e.g., a high-end home theater system, etc.). The media program being played at a media device such as the client device, the second client device, etc., may be stored on the media device. Additionally, alternatively, or optionally, the media program being played at a media device such as the client device, the second client device, etc., may be streamed to the media device by a media streaming device from a multimedia device (e.g., a DVR, etc.).
The user may use a gesture such as a flick motion, etc., to trigger switching (including but not limited to switching back and forth) the playing of the media program from one media device such as the client device, etc., to another media device such as the second client device, etc. In some embodiments, such a flick motion may be preceded by another gesture such as a hovering motion (which may help the client device or the media streaming device to narrow down the interpretation of the flick motion to specifically a user command to switch playing the media program from one media device to a different media device).
The client device or the media streaming device may be configured to determine, identify, and/or select the second client device. For example, the media streaming device, the client device, etc., may be configured with device location information manually, programmatically, dynamically, etc. Based on the device location information, the media streaming device, the client device, etc., may be configured to determine, identify, and/or select the second client device to switch the playing of the media program to. For example, a media device to which the playing of the media program is to switch may be determined to be presently located near (e.g., in the same room, etc.) the current media device at which the media program is being played.
Techniques as described herein may be implemented to allow a media device such as the second client device to resume playing the media program from a time point (e.g., 30 minutes into the media program, a specific number of media frames into the media program, etc.) at which the media program the current media device such as the client device stops playing the media program. In the present example, in response to detecting the flick motion, the client device identifies, on the client device, a time point at which the client device is to stop playing the media program. Subsequently, the client device sends a streaming request to a media streaming device to stream the media program to the second client device from the identified time point in the media program.
In some embodiments, the second client device may be identified among one or more client devices other than the client device by the client device, based on a direction of the gesture. The streaming request sent by the client device to the media streaming device may indicate the second client device to the streaming device.
In some embodiments, the user's gesture may carry directional information that a client device or a media streaming device can use to determine, identify, or select a target media device for playing subsequently the media program.
At the time of switching playing of a media program from one media device to another media device, the media program may be played in a specific playing mode at the former of the media devices. A streaming request that causes switching the playing of the media program between the media devices can indicate the specific playing mode. Thus, the latter of the media devices may continue playing the media program at the specific playing mode. Such a playing mode includes any of a variety of trick playing modes.
A user may continuously control playing of a media program even after the media program has been switched playing to one or more other media devices. In the present example, the client device may continue to accept user commands, which may or may not be gesture-based, to control the streaming and playing of the media program to the second client device and/or subsequent devices. The client device can cause a user command to be sent to any of these media devices directly or by way of the media streaming device.
A media program may also be concurrently played at a media device, while being streamed to another media device. In the present example, the client device may continue playing the media program while the media program is being streamed from the multimedia device to the second client device.
Different media devices may have different capabilities in supporting coding formats of media data. A media program rendered by the client device may be encoded in a first format which the client device is configured to decode but which the second client device is not configured to decode. Transcoding may be performed by one or more of available media devices. For example, transcoding between the two coding formats may be performed as a part of streaming a media program by a media streaming device, a client device, a DVR from which the media program is sourced, etc.
A media device as described herein may be one or more of tablet computers, handheld devices, laptops, e-readers, personal computing devices, game devices, or display systems, whereas the second device is a different one of tablet computers, handheld devices, laptops, e-readers, personal computing devices, game devices, or display systems.
In some embodiments, a network connection among, the client device, the streaming device and the second client device comprises at least one wireless network link.
Although a specific computer architecture is described herein, other embodiments of the invention are applicable to any architecture that can be used to perform the functions described herein.
Example multimedia devices include but are not limited to any of: digital video recorders (DVRs), home based computing devices configured to send multimedia content in streams to recipient devices over network connections, media servers, set-top boxes, digital media receivers, etc. In some embodiments, all the multimedia devices (108-1 through 108-N) in
One or more of the multimedia devices (108-1 through 108-N), the streaming device (102), the client devices (106-1 through 106-M), etc., may be configured to support one or more (e.g., multi-room) streaming protocols that allow the devices to share media through streaming over network connections. As illustrated in
As used herein, “content in a stream of a media program” may be the same as, or alternatively may be different than, the content of the media program from which the stream is derived or generated. In an example, when a media program is streamed for playing or recording in a normal playing mode, content in a corresponding stream may be the same as the content of the media program. In another example, when the media program is streamed for playing or recording in a different mode other than the normal playing mode, content in a corresponding stream may be different (e.g., a version adapted for trick play modes, time-wise or spatially downsampled/upsampled from the normal playing media program, etc.) from the content of the media program (e.g., as received from a broadcast or a broadband source, as retrieved from a persistent media data store, etc.). For example, in a trick play mode involving playing while fast forwarding or rewinding, content in a corresponding stream may be a sub-sampled version and/or a time-reversed version of the content of the media program.
In some embodiments, a stream as described herein may be configured to deliver content of a media program which content has been dynamically varied from the content of the media program (e.g., as received from a broadcast or a broadband source, as retrieved from a persistent media data store, etc.) and specifically adapted for a particular playing mode (including but not limited to any of: normal playing modes at different time points, trick playing modes at different time points, etc.) at a client device. Thus, at a particular time point of streaming a media program, the stream may carry a portion of content of the media program without skipping or repeating, but at a different time point of streaming of the media program, the stream may carry an altered/generated/adapted portion (e.g., with skipping, repeating, downsampling, upsampling, rate adapting, etc.) that is different from a portion of the media program from which the altered/generated portion is derived. In some embodiments, a stream between a multimedia device (e.g., 108-1) and a streaming device (102) may carry the content of the media program without any skipping or repeating, but a corresponding stream (which corresponds to the stream between the multimedia device 108-1 and the streaming device 102) between the streaming device (102) and the client device (106-1) may carry altered/generated/adapted portions (e.g., with skipping, repeating, downsampling, upsampling, rate adapting, etc.) that are different from corresponding portions of the media program from which the altered/generated/adapted portions are derived.
The speed at which a media program is streamed between devices may be the same as the normal playing speed, or alternatively may be different from the normal playing speed of the media program. A media program of a certain playing time duration (e.g., 2 hours) may be streamed by a streaming device (e.g., 102) from a multimedia device (e.g., 108-1) to a client device (e.g., 106-1) in a time duration shorter (e.g., 10% of 2 hours, several minutes, several seconds, etc.) than the certain playing time duration, or alternatively longer (e.g., 200% of 2 hours, 3 hours, etc.) than the certain playing time duration. In some embodiments, the streaming device (102) may be configured to prioritize two or more streams in terms of downloading speeds based on one or more factors that include but are not limited to operational modes that are being supported by the two or more streams, respectively. Fast forward playing modes may be given the highest priority. Normal playing modes may be given the next highest priority. Downloading without playing may be given a lower priority than the foregoing priorities. Side-loading modes (downloading/or side-loading a program while playing another program) may be given some of the lowest priorities. The one or more factors may also include but are not limited to: types of media programs that are being streamed, etc. For example, a stream that is side-loading a media program to a client device may be placed on a lower priority and hence may take a longer time to stream that another stream that is streaming a live broadcast, a media program, etc., to be played in the normal playing mode at the same client device, at a different client device, etc.
The maximum number of streams which the streaming device (102) may be configured to be capable of concurrently supporting may be one, two, three, four, or more. For instance, the streaming device (102) may be configured to support four separate shows from one, two, three or four multimedia devices (e.g., 108-1 through 108-N) and separate interactions (including but not limited to individual trick playing modes for the separate shows) with one, two, three or four client devices (e.g., 106-1 through 106-M). In an example, a streaming device may concurrently stream a media program from a multimedia device (108-1) to a client device (106-1) at the same time while the streaming device (102) stream another media program from the same multimedia device (108-1) or a different multimedia device (e.g., 108-2) to the same client device (106-1) or a different client device (106-2). In another example, a streaming device (102) may concurrently stream a media program from a multimedia device (108-1) to two or more client devices (e.g., 106-1, 106-2, etc.) at the same time. In yet another example, a streaming device (102) may concurrently stream different portions—which may or may not be overlapping—of a media program from two or more multimedia devices (e.g., 108-1, 108-2, etc.) to one, two or more client devices (e.g., 106-1, 106-2, etc.) at the same time.
The streaming device (102) may be configured to perform one or more operations related to device discovery, de-multiplexing, multiplexing, buffering, decryption, decoding, transcoding, encoding, encryption, time-wise resampling, spatial resampling, streaming, rate adaptation, resolution adaptation, etc.
A wide variety of standard-based or proprietary device discovery techniques including but not limited to service discovery protocols, DNS service discovery (DNS-SD), dynamic host configuration protocol (DHCP), etc., may be used by streaming, multimedia, and client devices to discover other streaming, multimedia, and client devices. The streaming device (102) may be configured to discover multimedia devices (e.g., 108-1 through 108-N) and client devices (e.g., 106-1 through 106-M), exchange one or more credentials with the discovered devices, and establish one or more trust levels with the discovered devices that may be used in part to determine whether a particular user or device has appropriate digital rights and/or authenticated identity to access particular programs. Similarly, any of the multimedia devices (108-1 through 108-N) and the client devices (106-1 through 106-M) may be configured to discover, exchange credentials with, and establish trust levels with, other devices.
A service or device discovery process involving media devices such as multimedia devices (108-1 through 108-N), streaming devices (one of which may be 102 of
A wide variety of cryptography techniques or security schemes including but not limited to the Data Encryption Standard (DES), the Advanced Encryption Standard (AES), cryptographic hash functions such as MD5, SHA-1, SHA-2, SHA-3, private and public keys, etc., may be used for encryption/decryption of media content. A cryptography technique as described herein may be implemented in hardware, software, a combination of the two, etc. Streamed content (or content carried in a stream) may be encrypted based on a shared secret between a stream sending device and a stream recipient device. One or more first cryptography techniques may be used to encrypt and decrypt streamed content between the multimedia device (108-1) and the streaming device (102). One or more second cryptography techniques may be used to encrypt and decrypt streamed content between the streaming device (102) and the client device (102-1). In some embodiments, the one or more first cryptography techniques are the same as the second cryptography techniques. In some embodiments, at least one of the one or more first cryptography techniques is different from all of the one or more second cryptography techniques. Additionally, optionally, or alternatively, in some embodiments, at least one of the one or more second cryptography techniques is different from all of the one or more first cryptography techniques. The streaming device (102) may be configured to decrypt a whole or a part of streamed content encrypted with the one or more first cryptography techniques from the multimedia device (108-1), encrypts a whole or a part of a re-streamed content generated based on the streamed content received from the multimedia device (108-1), and send the encrypted re-streamed content to the client device (106-1).
A wide variety of coding techniques related to one or more of MPEG-2, MPEG-4, H.263, H.264, VP8, QuickTime, Adobe Flash, Windows Media, etc., may be used for encoding/decoding of media content. A coding (e.g., encoding, decoding, transcoding, etc.) technique as described herein may be implemented in hardware, software, a combination of the two, etc. A first coding technique may be used to encode and decode streamed content between the multimedia device (108-1) and the streaming device (102). A second coding technique may be used to encode and decode streamed content between the streaming device (102) and the client device (102-1). In some embodiments, the first coding technique is the same as the second coding technique. In some embodiments, the first coding technique is different from the second coding technique. The streaming device (102) may be configured to transcode a whole or a part of the streamed content in a first coding format from the multimedia device (108-1) into a second coding format and send the transcoded streamed content in the second coding format to the client device (106-1). The second coding format may be one that the client device (108-1) has been implemented with hardware-based acceleration features. Alternatively, the second coding format may be one that the client device (108-1) has been installed with supporting software packages.
In some embodiments, the streaming device (102) may delegate one or more operations related to transcoding to the multimedia device (108-1) or the client device (106-1). In an example, the streaming device (102) requests the multimedia device (108-1) to transcode content of a media program from the first coding format to the second coding format at the multimedia device (108-1) and then streams the transcoded content of the media program already in the second coding format to the streaming device (102). In another example, the streaming device (102) streams the streamed content of a media program in the first coding format, as received from the multimedia device (108-1), to the client device (106-1). The client device (106-1) may be configured to make use of the streamed content in the first coding format and/or to transcode the streamed content into the second coding format.
Media programs (e.g., TV shows, movies, live broadcasts, etc.) may run/last for varying media time durations in the normal playing mode. In an example, a TV show lasts 30 minutes in the normal playing mode and hence has a 30 minute media time duration. In another example, a movie lasts 2 hours in the normal playing mode and hence has a 2 hour media time duration. In yet another example, a live broadcast has an undetermined media time duration until the broadcast is over. In some embodiments, the streaming device (102) is configured to receive a first stream (e.g., 300-1) of a media program from the multimedia device (108-1), and buffer/cache/store a certain portion of the media program (e.g., in a media data buffer 302). The portion of the media program buffered on the streaming device (102) may represent the entire media time duration of the media program, or may represent only a subset of the entire media time duration of the media program. The portion of the media program buffered on the streaming device (102) may already be transcoded into the second coding format, or may be still encoded in the first coding format, or may be transcoded into an intermediate coding format. In some embodiments, the streaming device (102) may be configured with a remote buffering capability. In an example, the streaming device is configured to use the multimedia device (108-1) to buffer a portion (e.g., in the first coding format) of the media program under streaming. In another example, the streaming device is configured to use the client device (106-1) to buffer a portion (e.g., in the second coding format) of the media program under streaming.
In some embodiments, a buffered portion of a media program as described herein may be used to support both normal and trick play modes, which is accessible/operable on the client device (106-1) by a user. A normal playing mode refers to the playing of media program at a normal speed without skipping or repeating video frames in the media program (which may be provided by a content provider). Trick play modes refer to playing media programs in manners that skip or repeat some video frames in the media program.
In an example, if the client device (106-1) is showing a live broadcast, as received through a video tuner of the multimedia device (108-1) and streamed through the streaming device (102), the client device (106-1) and/or the streaming device (102) may accumulate and buffer a (e.g., thirty minute, etc.) portion of the live broadcast up to the current wall clock time. The buffered portion of the live broadcast may be used to support any of a normal playing mode at the current wall clock time, a normal playing mode at a time preceding the current wall clock time, one or more fast forward (1.2×, 1.5×, 1.8×, etc. of the normal playing speed) playing modes at a time preceding the current wall clock time, one or more rewind playing modes from the current wall clock time back to a time at which the streamed content of the media program may be found in the buffered portion of the live broadcast, etc.
In another example, if the client device (106-1) is playing a non-live media program, as stored in the multimedia device (108-1) and streamed through the streaming device (102), the client device (106-1) and/or the streaming device (102) may accumulate and buffer a (e.g., thirty minute, etc.) portion of encompassing a current playing position of the non-live media program on the client device (106-1). The buffered portion of the non-live media program may be used to support any of a normal playing mode at the current playing position, a normal playing mode at a different time (e.g. a new current playing position) other than what corresponds to the current playing position, one or more fast forward (1.2×, 1.5×, 1.8×, etc. of the normal playing speed) playing modes with the buffered portion of the non-live media program, one or more rewind playing modes within the buffered portion of the non-live media program, etc.
In some embodiments, a client-centric streaming model may be used, in which a multimedia device (e.g., 108-1) may serve content of media programs to a client device (e.g., 106-1) through a streaming device (e.g., 102) under direction of the client device (106-1), for example, after the streaming, multimedia and client devices (e.g., 102, 106-1, and 108-1) have discovered the presence of their respective other devices. Subsequently, requests and responses may be exchanged between two or more of the client device (106-1), the streaming device (102), and the multimedia device (108-1). In some embodiments, other devices such as other multimedia devices (e.g., 108-2 through 108-N) and other client devices (e.g., 106-2 through 106-M), if any, may also be involved in operations as described herein in similar or dissimilar manners. Some of the requests and responses may be generated based on user commands, or may be specified with user commands.
In some embodiments, streams of media programs from a streaming device (e.g., 102) to a client device (e.g., 106-1) are generated based on streams of the media programs to the streaming device (102) from multimedia device (e.g., 108-1 through 108-N). The client device (106-1) may exchange requests and responses with a multimedia device (e.g., 108-1) in one or more communication channels provided by or established with the streaming device (102). Available programming information, metadata information (e.g., descriptive or textual information about a media program that is being played or that is interesting to a user, information about actors, places, products, or objects appearing in media programs, etc.) relating to the media programs, etc., may be obtained by the client device (106-1) from the multimedia device (108-1) using one or more (e.g., non-streaming) requests and responses. In some embodiments, streaming requests from a client device (e.g., 106-1) are addressed to a streaming device (e.g., 102), which in turn may invoke separate streaming requests (corresponding to the streaming requests from the client device 106-1) to one or more multimedia devices (108-1 through 108-N).
The client device (106-1) may be configured to present screen displays to, and to receive user commands from, a user. The user may navigate interactively among the screen displays to specific media programs in which the user is interested, and to direct the client device (102) to obtain information about media programs, to play selected media programs, to download or side-load media programs. In some embodiments, side-loading refers to a loading of a media program performed in parallel with a playing of the media program or another media program.
Available programming information may be obtained by the client device (106-1) from the streaming device (102) and/or the multimedia device (108-1). One or more tuners on multimedia devices (e.g., 108-1 through 108-N) may be allocated to client devices (106-1 through 106-M) on demand or after the discovery process successfully results in trust levels satisfying the requirements for streaming media programs from the multimedia devices (108-1 through 108-N) to the client devices (106-1 through 106-M).
The client device (106-1) may send a request to the streaming device to receive available programming information (e.g., electronic program guides, stored program lists on various multimedia devices, etc.) that describes what media programs may be available from broadcast sources, broadband sources, media data stores from remote and local multimedia devices, etc. Upon receiving the request, the streaming device (102) may be configured to provide the available programming information to the client device (106-1). The streaming device (102) may obtain at least a part of the available programming information on demand (e.g., in response to receiving the request from the client device (106-1) from one or more of the multimedia devices (e.g., 108-1 through 108-N) that are operatively linked to the streaming device (102). Alternatively, the streaming device (102) may obtain at least a part of the available programming information from one or more of the multimedia devices (e.g., 108-1 through 108-N) that are operatively linked to the streaming device (102) before receiving the request from the client device (106-1).
Available programming information may comprise or even be in the form of addresses (e.g., channels, Universal Resource Locators, file names, media data databases, media servers, media distribution systems, etc.) at which media programs may be obtained or streamed. Available programming information as described herein may include but is not limited to availability information of media programs that are stored at one of the multimedia devices (108-1 through 108-N), or media programs that may not be stored at one of the multimedia devices (108-1 through 108-N) and that may be received through one of the multimedia devices (108-1 through 108-N). For example, the client device (102-1) may request a live broadcast or a movie on DVD that may not have been stored on one or more of the multimedia devices (108-1 through 108-N) but nevertheless may be received through a selected multimedia device (e.g., 108-1) among the multimedia devices (108-1 through 108-N). The selected multimedia device (108-1) may allocate one of one or more tuners to receive the live broadcast and stream the content of the live broadcast through the streaming device (102) to the client device (106-1). Similarly, the selected multimedia device (108-1) may access a movie on DVD through one of its digital interfaces and stream the content of the movie through the streaming device (102) to the client device (106-1). In some embodiments, multiple streams of media programs generated based on streams from multimedia devices to the streaming device may be concurrently streamed by the streaming device (102) to a client device (102). One of the multiple streams of media programs may be played while others of the multiple streams of media programs may be side-loaded into the client device (106-1).
A media program may be copyright free and thus content of the media program including any streamed content may be copied without legal limitation. Alternatively, a media program may be copyright protected and thus the content of the media program including any streamed content may only be copied, recorded or distributed if digital rights to the media program for performing these operations are secured and verified. In some embodiments, a multimedia device (e.g., 108-1) and/or the streaming device (102) may be configured to verify whether a client device (e.g., 106-1) or a user thereof possesses sufficient digital rights to a media program. The streaming of the media program to the client device (106-1) may be performed in compliance with the user's verified digital rights to the media program. For example, media devices (e.g., multimedia devices, streaming devices, client devices, etc.) as described herein may implement a security scheme that permits a recipient client device to play a media program with a stream of the media program but does not permit the recipient client device to copy or record (e.g., save to persistent store for playback or for distribution) the media program with the stream.
In an example, the client device (106-1) may send a request to the streaming device to select a media program for streaming. The request may represent a user command to play the media program or to side-load the media program in parallel with playing another media program. Upon receiving the request from the client device (106-1), the streaming device (102) may be configured to interrogate the client device programmatically and/or manually for proof of the user's digital rights to the media program. Additionally, optionally, or alternatively, upon receiving the request from the client device (106-1), the streaming device (102) may be configured to determine the user's digital rights to the media program based at least in part on the credentials previously received from the client device (106-1) or based at least in part on trust levels previously established with the client device (106-1).
Digital rights as described herein include but are not limited to any of: playing rights, copying rights, distribution rights, etc. In response to a successful interrogation/validation of the user's digital rights to the media program, the streaming device (102) may be configured to stream the media program from the multimedia device (108-1) to the client device (106-1) in compliance with the digital rights that have been verified. Otherwise, the user's request to the media program may be denied or limited in compliance with the user's digital rights to the media program.
Additionally, optionally, or alternatively, the streaming device (102) may be configured to determine whether the user only possesses a single copy right to the media program. If so, the devices involved in streaming the media program may implement a protocol to cause the media program to be removed, erased, expired, etc., from the multimedia device (108-1) once the media program has been successfully copied/recorded by the client device (106-1). The streaming device may perform one or more operations (e.g., delivering a media program to one device, deleting the media program from another device, maintaining the copies of the media program among multiple devices no more than a limit in accordance with the verified digital rights (e.g., there is only one permissible copy of the media program on either the multimedia device (108-1) or the client device (106-1)).
If the streaming device (102) determines that the client device, or the user thereof, does not have the digital rights to the media program, the streaming device (102) may take one or more of the following actions. The streaming device (102) may deny the request to streaming the media program to the client device (106-1). Additionally, optionally, or alternatively, the streaming device (102) may stream only a version embedded with commercials, a trailer, a highlight, or an approved abbreviated version of the media program to the client device (102). Additionally, optionally, or alternatively, the streaming device (102) may cause the client device (102) to acquire the digital rights to the media program either through the streaming device (102), one of the multimedia devices (108-1 through 108-N), or directly over a network connection (e.g., internet based) from an authorized right holder to the media program.
If the streaming device (102) determines that the client device (106-1), or the user thereof, has the digital rights to the media program, the streaming device (102), or a stream controller (e.g., 116 of
The streaming device (102), or a source stream module (e.g., 110 of
In some embodiments, one or more tags may be embedded in streams from a streaming device (e.g., 102) to a client device (e.g., 106-1). Techniques related to tags are described in U.S. Pat. No. 7,889,964, the entire content of which are incorporated by reference herein. A device as described herein may be configured with a mechanism for inserting tags into a media stream such as an audio stream, a video stream, a television broadcast stream, etc. Tags may be inserted into a media stream prior to or at the time of transmission. The tags contain command and control information that a recipient device translates and acts upon. During the tag processing stage, the recipient device may be configured to perform operations as described herein in response to the tags. Tags can be used to indicate the start and end points of a program segment, a subset of media data units, etc. Tags can be used to indicate a presence of a media feature, an absence of a media feature, etc. The recipient device may be configured to fast forward, slow forward, skips over a program segment during playback in response to the tags or user input related to the tags.
Menus, icons, and Web pages may be displayed to the user based on information included in a tag. The user may interact with the menu, icon, or Web page through an input device. The recipient device performs the actions associated with the menu, icon, or Web page and the user's input. Tags may be used to create indexes in media data, media streams, media files, etc. This allows the user to jump to particular indexes in the media data, media streams, media files, etc.
A tag in a stream (e.g., the second stream 300-2 in the previous example) to the client device (106-1) may cause the client device (106-1) to display an interactive icon to a user so that the user may select. Selecting the interactive icon by the user may lead to performing one or more actions related to the tag. An information tag in a stream (e.g., the second stream 300-2 in the previous example) to the client device (106-1) may inform the client device (106-1) a specific piece of information. For example, a time duration (e.g., 10 minute fast forward playing of a media program) in a trick play mode on the client device (106-1) may correspond to a time duration (e.g., 20 minute unskipped and unrepeated normal playing of the media program) in a normal playing mode. An information tag may be used to tell the client device (106-1) how much the corresponding time duration in the normal playing mode is for the time duration in the trick play mode. A tag may be embedded in a stream (e.g., the first stream 300-1 in the previous example) from a multimedia device (e.g., 108-1) as received by the streaming device (102). Additionally, optionally, or alternatively, a tag may be inserted into a stream (e.g., the second stream 300-2) to the client device (106-1) by the streaming device (102).
Content delivered through a stream may comprise premium content and/or non-premium content. For example, a pay-per-view media program may be delivered in a stream as described herein. Resources on a multimedia device (e.g., 108-1) such as tuners may be made available to acquire multimedia content to be streamed from the multimedia device (108-1) to a client device (e.g., 106-1). A streaming device (e.g., 102) may be configured to support viewing TV channels acquired by tuners controlled by or located in multimedia devices (e.g., 108-1 through 108-N). A user may change channels and watch live TVs streamed by the multimedia devices (108-1 through 108-N). For example, while streaming a media program (which may be a live TV channel, a stored media program, a media program through a digital video interface, etc.) from a multimedia device (108-1) to a client device (106-1), the streaming device (102) may receive a streaming request from the client device (106-1) to switch or to play simultaneously another media program. The other media program may, but is not limited to, be received from a tuner of the multimedia device (108-1), a tuner of another multimedia device (e.g., 108-2), a stored program on one of the multimedia devices, a broadband accessible program through one of the multimedia devices, etc. In response, the streaming device (102) may switch to, or add, a new stream for the other media program.
In some embodiments, a multimedia device (e.g., 108-2) may become a client device for streaming services provided by a streaming device (e.g., 102) as described herein. The streaming device may be configured to receive a stream of a media program from a source multimedia device (e.g., 108-1), and generate two or more streams of the media program based on the stream of the media program to client devices. One of the two or more streams of the media program may be for recording at a destination multimedia device (e.g., 108-2), which becomes a client device for the purpose of streaming the media program. Another of the two or more streams of the media program may be for recording or playing at a mobile device, which may be a client device (e.g., 106-2). The streaming device (102) may be configured to determine that streaming a media program into multiple devices for the intended playing or recording operations complies with digital rights of one or more users or client devices that make the streaming requests for the media program.
In some embodiments, the streaming device (e.g., 102) may be configured to receive one or more streaming requests related to a media program from a first device (which may be a local device, a remote device connected over the internet, etc.), and generate one or more streams of the media program to at least a second device that is different from the first device. Thus, a user may travel around the world and still be able to interact with a streaming device (e.g., 102) to stream favorable media programs to a remote device (e.g., 106-1) with which the user carries around or to a different client device (e.g., 106-2) that is located elsewhere.
A streaming device (e.g., 102) as described herein may be configured to set up communication channels with multimedia devices (e.g., 108-1 through 108-N) and client devices (e.g., 106-1 through 106-M). The setting up of the communication channels may be performed as a part of a service and device discovery process among these media devices, or as separate operations performed after the discovery process. A communication channel may be used as one or more data paths and/or one or more control paths between two or more of the multimedia devices (108-1 through 108-N), the streaming device (102), the client device (106-1 through 106-M), other devices/servers (e.g., a content server connected to one or more of the multimedia devices 108-1 through 108-N over the internet or a dedicated wide area network connection), etc. A communication channel as described herein may carry streams of media programs, in-band control and data information (e.g., along with a stream of a media program), out-of-band control and data information (e.g., separate from any stream of media program), etc.
In some embodiments, a client device (e.g., 106-1) and a multimedia device (e.g., 108-1), from which media programs may be streamed by a streaming device (e.g., 102) to the client device, may implement a plurality of common (or standard) menu screens. Through one or more communication channels, available programming information and other metadata, which may be used to drive the common menu screens (e.g., implemented in a data-driven model) on a client device as described herein, may be provided or forwarded from any of one or more multimedia devices (e.g., 108-1 through 108-N) to any of one or more client devices (106-1 through 106-N) by the streaming device (102). Under techniques as described herein, a use may be enabled to use a client device to access the same media programs (e.g., shows, channels, live broadcasts, podcasts, etc.) as those accessible through a multimedia device. In some embodiments, software and/or hardware based security features that prevent hacking or stealing protected media content (e.g., a premium media program) may be implemented by one or more of a multimedia device (e.g., 108-1), a streaming device (e.g., 102), and a client device (e.g., 106-1) that are involved in streaming the protected media content.
In some embodiments, a streaming device (e.g., 102) is configured to—automatically, with a user command, etc.—switch an ongoing stream of a media program from a first multimedia device (e.g., 108-1) to a second different multimedia device (e.g., 108-2). The streaming device (102) may be configured to determine whether to switch an ongoing stream based on one or more factors. These factors include but are not limited to: network load conditions, multimedia device load conditions, multimedia device capabilities, device compatibilities, etc. In an example, the streaming device (102) may determine that the second different multimedia device (108-2) is the least busy multimedia device among a plurality multimedia devices (e.g., 108-1 through 108-N), and hence switch the stream from the first multimedia device (108-1). In some embodiments, a streaming device (e.g., 102) is configured to switch an ongoing stream of a media program from a first multimedia device (e.g., 108-1) to a second different multimedia device (e.g., 108-2). The streaming device (102) may be configured to determine whether to switch an ongoing stream based on one or more factors. These factors include but are not limited to: user commands, network load conditions, multimedia device load conditions, etc. In an example, the streaming device (102) may receive a user command (e.g., as provided by a client device such as 106-1) that the second different multimedia device (108-2) should be used in place of the first multimedia device (108-1). In response, the streaming device (102) may switch the stream from the first multimedia device (108-1) to the second multimedia device (108-2). In another example, the streaming device (102) may determine that the second different multimedia device (108-2) is the least busy multimedia device among a plurality multimedia devices (e.g., 108-1 through 108-N), and hence switch the stream from the first multimedia device (108-1) to the second multimedia device (108-2). In a further example, the streaming device (102) may determine that the first multimedia device (108-1) is busier and/or consumes more resources and/or performs worse than the second different multimedia device (108-2), and hence switch the stream from the first multimedia device (108-1) to the second multimedia device (108-2).
In some embodiments, a streaming device (e.g., 102) may be configured to—automatically, with a user command, etc.—switch an ongoing stream of a media program from a first client device (e.g., 106-1) to a second different client device (e.g., 106-2) or another media device. The streaming device (102) may be configured to determine whether to switch an ongoing stream based on one or more factors. These factors include but are not limited to: network load conditions, client device load conditions, device capabilities and compatibilities, etc. In an example, the streaming device (102) may determine that the second different client device (106-2) or the other media device is the best media device (e.g., a high resolution TV in a room in which the user's presence is detected or sensed) for rendering the media program among a plurality media devices (e.g., client devices 106-1 through 106-N, other media devices, etc.), and hence switch the stream from the first client device (106-1) to the second multimedia device (106-2) or the other media device.
A streaming device (e.g., 102) may be configured to support a variety of trick play modes for a media program that is being streamed from a multimedia device (108-1) to a client device (e.g., 106-1). The client device (102) may send a user command in the form of a trick mode streaming request to the streaming device (102) to commence a trick play mode while the media program is being streamed for a normal playing mode in a full stream path (e.g., 300 of
A streaming device (e.g., 102) may be configured to allow a multimedia device (e.g., 108-1) to concurrently support a first user for performing media processing/rendering operations directly with the multimedia device (108-1) and image rendering device operatively linked with the multimedia device (108-1), while supporting a second user for performing independent media processing/rendering operations with a client device (e.g., 106-1). In some embodiments, the multimedia device may be configured with one, two or more tuners. In the case of two or more tuners, in some embodiments, each of the first user and the second user is allocated with a separate tuner, allowing each of the users to watch separate channels and live broadcasts, etc. In some embodiments, menu screen presentations and interactions may be centrally (e.g., directly) served by the multimedia device (108-1), for example, using a thin-client approach. In some embodiments, the multimedia device (108-1) provides underlying data (program metadata, EPG data, media storage information, broadband access resource locators, broadcast channels, etc.) for the client device (106-1) to present menu screen presentations and interact with the user locally with the user using a thick-client approach. For example, the multimedia device (108-1) can display an electronic program guide (EPG) to a user of the multimedia device (108-1). Subsequently, the user can provide user input to the multimedia device (108-1). Examples of the user input include but are not limited to only a selection of a program from the displayed EPG. In response to receiving the user input, the multimedia device (108-1) can be configured to display a program description of the program. The user can use a gesture such as a flick motion, etc., to trigger playing the program on a second multimedia device (e.g., 108-2, etc.).
A streaming device (e.g., 102) may be configured to detect/determine specific types of multimedia devices (108-1 through 108-N) and client devices (106-1 through 106-M), and customize one or more characteristics, operational parameters, bitrates, dynamic ranges, color gamut support, resolutions, etc., according to the detected device types. In an example, the streaming device (102) may set a 2 Mbit/sec bitrate for a client device such as a tablet computer, and may set a 10 Mbit/sec bitrate for a 50 inch high-end TV. The streaming device (102) may be configured to monitor bandwidth usages of one or more streams and dynamically alter bandwidth allocations to the one or more streams based on the bandwidth usages.
A streaming device (e.g., 102) may be configured to stream media content from a client device (106-1) to a multimedia device (e.g., 108-1). For example, personal videos shot by a tablet computer or a handheld device may be streamed by the streaming device (102) from the handheld device to another media device in a manner similar to how media content may be streamed in a reverse direction.
A streaming device (e.g., 102) may be configured to interoperate with media devices of a variety of capabilities and features and to take advantage of the capabilities and features of the media devices as appropriate. For example, for less capable multimedia devices, the streaming device (102) may perform streaming, transcoding (e.g., personal media content, home video, etc., from a client device), and/or more operations for the less capable multimedia devices, whereas for more capable multimedia devices, the streaming device (102) may perform streaming and/or fewer operations for the more capable multimedia devices. Additionally, optionally, or alternatively, the streaming device (102) may perform different operations for client devices of different capabilities and features.
In an embodiment, the one or more features or functionalities as described herein may be implemented by one or more software modules, hardware modules, combinations of software and hardware modules, etc. The modules may be preconfigured, preloaded, downloaded, installed, etc., on a device. The modules may execute concurrently with other modules, and may be configured to detect gestures made by a user of a media device (e.g., a multimedia device, a client device, etc.).
An example of gesture as described herein may be a flick made by a user touching a particular spot on a touch screen interface (e.g., as a part of gesture input interface 422, etc.) of a device with a finger, and sliding the finger away from the particular spot while maintaining contact with the touch screen interface, as described in the U.S. patent application Ser. No. 12/950,857, which is incorporated by reference as though originally disclosed herein. It should be noted that for the purpose of illustration only, finger-based gestures are described; however, other gestures and/or other biological or non-biological input means, pens, stylus, gloves, etc., may be used in various embodiments of the invention. In some embodiments, maintaining contact with a touch screen interface may include maintaining a (e.g., close) hovering motion—for example, by hand—over the touch screen interface, wherein the hovering motion is detectable by the touch screen interface. Examples of touch screen interfaces include but are not limited to any of: resistive touch screen interfaces, capacitive touch screen interfaces, pressure-based touch screen interfaces, heat-based touch screen interface, optics-based touch screen interface, etc.
Examples of gestures as described herein include but are not limited to motions of devices as detected by motion tracking modules, one or more of which may be a part of gesture input interface 422, etc. Examples of motion tracking modules include but are not limited to any of: displacement tracking modules, velocity tracking modules, acceleration tracking modules, etc.
In an embodiment, any other device used concurrently with a device configured to detect one or more types of gestures may or may not be configured to detect the same types of gestures. In an example, a concurrently used device (e.g., client device 106-2) may not even support any type of gesture detection. In another example, a client device such as 106-1 may be configured to detect both flick motions with a touch screen interface and device motions with motion tracking modules. In a further example, a client device (e.g., 106-3) or a multimedia device (108-1) may be configured to detect only flick motions on a touch screen interface.
In an embodiment, while a client device (e.g., 106-1) is playing a media program on a first display integrated or attached with the client device (106-1), a user of the client device (106-1) may request switching the playing of the media program to a second display that is not integrated or attached with client device 106-1. In an example, the second display may be integrated or attached with a multimedia device (e.g., 108-1), another client device (e.g., 106-2), etc. In another example, the second display may be a shared display by one or more of client devices and multimedia devices.
For illustration purposes, client device 106-1 comprises a gesture input interface (e.g., 422 of
Streaming of the media program to the target device for switching playing of the media program from the first display to the second display may, but is not required to, start at the identified time point of the media program if some portions of the media program has been played before switching rendering the media program from the first display to the second display. For example, the time point identified for client device 106-1 to stop playing on the first display may be specified in the streaming request to the media streaming device 102. Streaming the media program to the target device may start from the time point at which client device 106-1 stops playing the media program.
In some embodiments, the streaming request contains information specifying a target device (e.g., 106-2, 108-1, etc.). In some other embodiments, the streaming request does not contain information specifying a target device (e.g., 106-2, 108-1, etc.), or contain information merely suggesting a target device (e.g., 106-2, 108-1, etc.) as a default choice. In some embodiments, media streaming device 102 is configured to autonomously determine a suitable device as the target device (e.g., 108-1). For example, the user may be initially watching the media program (e.g., a movie) on the first display of client device 106-1 (e.g., a tablet computer, etc.). When the user makes a gesture to cause sending the streaming request to media streaming device 102 to stream the media program to a target device from that time point on, media streaming device 102 may be configured to identify one or more available devices (e.g., 106-2, . . . , 106-M, 108-1, . . . , 108-N, etc.). Media streaming device 102 may be configured to default to an available device if the available device is the only one detected. Otherwise, if more than one available device is sensed by media streaming device 102, media streaming device 102 may be configured to select one of the one or more available devices as the target device (e.g., 106-2, 108-1, etc.) based on one or more selection criteria (e.g., equally or non-equally weighted, etc.), which may include but are not limited to one or more of: locations and/or motions of one or more users, characteristics of available displays, characteristics of available sound systems, sizes of displays, resolutions of displays, proximities to client device 106-1, dynamic ranges, color gamuts, sound systems, energy uses, availability of resources and capabilities relating to tuners, processors, memory spaces, etc. For example, multimedia device 108-1 which may be integrated or attached with a high resolution high dynamic range display near client device 106-1 can be selected as the target device based on the selection criteria.
In embodiments in which a streaming request may contain information specifying a target device (e.g., 106-2, 108-1, etc.), a media streaming device (e.g., 102) may be configured to determine the target device (e.g., 108-1) based on the information in the streaming request. As in the previous example, the user may be initially watching the media program (e.g., a movie) on the first display of client device 106-1 (e.g., a tablet computer, etc.). When the user makes a gesture to cause sending the streaming request to media streaming device 102 to stream the media program to a target device from that time point on, client device 106-1 may be configured to determine the target device based on the gesture and specify the target device in the streaming request to media streaming device 102. In an example, client device 106-1 may be configured to determine a spatial direction from the gesture and correlated the spatial direction with a specific device if more than one available device exists. In another example, at the start of the user making the gesture, client device 106-1 may be configured to overlay one or more icons for one or more available devices with the images from the media program and to select a specific device among the one or more available devices, as indicated by a spatial direction of a flick motion. The icons for the available devices may be preconfigured or dynamically created by client device 102 on a display (e.g., the first display, etc.).
In some embodiments, the user makes the gesture while the media program is being streamed from media streaming device 102 to client device 106-1. In some embodiments, the media program is not being streamed to client device 106-1 by media streaming device 102 when the gesture is detected by client device 106-1. For example, the media program being played on client device 106-1 may be from a local media data store on, or accessible to, client device 106-1. Media streaming device 102 may stream the media program to the target device from the media data with client device 106-1 or alternatively from a different device other than the target device and client device 106-1. In some embodiments, the media program may already be available to the target device; in such a scenario, media streaming device 102 may be configured to send a playback request with the time point contemporaneous or substantially contemporaneous with the gesture, as determined by client device 106-1, to the target device to start playing the media program from that time point.
In some embodiments, the streaming request may be used to also request media streaming device 102 to stream the media program to more than one target devices and/or target displays. For example, the streaming request may cause two or more of display systems, handheld devices (e.g., intelligent phones, tablet computers, etc.), media devices, etc., to concurrently playing the media program from the time point to the user and/or multiple users.
Client device 106-1 may be playing the media program in a specific playing mode, when the user makes the gesture that triggers sending the streaming request to media streaming device 102. The streaming request sent by client device 106-1 to media streaming device 102 may be configured to include information that indicates the specific playing mode. Media streaming device 102 may be configured to inform the target device of the specific playing mode. In some embodiments, the target device is configured to accept and support the specific playing mode as specified in the streaming request. Examples of playing modes as described herein may include but are not limited to any of: one or more normal playing modes, one or more fast forward playing modes, one or more rewind playing modes, etc.
In some embodiments, one or more media devices (e.g., client device, media streaming device, multimedia device, target devices, etc.) may be configured to cooperatively support a user to control playing of a media program on target devices from a media device such as client device 106-1. Client device 106-1 from which the user controls the playing of the media program may or may not be one of the target devices which is rendering the media program presently. Client device 106-1 may be configured to detect gestures. The target devices, streaming devices, etc., may be configured to operate with user commands generated based on the gestures detected by client device 106-1. These user commands include but are not limited to streaming requests that switch the playing of the media program among the target devices, user commands that control how a media program should be played on a target device, etc. Thus, in some embodiments, a user may continue controlling the playing of a media program from a single device—even after the playing of the media program has been successfully handed off to another target device. The user may use one or more input methods relating to gesture input interfaces, graphic interfaces, menus, keypads, voice input, buttons, wheels, etc., to issue one or more user commands to a target device on which the media program is being played. For example, a user command may be sent to the target device to a media streaming device (e.g., 102), which in turn notifies the target device (e.g., 108-1) of the user command. As a result, the target device may change the playing of the media program from a current playing mode to a specific playing mode as requested by the user command. The user command may represent one of one or more user commands for changing playing modes as inputted by the user of client device 106-1 while the media program is being streamed to the target device by media streaming device 102.
The media program rendered by client device 106-1 may be encoded in a first format client device 106-1 is configured to decode before the playing of the media program is switched from client device 106-1 to the target device. The media program as received by the target device for rendering may be encoded in a second different format the second client device is configured to decode. The transcoding of media data of a media program from one or more first formats to one or more second formats may be performed by media streaming device 102 as a part of streaming the media program from one media device to another media device, as controlled by the user.
In some embodiments, after the playing of the media program is switched from client device 106-1 to a target device, client device 106-1 continues playing the media program at the client device (or a display attached therewith) while the media program is being streamed to the target device for playing at the target device. Additionally, optionally, or alternatively, client device 106-1 may play a different media program while the media program is being streamed to the target device for playing at the target device, side-loading at the target device, etc. Client device 106-1 may be configured to receive a different media program streamed from media streaming device 102 while the media program is being streamed by media streaming device 102 to the target device. Additionally, optionally, or alternatively, media streaming device 102 may be configured to stream one or more additional media programs concurrently to one or more devices (e.g., 106-1, . . . , 106-M, 108-1, . . . , 108-N, etc.) while the media program is being streamed by media streaming device 102 to the target device.
Although a specific system or system configuration is described, other embodiments are applicable to any system or system configuration that can be used to perform the functionality described herein. Components of the system or system configuration may be connected by, for example, a data bus, a data link, a Local Area Network (LAN), Wide Area Network (WAN), the Internet, Intranet, Extranet, etc. Alternatively or additionally, any number of devices within the system or system configuration may be directly connected to each other through wired or wireless communication segments.
One or more components described within system or system configuration may be combined together in a single device or divided among several operatively linked discrete devices. Each of these components is presented to clarify the functionalities described herein and may not be necessary to implement the invention. Furthermore, components not shown (in figures as described herein) may also be used to perform the functionalities described herein. Functionalities described as performed by one component may instead be performed by another component.
As used herein, media program may refer to media data containing audio content including but not limited to any of: audio data, audio transcription data, audiovisual data, multimedia data, internet downloaded content data, multimedia data with markup language pages, videos, movies, multimedia presentations, audio books, electronic books, podcasts, etc. A media data unit may refer to a data unit containing audio data including but not limited to any of: audio samples, audio transcription data that may be used for voice synthesis, audio data units, audiovisual data units, media data segments, image frames, etc. Media data may be received by a system as described herein using one or more of wire-based links or wireless links. Media data may be received in the form of a media file, a media data stream, etc. Media data may be received with any of a wide variety of formats defined by standard or proprietary specifications including but not limited to any related to CD, MPEG-1, MPEG-2, and MPEG-2.5 Audio Layer III (MP3), Advanced Audio Coding (AAC), DVD, HD DVD, Blu-ray Disc, H.261, H.263, H.264/MPEG-4, etc.
The multimedia device shown in
An MPEG-2 transport multiplex supports multiple programs in the same broadcast channel, which multiple video and audio feeds and private data. Input module 401 tunes the channel to a particular program, extracts a specified MPEG stream from the channel, and feeds the MPEG stream to the rest of the system. Analog TV signals are encoded into a similar MPEG format using separate video and audio encoders, such that the remainder of the system is unaware of how the signal was obtained. Information may be modulated into the vertical blanking interval (VBI) of the analog TV signal in a number of standard ways; for example, the North American Broadcast Teletext Standard (NABTS) may be used to modulate information onto certain lines of an NTSC signal, which the FCC mandates the use of a certain other line for closed caption (CC) and extended data services (EDS). Such signals are decoded by input module 401 and passed to the other modules as if the signals had been delivered via an MPEG-2 private data channel.
Media switch 402 mediates between a microprocessor CPU 406, a hard disk or storage device 405, and memory 404. Input streams are converted to an MPEG stream and sent to media switch 402. Media switch 402 buffers the MPEG stream into memory 404. Media switch 402 then performs two operations if a user of the multimedia device is watching real-time TV: media switch 402 sends the MPEG stream to output module 403 and simultaneously writes the MPEG stream to hard disk or storage device 405.
Output module 403 receives MPEG streams as input and produces an analog TV signal according to NTSC, PAL, or other TV standards. Output module 403 comprises an MPEG decoder, an on-screen display (OSD) generator, an analog TV encoder, and audio logic. The OSD generator allows the program logic to supply images which may be overlaid on top of the resulting TV analog signal. Additionally, output module 403 can modulate information supplied by the program logic onto the VBI of the output signal in a number of standard formats, including NABTS, CC, and EDS.
In various embodiments, one, two or more devices such as one or more of those illustrated may be singly or jointly implement at least some of the techniques as described herein.
In block 502, while a client device (e.g., 106-1) is playing a media program, the client device detects a gesture with a gesture input interface of the client device. In some embodiments, at least the portion of the media program comprises one or more tags. The gesture may comprise one or more of flick motions, hovering motions, or device motions.
In block 504, in response to detecting the gesture, the client device identifies, on the client device, a time point at which the client device stops playing the media program.
In block 506, the client device sends a streaming request to a media streaming device (e.g., 102) to stream at least a portion of the media program to a second client device (e.g., 106-2). The portion of the media program includes media content starting from the time point at which the client device stops playing the media program.
In some embodiments, the second client device may be identified among one or more client devices other than the client device by the client device, based on a direction of the gesture. The streaming request sent by the client device to the media streaming device may indicate the second client device to the streaming device.
In some embodiments, the second client device may be identified among one or more client devices other than the client device by the media streaming device. The streaming request sent by the client device to the media streaming device may not indicate the second client device to the streaming device.
In some embodiments, the media program is being streamed to the client device by the media streaming device when the gesture is detected by the client device. In some embodiments, however, the media program is not being streamed to the client device by the media streaming device when the gesture is detected by the client device.
In some embodiments, the streaming request sent by the client device to the media streaming device also requests the media streaming device to stream—concurrently or non-concurrently with streaming at least the portion of the media program to the second client device—at least the portion of the media program to a third client device other than the client device and the second client device.
In some embodiments, at the time detecting the gesture, the client device is playing the media program in a specific playing mode. The streaming request sent by the client device to the media streaming device indicates the specific playing mode, which represents one of one or more normal playing modes, one or more fast forward playing modes, one or more rewind playing modes, etc. The client device may continue to accept user commands, which may or may not be gesture-based, to control the streaming of the media program to the second client device and/or subsequent devices to which the media program is being or is to be streamed subsequent to and in connection with the streaming request. The client device can cause a user command to be sent to the second client device by way of the media streaming device. The user command can cause the second client device to operate in a second playing mode other than the specific playing mode. Here, the user command may represent one of a plurality of user commands for changing playing modes as inputted by a user of the client device while the media program is being streamed to the second client device.
In some embodiments, the media program rendered by the client device is encoded in a first format the client device is configured to decode. At least the portion of the media program as received by the second client device for rendering may be transcoded by the client device or the media streaming device into a second different format the second client device is configured to decode.
In some embodiments, the client device is one of tablet computers, handheld devices, laptops, e-readers, personal computing devices, game devices, or display systems, whereas the second device is a different one of tablet computers, handheld devices, laptops, e-readers, personal computing devices, game devices, or display systems.
In some embodiments, a network connection among, the client device, the streaming device and the second client device comprises at least one wireless network link.
In some embodiments, the client device continues playing the media program while the media program is being streamed from the multimedia device to the second client device. In some embodiments, the client device plays a different media program while the media program is being streamed from the multimedia device to the second client device. The client device may receive a different media program streamed from the media streaming device while the media program is being streamed from the multimedia device to the second client device.
In some embodiments, the media streaming device streams one or more additional media programs concurrently to one or more client devices while the media program is being streamed from the multimedia device to the second client device.
Embodiments include an apparatus comprising a processor and configured to perform any one of the foregoing methods. Embodiments include a computer readable storage medium, storing software instructions, which when executed by one or more processors cause performance of any one of the foregoing methods.
Note that, although separate embodiments are discussed herein, any combination of embodiments and/or partial embodiments discussed herein may be combined to form further embodiments.
Computer system 600 may be coupled via bus 602 to a display 612, such as a cathode ray tube (CRT) or a liquid crystal display (LCD), for displaying information to a computer user. An input device 614, including alphanumeric and other keys, is coupled to bus 602 for communicating information and command selections to processor 604. Another type of user input device is cursor control 616, such as a mouse, a trackball, or cursor direction keys for communicating direction information and command selections to processor 604 and for controlling cursor movement on display 612. This input device typically has two degrees of freedom in two axes, a first axis (e.g., x) and a second axis (e.g., y), that allows the device to specify positions in a plane.
The invention is related to the use of computer system 600 for a window configuration unit. According to one embodiment of the invention, the window configuration unit is provided by computer system 600 in response to processor 604 executing one or more sequences of one or more instructions contained in main memory 606. Such instructions may be read into main memory 606 from another computer-readable medium, such as storage device 610. Execution of the sequences of instructions contained in main memory 606 causes processor 604 to perform the process steps described herein. One or more processors in a multi-processing arrangement may also be employed to execute the sequences of instructions contained in main memory 606. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions to implement the invention. Thus, embodiments of the invention are not limited to any specific combination of hardware circuitry and software.
The term “computer-readable medium” as used herein refers to any medium that participates in providing instructions to processor 604 for execution. Such a medium may take many forms, including but not limited to, non-volatile media, volatile media, and transmission media. Non-volatile media includes, for example, optical or magnetic disks, such as storage device 610. Volatile media includes dynamic memory, such as main memory 606. Transmission media includes coaxial cables, copper wire and fiber optics, including the wires that comprise bus 602. Transmission media can also take the form of acoustic or light waves, such as those generated during radio wave and infrared data communications.
Common forms of computer-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, a RAM, a PROM, and EPROM, a FLASH-EPROM, any other memory chip or cartridge, a carrier wave as described hereinafter, or any other medium from which a computer can read.
Various forms of computer readable media may be involved in carrying one or more sequences of one or more instructions to processor 604 for execution. For example, the instructions may initially be carried on a magnetic disk of a remote computer. The remote computer can load the instructions into its dynamic memory and send the instructions over a telephone line using a modem. A modem local to computer system 600 can receive the data on the telephone line and use an infrared transmitter to convert the data to an infrared signal. An infrared detector coupled to bus 602 can receive the data carried in the infrared signal and place the data on bus 602. Bus 602 carries the data to main memory 606, from which processor 604 retrieves and executes the instructions. The instructions received by main memory 606 may optionally be stored on storage device 610 either before or after execution by processor 604.
Computer system 600 also includes a communication interface 618 coupled to bus 602. Communication interface 618 provides a two-way data communication coupling to a network link 620 that is connected to a local network 622. For example, communication interface 618 may be an integrated services digital network (ISDN) card or a modem to provide a data communication connection to a corresponding type of telephone line. As another example, communication interface 618 may be a local area network (LAN) card to provide a data communication connection to a compatible LAN. Wireless links may also be implemented. In any such implementation, communication interface 618 sends and receives electrical, electromagnetic or optical signals that carry digital data streams representing various types of information.
Network link 620 typically provides data communication through one or more networks to other data devices. For example, network link 620 may provide a connection through local network 622 to a host computer 624 or to data equipment operated by an Internet Service Provider (ISP) 626. ISP 626 in turn provides data communication services through the worldwide packet data communication network now commonly referred to as the “Internet” 628. Local network 622 and Internet 628 both use electrical, electromagnetic or optical signals that carry digital data streams. The signals through the various networks and the signals on network link 620 and through communication interface 618, which carry the digital data to and from computer system 600, are exemplary forms of carrier waves transporting the information.
Computer system 600 can send messages and receive data, including program code, through the network(s), network link 620 and communication interface 618. In the Internet example, a server 630 might transmit a requested code for an application program through Internet 628, ISP 626, local network 622 and communication interface 618. In accordance with the invention, one such downloaded application provides for a remote display device as described herein.
The received code may be executed by processor 604 as it is received, and/or stored in storage device 610, or other non-volatile storage for later execution. In this manner, computer system 600 may obtain application code in the form of a carrier wave.
Although specific components are recited herein as performing the method steps, in other embodiments agents or mechanisms acting on behalf of the specified components may perform the method steps. Further, although some aspects of the invention are discussed with respect to components on a system, the invention may be implemented with components distributed over multiple systems. Embodiments of the invention also include any system that includes the means for performing the method steps described herein. Embodiments of the invention also include a computer readable medium with instructions, which when executed, cause the method steps described herein to be performed.
In the foregoing specification, embodiments of the invention have been described with reference to numerous specific details that may vary from implementation to implementation. Thus, the sole and exclusive indicator of what is the invention, and is intended by the applicants to be the invention, is the set of claims that issue from this application, in the specific form in which such claims issue, including any subsequent correction. Any definitions expressly set forth herein for terms contained in such claims shall govern the meaning of such terms as used in the claims. Hence, no limitation, element, property, feature, advantage or characteristic that is not expressly recited in a claim should limit the scope of such claim in any way. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.
This application claims priority of Provisional Application Ser. No. 61/777,981, filed Mar. 12, 2013, the entire contents of which are hereby incorporated by reference as if fully set forth herein, under 35 U.S.C. §120. This application is related to Provisional U.S. Patent Application No. 61/696,747 filed on Sep. 4, 2012 (with Attorney Docket No. 60097-0924), which is hereby incorporated herein by reference for all purposes as if fully set forth herein.
Number | Date | Country | |
---|---|---|---|
61777981 | Mar 2013 | US |