Television viewers frequently engage in “channel surfing”, which is the process of quickly scanning through different television channels to find content of interest. Channel surfing live television can result in a user stumbling across a “hook” (e.g., a scene of interest) in television content that grabs the user's attention and prompts the user to continue watching. One problem with channel surfing is that the user may skip a channel currently showing a commercial during a program in which the user may have interest. The user may also skip a channel having content of interest if a show on that channel is currently at a scene that does not grab the user's attention, even though the user may enjoy the overall show.
In contrast to live television, when users browse video on-demand (VOD) content using an On-demand Service (e.g., Netflix®, Play®, HBO®), the users are generally required to rely on arbitrary factors, such as cover art, ratings, a description, and other metadata to decide whether to watch a particular movie or show. Because the number of available movies and shows is so great, users are subjected to the paradox of choice, which results in many users spending greater amounts of time browsing than actually watching a show because they are unsure as to what exactly they want to watch.
These problems are time consuming to users, and in many cases can lead to user frustration. To avoid choosing a video that the user may not enjoy, users frequently spend extended amounts of time browsing information about various shows rather than actually watching a show.
This background description is provided for the purpose of generally presenting the context of the disclosure. Unless otherwise indicated herein, material described in this section is neither expressly nor impliedly admitted to be prior art to the present disclosure or the appended claims.
Apparatuses of and techniques using methodologies for on-demand video surfing are described with reference to the following drawings. The same numbers are used throughout the drawings to reference like features and components:
Conventional techniques that allow users to channel surf through video on-demand (VOD) content are inefficient at least because users may only rely on descriptive text that fails to accurately portray content in a video. This form of content browsing to find content of interest is time consuming, and users frequently spend more time browsing the descriptive text than actually viewing content of interest.
The methodologies for on-demand video surfing described herein improve navigation for VOD content by using a search query specifying types of scenes (e.g., hooks), which increases a likelihood of catching the user's attention. Further, when resultant videos are provided to a client device, the videos are time-shifted according to the hooks. For instance, a server can stream a time-shifted video to the client device beginning at a particular scene, or the server can transmit a mark to the client device indicating a location of the scene in the video to enable the client device to jump directly to the scene when the video is played.
In this way, the user can surf through the videos in a manner similar to channel surfing television channels, but with the client device navigating directly to scenes of the specified type in each video based on the search query. This avoids browsing certain moments in the videos that have a low likelihood of catching the user's attention, and allows the user to surf through purposefully chosen moments in the videos. Further, these techniques reduce time spent browsing for content of interest or time spent surfing through on-demand content in comparison to conventional techniques. These techniques further allow playback of any of the videos to automatically continue through to the end of the video or, based on a user input, restart at a beginning of the video.
As used herein, the term “hook” may refer to a scene designed to catch a user's attention. For example, an action movie can include scenes with thrilling action, such as explosions or car chases, that grab a user's interest and prompt the user to continue watching. Movie trailers frequently use hooks or portions of hooks that show users a very dramatic or exciting moment in the movie in an attempt to encourage the users to watch a particular movie. The hook can be chosen by a service provider or studio, or can be selected based on one or more factors, such as spikes on social media while the video aired, extracted clips uploaded to a content sharing website (e.g., Youtube®), crowd volume in a live sporting event, and so on. Accordingly, a hook can include a wide variety of hooks designed to grab the user's attention, and can be selected based on audience interaction or feedback.
As used herein, the term “time-shift” refers to playing a video at a time other than time zero (e.g., a beginning of the video). Time-shifting can be performed in a variety of different ways. Some examples include: streaming a video to a client device beginning at a location that is not at time zero of the video, identifying a mark associated with the video that is usable to skip to a specified location in the video, or identifying a location in the video that is not at time zero and which indicates a beginning of a portion of the video that is transmittable to the client device for playback. Other examples are also contemplated, and are discussed in further detail below. Accordingly, the term “time-shift” can refer to a variety of different ways to cause a video to be initiated for playback at a time other than time zero.
The following discussion first describes an operating environment, followed by techniques and procedures that may be employed in this environment. This discussion continues with an example electronic device in which methodologies for on-demand video surfing can be embodied.
Computing devices that are used to implement the service provider 104 or the video-rendering device 102 may be configured in a variety of ways. Computing devices, for example, may be configured as a desktop computer, a laptop computer, a mobile device (e.g., assuming a handheld configuration such as a tablet or mobile phone), and so forth. Additionally, a computing device may be representative of a plurality of different devices, such as multiple servers of the service provider 104 utilized by a business to perform operations “over the cloud” as further described in relation to
The service provider 104 is representative of functionality to distribute media content 108 obtained from one or more content providers 110. Generally speaking, the service provider 104 is configured to make various resources 112 available over the network 106 to clients, such as the video-rendering device 102. In the illustrated example, the resources 112 can include program content or VOD content that has been processed by a content controller module 114(a). In some implementations, the content controller module 114(a) can authenticate a user to access a user account that is associated with permissions for accessing corresponding resources, such as particular television stations or channels, from a provider. The authentication can be performed using credentials (e.g., user name and password) before access is granted to the user account and corresponding resources 112. Other resources 112 may be available without authentication or account-based access. The resources 112 can include any suitable combination of services and/or content typically made available over a network by one or more providers. Some examples of services include, but are not limited to: a content publisher service that distributes content, such as streaming videos and the like, to various computing devices, an advertising server service that provides advertisements to be used in connection with distributed content, and so forth. Content may include various combinations of assets, video comprising part of an asset, advertisements, audio, multi-media streams, animations, images, television program content such as television content streams, applications, device applications, and the like.
The content controller module 114(a) is further configured to manage content requested by the video-rendering device 102. For instance, the video-rendering device 102 can receive a search query from a user, and transmit the search query to the service provider 104 to search for a particular genre of movie. The content controller module 114(a) represents functionality to perform a search for media content matching search criteria of the search query. Then, results of the search can be communicated to the video-rendering device 102 to enable the user of the video-rendering device 102 to view media content matching the search criteria. As is discussed in more detail below, the content controller module 114(a) is configured to identify specific scenes in the resultant media content, and time-shift the results according to the specific scenes matching the search criteria to enable the computing device to navigate between the videos from specific scene to specific scene.
The content provider 110 provides the media content 108 that can be processed by the service provider 104 and subsequently distributed to and consumed by end-users of computing devices, such as video-rendering device 102. Media content 108 provided by the content provider 110 can include streaming media via one or more channels, such as one or more programs, on-demand videos, movies, and so on.
Although the network 106 is illustrated as the Internet, the network may assume a wide variety of configurations. For example, the network 106 may include a wide-area-network (WAN), a local-area-network (LAN), a wireless network, a public telephone network, an intranet, and so on. Further, although a single network 106 is shown, the network 106 may be representative of multiple networks. Thus, a variety of different networks 106 can be utilized to implement the techniques described herein.
The video-rendering device 102 is illustrated as including a communication module 116, a display module 118, and a content manager module 114(b). The communication module 116 is configured to communicate with the service provider 104 to request particular resources 112 and/or media content 108. The display module 118 is configured to utilize a renderer to display media content via a display device 120. The communication module 116 receives the media content 108 from the service provider 104, and processes the media content 108 for display.
The content manager module 114(b) represents an instance of the content manager module 114(a). The content manager module 114(b) is configured to manage local media content based on search queries received at the video-rendering device 102. For example, the content management module 114(a) represents functionality to perform a search for local media content that matches search criteria of the search query. Then, results of the search can be presented to the user via the display device 120 of the video-rendering device 102 to enable the user of the video-rendering device 102 to view local media content matching the search criteria. As is discussed in more detail below, the content controller module 114(b) is configured to identify specific scenes in the local media content based on the search query, and time-shift the results according to the specific scenes to enable navigation between the results from specific scene to specific scene.
Having generally described an environment in which methodologies for on-demand video surfing may be implemented, this discussion now turns to
The video-rendering device 102 also includes I/O ports 210 and network interfaces 212. I/O ports 210 can include a variety of ports, such as by way of example and not limitation, high-definition multimedia interface (HDMI), digital video interface (DVI), display port, fiber-optic or light-based, audio ports (e.g., analog, optical, or digital), USB ports, serial advanced technology attachment (SATA) ports, peripheral component interconnect (PCI) express based ports or card slots, serial ports, parallel ports, or other legacy ports. The video-rendering device 102 may also include the network interface(s) 212 for communicating data over wired, wireless, or optical networks. By way of example and not limitation, the network interface 212 may communicate data over a local-area-network (LAN), a wireless local-area-network (WLAN), a personal-area-network (PAN), a wide-area-network (WAN), an intranet, the Internet, a peer-to-peer network, point-to-point network, a mesh network, and the like.
Having described the video-rendering device 102 of
In the example implementation 300, a search has been performed to identify multiple on-demand videos each having a scene corresponding to search criteria of a search query. One or more identified videos are provided as a content stream. For example, a first stream includes video 302, a second stream includes video 304, another stream includes video 306, and yet another stream includes video 308. Any number of videos can be provided as content streams. Because the videos are provided as content streams, the user can navigate (vertically in the illustrated example) between the videos.
Each of the identified videos includes a particular scene (e.g., hook) that matches the search criteria of the search query. For example, video 302 includes scene 310 represented by hash marks that identify a beginning and an ending of the scene. In addition, video 304 includes scene 312, video 306 includes scene 314, and so forth. The identified scenes 310, 312, 314 include a similar type of content but differ in actual content. Further, the identified scenes 310, 312, 314 can include different durations of time and can be located at different times in the videos 302, 304, 306, respectively, in comparison to one another. For example, scene 314 has a longer relative time duration than scenes 310, 312, and scene 312 has the shortest relative time duration among the scenes 310, 312, 314. In another example, the scene 310 may begin at time 10:32 while the scene 312 begins at time 13:17 and the scene 314 begins at time 11:40. Some scenes may be located near the beginning of a respective video while other scenes are located near the end of the respective video. Accordingly, each scene can be located at any of a variety of locations within the respective video.
Initially, the videos are aligned based on a beginning of each video, such as at alignment point 316, which is set at time zero for each video. Allowing the user to navigate between the streams at this point would result in navigating to the beginning (e.g., time zero) of each video. One problem with this is that the first several minutes of many movies generally includes information related to a production company, titles, logos, opening credits, and so on. None of this information, however, is likely to be a hook, particularly a hook corresponding to the search criteria.
In at least one implementation, the content management module 114 is configured to realign the videos in the content streams based on the identified hooks. In the illustrated example, the on-demand content (e.g., videos 302, 304, 306) is time-shifted and aligned based on the identified hooks (e.g., scenes 310, 312, 314). Because the videos include different content, the videos are aligned at alignment point 318, which is at different times in each video. The alignment point 318 allows navigation to particular moments in each video. For example, video 302 is aligned to scene 310, video 304 is aligned to scene 312, video 306 is aligned to scene 314, and so on.
In another example implementation, the identified videos can include video identities (IDs) that are provided to the client device. Then, a user input via the client device can select a video ID to request that a corresponding video begin streaming for display at the client device. Alternatively, the service provider 104 can provide a corresponding video file to the client device based on the selected video ID. In at least one example, a portion of the video file beginning at the scene is sent to the client device for playback. Alternatively, an entire video file can be sent to the client device along with a mark specifying a location (e.g., alignment point 318) of the scene in the video file. The client device can then use the mark to jump directly to the scene corresponding to the search criteria.
In implementations, video 302 is selected to initiate playback. Rather than playing the video 302 at the beginning (e.g., time zero), the video 302 automatically begins playing at scene 310. If the user desires to browse to a next video, the video-rendering device 102 can navigate (e.g., navigation 320) to the next stream and begin playback of the video 304 directly at scene 312. Accordingly, the techniques described herein for on-demand video surfing allow navigation 320 directly to a hook in each video. Although navigation 320 is illustrated in a single direction, the video-rendering device 102 can also navigate in the reverse direction, jump to a particular video, skip a video, return to a previous video, or any combination thereof. Accordingly, the navigation 320 is not limited to a unidirectional navigation.
Further, playback of each video is not limited to playback of the identified scene (e.g., hook). For example, rather than playing the hook in a first video and then automatically jumping to a next video's hook, the playback of the first video automatically continues after the hook is completed. In the illustrated example, assume the user enjoys the scene 314 of the video 306 such that the user desires to continue viewing the video 306. In this case, the playback of the video 306 automatically continues after reaching the end of the scene 314 to play back a remaining portion of the video subsequent to the scene, as is represented by arrow 322. In addition, subsequent to the playback being initiated and responsive to a user selection of a user interface instrumentality, the video-rendering device 102 can navigate to time zero of the video 306 to view the video 306 from the beginning. Also, at any time during the playback of the video 306, the user can navigate to the hook in a video of the next stream.
In implementations, the content management module 114 can generate multiple streams corresponding to the video 502, where an instance of the video 502 in each stream is time-shifted according to a different hook. In the illustrated example, the video 502 is provided in three separate streams based on the three identified scenes 504, 506, 508. A first stream is provided that includes an instance of the video 502 time-shifted based on the scene 504, a second stream is provided that includes an instance of the video 502 time-shifted based on the scene 506, and a third stream is provided that includes an instance of the video 502 time-shifted based on scene 506. This enables navigation between the scenes 504, 506, 508 from the same video 502. This further enables playback to continue after any of the scenes 504, 506, 508, rather than automatically navigating to or playing back a next hook. In implementations, navigation to a next hook is responsive to a user navigation input.
In at least one implementation, the video 502 can include multiple marks that indicate a respective location of each scene 504, 506, 508. These marks can be provided to the client device to enable the client device to jump to locations associated with one or more of the scenes 504, 506, 508. Thus, the client device can initiate playback of the video 502 at any of the scenes 504, 506, 508, and navigate between the scenes 504, 506, 508 in the video 502. From the user perspective, the client device simply skips to specific scenes in the video 502 that correspond to the search query.
At some point after scene 312, the user becomes disinterested in the video 304 and decides to navigate to another video. Thus, a user input is received at time 608, and the video-rendering device 102 navigates (e.g., arrow 610) to scene 314 of video 306. Accordingly, navigation between the streams can occur at any point in time, and there is no minimum or maximum time required for viewing before navigation is allowed. Further, as illustrated by arrow 610, navigation can skip one or more streams, and is not limited to sequential or linear navigation in a list of streams. In the illustrated example, the user becomes interested in video 306 based on scene 314 and allows playback to continue after the scene 314. Accordingly, playback 612 of the video 306 continues until the end of the video 306, or until receiving a user input that initiates navigation to yet another stream or otherwise ceases playback 612 of the video 306.
Using the techniques described herein, users can easily and efficiently navigate directly to specific types of hooks in on-demand videos, based on a user-generated search query. At least some of the on-demand videos can be accessible via an on-demand service or local storage. Browsing the hooks of the videos enables the user to more easily decide which video to continue watching than by using conventional techniques, at least because the user can immediately view specific parts of the videos that are most likely to grab his attention.
The following discussion describes methods by which techniques are implemented to enable use of methodologies for on-demand video surfing. These methods can be implemented utilizing the previously described environment and example systems, devices, and implementations, such as shown in
At 704, on-demand content is searched based on search criteria associated with the search query to identify videos having at least one scene corresponding to the search criteria. For example, the service provider 104 searches the on-demand content based on the search query. Video image recognition techniques can be used to identify and label scenes in the on-demand content. In implementations, metadata associated with the on-demand content can include information identifying different scenes according to different scene type based on events occurring in these scenes. The video-rendering device 102 or the service provider 104 can search the metadata and/or the on-demand content to locate videos matching the search criteria.
At 706, video identities (IDs) corresponding to the identified videos, the identified videos, or portions of the identified videos are provided to the video-rendering device. For example, the service provider 104 can provide IDs to enable the video-rendering device 102 to select one or more of the videos for playback, such as via a content stream. In implementations, the service provider 104 can also provide an indication (e.g., mark) that specifies a location of the scene in a video that corresponds to the search criteria. A separate indication can be provided for each video identified based on the search. The indication is configured to enable the client device to jump directly to the location of the scene in the video when the video is selected for playback. In at least one implementation, the service provider 104 provides the video IDs to the video-rendering device 102, which allows the service provider 104 to provide a particular video responsive to a user input selecting a corresponding video ID.
At 708, responsive to a user input selecting a video ID associated with one of the videos, the video-rendering device is caused to play the video at the scene. In implementations, the service provider 104 can begin streaming the video to the video-rendering device 102 beginning at the scene. In other implementations, the service provider 104 can provide the video to the video-rendering device 102 to allow the video-rendering device 102 to skip directly to the scene by using the mark and play the video at the scene.
Optionally at 710, a remaining portion of the video that is subsequent to the scene is automatically streamed in response to completion of playback of the scene. By continuing streaming the video, the service provider 104 can cause the video-rendering device 102 to play the remaining portion of the video without interruption. In this way, a user of the video-rendering device 102 is not limited to watching only the scene, but can continue watching the video past the end of the scene.
Optionally at 712, an additional selection of an additional video ID associated with an additional video is received. For instance, during playback of a first video, a user of the video-rendering device 102 decides to navigate to another video, and thus selects a second video ID via a user interface at the video-rendering device 102. This selection of the second video ID is received at the service provider 104 for processing.
At 714, the video-rendering device is caused to play the additional video at the scene corresponding to the search criteria in response to the additional selection. For instance, the service provider 104 can provide a second video to the video-rendering device 102 via a separate content stream from the first video. Alternatively, the service provider 104 can provide the second video to the video-rendering device 102 along with a mark that identifies the location of the scene in the second video that matches the search criteria. Providing this information enables the video-rendering device 102 to skip to the scene in the second video when playing the second video.
At 806, one or more of the videos are received at the client device. For instance, the videos can be received via a content stream. In implementations, the videos can be time-shifted such that the videos are playable directly at the scene corresponding to the search criteria in each video. For example, if the search query was for explosions, then the videos are aligned to each scene having an explosion. Then, when the user navigates to a particular video, the scene with the explosion is presented, rather than the beginning of the video. Alternatively, at least a portion of the videos can be downloaded at the client device to enable the client device to play a portion of a video beginning at the scene. In yet other embodiments, a mark associated with a respective video is received that indicates a location of the scene in the respective video. This mark is usable by the client device to jump directly to the specific location of the scene in the video.
At 808, a selected video is played at the scene corresponding to the search criteria in response to a user input selecting the video. For instance, a user can select one of the videos via a user interface of the client device, such as via a list, an icon, an image, or object. The client device begins playing the video at the scene by using the mark to jump directly to the location of the scene in the video. Alternatively, the client device can receive the selected video as streaming content that begins at the location of the scene.
Optionally at 810, a remaining portion of the selected video subsequent to the scene is automatically played in response to playback of the video reaching an end of the scene. For instance, playback of the video is not limited to the scene only, but the client device can continue playing the video past the end of the scene and through to the end of the video. Optionally at 812, an additional user input is received that selects an additional video. For instance, a user may select a different video ID via the user interface to initiate playback of a different video. At 814, the selected different video is played at the scene corresponding to the search criteria in response to receiving the additional user input. In this way, the user can surf through a variety of different on-demand videos at scenes corresponding to the user-generated search query, and can allow any of the videos to continue playing past the end of the scene and through to the end of the video or play a selected video from the beginning.
These methodologies allow a user to surf through different on-demand videos in an easy and efficient manner Using these techniques, the user can preview purposefully chosen scenes in each video that are likely to grab the user's attention, rather than simply read a description of the video, or view a movie trailer of the video. Furthermore, those purposefully chosen scenes are based on a user-generated search query, which represents the user specifying the type of hook that he is interested in at that moment in time. Additionally, playback of the video is not limited to those particular scenes, but the playback can continue through the end of the video. Moreover, surfing through the on-demand content in this way allows the user to essential assess a production quality of the video based on the viewed scene. Accordingly, these methodologies and techniques provide a variety of functionalities that improve conventional techniques used to navigate on-demand content.
Electronic device 900 includes communication transceivers 902 that enable wired and/or wireless communication of device data 904, such as received data, transmitted data, or sensor data as described above. Example communication transceivers include NFC transceivers, WPAN radios compliant with various IEEE 902.15 (Bluetooth™) standards, WLAN radios compliant with any of the various IEEE 902.11 (WiFi™) standards, WWAN (3GPP-compliant) radios for cellular telephony, wireless metropolitan area network (WMAN) radios compliant with various IEEE 902.16 (WiMAX™) standards, and wired local-area-network (LAN) Ethernet transceivers.
Electronic device 900 may also include one or more data input ports 906 via which any type of data, media content, and/or inputs can be received, such as user-selectable inputs, messages, music, television content, recorded video content, and any other type of audio, video, and/or image data received from any content and/or data source (e.g., other video devices). Data input ports 906 may include USB ports, coaxial cable ports, and other serial or parallel connectors (including internal connectors) for flash memory, DVDs, CDs, and the like. These data input ports may be used to couple the electronic device to components (e.g., image sensor 102), peripherals, or accessories such as keyboards, microphones, or cameras.
Electronic device 900 of this example includes processor system 908 (e.g., any of application processors, microprocessors, digital-signal-processors, controllers, and the like), or a processor and memory system (e.g., implemented in a SoC), which process (i.e., execute) computer-executable instructions to control operation of the device. Processor system 908 may be implemented as an application processor, embedded controller, microcontroller, and the like. A processing system may be implemented at least partially in hardware, which can include components of an integrated circuit or on-chip system, digital-signal processor (DSP), application-specific integrated circuit (ASIC), field-programmable gate array (FPGA), a complex programmable logic device (CPLD), and other implementations in silicon and/or other hardware.
Alternatively or in addition, electronic device 900 can be implemented with any one or combination of software, hardware, firmware, or fixed logic circuitry that is implemented in connection with processing and control circuits, which are generally identified at 910 (processing and control 910).
Although not shown, electronic device 900 can include a system bus, crossbar, or data transfer system that couples the various components within the device. A system bus can include any one or combination of different bus structures, such as a memory bus or memory controller, a peripheral bus, a universal serial bus, and/or a processor or local bus that utilizes any of a variety of bus architectures.
Electronic device 900 also includes one or more memory devices 912 that enable data storage, examples of which include random access memory (RAM), non-volatile memory (e.g., read-only memory (ROM), flash memory, EPROM, EEPROM, etc.), and a disk storage device. Memory device(s) 912 provide data storage mechanisms to store the device data 904, other types of information and/or data, and various device applications 920 (e.g., software applications). For example, operating system 914 can be maintained as software instructions within memory device 912 and executed by processors (e.g., processor system 908). In some aspects, content management module 114 is embodied in memory devices 912 of electronic device 900 as executable instructions or code. Although represented as a software implementation, content management module 114 may be implemented as any form of a control application, software application, signal-processing and control module, or hardware or firmware installed on the electronic device 900.
Electronic device 900 also includes audio and/or video processing system 916 that processes audio data and/or passes through the audio and video data to audio system 918 and/or to display system 922 (e.g., a screen of a smart phone or camera). Audio system 918 and/or display system 922 may include any devices that process, display, and/or otherwise render audio, video, display, and/or image data. Display data and audio signals can be communicated to an audio component and/or to a display component via an RF (radio frequency) link, S-video link, HDMI (high-definition multimedia interface), composite video link, component video link, DVI (digital video interface), analog audio connection, or other similar communication link, such as media data port 924. In some implementations, audio system 918 and/or display system 922 are external components to electronic device 900. Alternatively or additionally, display system 922 can be an integrated component of the example electronic device, such as part of an integrated touch interface.
Although embodiment of methodologies for on-demand video surfing have been described in language specific to features and/or methods, the subject of the appended claims is not necessarily limited to the specific features or methods described. Rather, the specific features and methods are disclosed as example implementations of on-demand video surfing.