The technology described herein relates to systems and methods for providing bookmarking data in set-top boxes or other types of client devices.
Set-top boxes or other types of client devices may be generally configured to store or access media content such as recorded video content or buffered content. It is desirable for there to be a mechanism for accessing the media content at specific points within the recorded video content. Furthermore, it is desirable for there to be a mechanism for selecting media content at specific points in a manner that is convenient for the user and in a manner that conveys information about the media content to be selected. Presently available systems do not provide such functionality. Instead, content can only be accessed at the beginning thereof or at a point of time identified by a user using a fast-forward/fixed increment jump/rewind functionality, random access or otherwise.
The information included in this Background section of the specification, including any references cited herein and any description or discussion thereof, is included for technical reference purposes only and is not to be regarded as subject matter by which the scope of the invention as defined in the claims is to be bound.
In one respect, the various embodiments of the present disclosure are directed to systems and methods for presenting media content, including receiving bookmarking data at a client device from a data processing and aggregating server, the bookmarking data referencing a specific point in a media content item that is playable directly or indirectly from the client device; providing a first output signal based on the bookmarking data from the client device to a display device, the output signal causing the display device to display at least one bookmark that includes at least a user-selectable portion and a descriptive portion; receiving an input signal at the client device from a user input device, the input signal indicating a user selection of a bookmark displayed by the display device; and providing a second output signal from the client device to the display device responsive to the input signal, the second output signal causing the display device to display a media content item at a specific point specified by the bookmarking data.
In some implementations, the first output signal causes the display device to display a list of selectable bookmarks. Such list may include a title and length for each of the one or more bookmarks.
In some implementations, a second output signal may be generated which instructs and/or causes the display device to additionally display the selected bookmark over a current playback position in a progress bar including the title and length for the selected bookmark.
In some implementations, the first output signal instructs and/or causes the display device to display a list of bookmarks with titles and start and stop times for each of the bookmarks.
In some implementations, the second output signal instructs and/or causes the display device to additionally display the selected bookmark over a current playback position in a progress bar including the title and start and stop times for the selected bookmark.
In some implementations, the first output signal instructs and/or causes the display device to display a list of bookmarks with titles and at least one category indicator for each of the bookmarks.
In some implementations, the second output signal causes the display device to additionally display the selected bookmark over a current playback position in a progress bar including the title and category for the selected bookmark.
In some implementations, the first output signal instructs and/or causes the display device to display a popup overlay on a gird of digital video recorder (“DVR”) items, the popup overlay may include a button that when selected instructs and/or causes the display device to generate and display a second overlay, the second overlay having one or more selectable bookmarks.
In some implementations, the selectable bookmarks of the second overlay are arranged in a single column.
In some implementations, the selectable bookmarks of the second overlay are arranged in two adjacent columns.
In some implementations, the first output signal instructs and/or causes the display device to display a menu of bookmarks alongside a video output of the corresponding media content, each bookmark in the menu including a list of descriptors for the bookmark.
In some implementations, the second output signal instructs and/or causes the display device to additionally display the selected bookmark over a current playback position in a progress bar including the list of descriptors for the bookmark.
In some implementations, the media content item is a commercial and the second output signal causes the media content item to skip to the beginning of the commercial.
In some implementations, the media content item is a commercial and the second output signal causes the media content item to skip to the end of the commercial.
In some implementations, the second output signal is provided responsive to user input.
In some implementations, the second output signal is automatically provided responsive to a commercial skipping setting.
In some implementations, the bookmarking data specifies a location of age restricted content within the media content item.
In another respect, at least one implementation of the present disclosure is directed to a method of processing a request for bookmarking data, including receiving a request for bookmark data from client device; requesting information from one or more data sources to fulfill the request for bookmark data; receiving one or more replies from those data sources responding to the request for information; processing the one or more responses received from the one or more sources to generate the bookmark data; and transmitting the bookmark data to the client device responsive to the request.
Some implementations further include determining if the data, all or in part, needed for fulfilling the request has been received from the data sources; and repeating the operations of determining and requesting information until the information needed for generating the requested bookmark has been received.
Some implementations further include, prior to the operation of requesting information from one or more data sources, determining what information is needed to fulfill the request for bookmark data.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter or to be used to limit the scope of the claimed subject matter. A more extensive presentation of features, details, utilities, and advantages of the various embodiments described herein and of the present invention, as defined in the claims presently or hereafter pending, is provided in the following written description of various embodiments of this disclosure and illustrated in the accompanying drawings.
As depicted in
As used herein, “bookmarking data” means data that specifies a location of a particular point or content segment within a given media program that may be received, played and/or otherwise presented at the client device 104 or via the client device 104, for example, via a directly or indirectly connected presentation device. For example, the media program may be a movie that is scheduled to be shown at a particular time by a particular content provider. In this example, the bookmarking data may include specific times for particular points in the movie, such as, the start of the movie, a particular scene in the movie, commercial breaks that will occur during the movie, the end of the movie, and so on. The client device 104 may be configured to use the bookmarking data to take certain actions, such as recording the entire media program, recording parts of the media program, deleting certain content segments from a recorded program, skipping certain content segments during playback of a media program, and so on. These types of bookmarking data and use of bookmarking data are provided by way of example and not by means of limitation. Additional examples of bookmarking data and uses of bookmarking data in accordance with this disclosure are discussed in greater detail below.
The client device 104 is generally configured to receive media content from a content source. In some embodiments, the client device 104 may be implemented as a set-top box (STB) or other device that is specifically configured to receive content from a service provider. The STB may be limited to receiving content from only specified service providers or, as the case may be, from any number of service providers. For example, in other embodiments, client device 104 may be a more general-purpose computing device such as a desktop computer, laptop computer, tablet computer or mobile device. As depicted in
Data processing and aggregating server 108 is generally configured as a computing device that receives information regarding one or more media content from one or more data sources and generates bookmarks for the client device 104. In at least one implementation, the server 108 generates a modified list of viewer measurement (VM) based data for the client device 104. In at least one implementation, server 108 generates timers for the client device 104. The server 108 may be implemented on one or more virtual and/or physical servers that are configured for processing and aggregating data for use in providing bookmarks. In other implementations, the server 108 may be implemented as a cloud-based device or other similar arrangement. The server 108 may also exist as a processing unit on the client device 104 or within an application running thereon.
The data processing and aggregating server 108 may be provided in association with and/or in communication with one or more information sources 112 that the server 108 may query, in advance or at the time of a request for information in connection with a request for bookmarking data. For instance, the server 108 may be provided in association with, communicatively coupled to or otherwise capable of accessing a user profile information source 124. The server 108 may connect to the user profile information source 124 and receive demographic, psychographic, preferences and/or other information about the user such as name, likes, dislikes, favorites, favorite teams, favorite events, favorite actors, programming packages, Pay-Per-View (PPV) events, Video-On-Demand (VOD), etc. The server 108 may also connect to a user STB information source 128 and receive information about the user's STB or other client device 104. Such information may include system time, device diagnostics, software version, serial numbers, firmware information, etc. The server 108 may also be provided in association with viewer measurement information source 132 that provides statistics or similar data on the viewing habits of one or more users. Generally, the server 108 may connect to any appropriate information source that provides relevant information, including a miscellaneous database 136 that may be used to provide personalized information about the user and/or the user's device.
The data processing and aggregating server 108 may also be provided in association with one or more data feeds 116 from which the server 108 receives information usable for responding to a request for bookmarking or other data. In some cases, the server 108 may receive a request for bookmarking data from one or more of the data feeds 116. The server 108 may receive information from various data feeds for generating bookmarks. Examples of data feeds include (but are not limited to): identifying commercials, identifying topics in recorded or streamed content, categories of bookmarks, start and stop time of bookmarks, category of bookmarks, timing info, trending events and keywords, video clips, alternate audio/video feed etc. The server 108 may receive information from various data feeds for generating commercial identification related bookmarks. Examples of data feeds include (but are not limited to): identifying commercials, categories of commercials, start and stop times of commercials, timing info, trending events and keywords, video clips, alternate audio/video feeds etc. The server 108 may receive information from various data feeds for modifying the VM based list. Examples of data feeds include (but are not limited to): identifying commercials, identifying topics in a recorded or streamed content, trending events and keywords, category of bookmarks, timing info, video clips, alternate audio/video feed etc. The server 108 may receive information from various data feeds for generating timers. Examples of data feeds include (but are not limited to): cast information, identifying topics in a recorded or streamed content, identifying sporting events, sporting event info, timing info, trending events and keywords, video clips, alternate audio/video feed etc.
In at least one implementation, the data processing and aggregating server 108 may be provided in association with an external server 120. The external server 120 may be configured to generate request for bookmarking data that is then processed by the data processing and aggregating server 108 and sent to the client device 104, as appropriate. Here, the external server 120 may generate the request on behalf of the client device 104 or an application running thereon.
In at least one implementation, a client device may take the form of a television receiver. As described for purposes of illustration only and not by means of limitation, a television receiver will be described herein as a set-top box, such as a satellite television, cable television, terrestrial television, streaming media receiver or internet television receiver that is external to an associated presentation device. However, it is to be appreciated that the television receiver may also be integrated within a presentation device, such as a television with an integrated cable television receiver.
As shown in
The television system of
In a cable television system configuration, the head-end 250 may transmit the television signal directly or indirectly to the STB 220 over one or more cable network connections. For example, the signal may be provided to the STB 220 through a dedicated cable connected between the STB 220 and the head-end 250. Alternatively, the signal may be provided over a network 280 connection, utilizing a modem 260 associated with the STB 220. Additionally, the head-end 250 may utilize the network 280 to provide other communication signals to the STB 220. For example, the head-end 250 may utilize a server 270 in communication with the head-end and the network 280 provide programming updates to the STB 220 over the network connection. Further, the STB 220 may also communicate over the network 280 connection to provide information to the head-end 250 or to store information within the network 280 itself.
As shown in
Further, as described above, the STB 320 may provide an interface to the user through the user's television 330 or other display device. In providing the interface to the user, the STB 320 may include a microprocessor 350 coupled to memory 370, as described in more detail below. The set-top box may also include an input/output (I/O) interface 360 to interface one or more I/O bridges or I/O devices. I/O devices may also include an input device (not shown), such as an infra-red or radio frequency signal provided by remote control device or alphanumeric input device, including alphanumeric and other keys for communicating information and/or command selections to the microprocessor 350. The I/O device may be utilized by a user to provide inputs and commands to the STB 320 to control the interface. Inputs may also be received from a network 390 through a modem 380 coupled to the STB 320. The modem 380 may be connected to the STB 320 through the I/O interface 360 or may be integrated within the STB 320. The modem 380 may also be configured to communicate over the network 390 to provide and receive information and commands from the network.
The STB 320 may include or be associated with a recorder 375, such as a digital video recorder (DVR). As used herein, a DVR or recorder 375 may be any physical or virtual device configured to record media content, such as a physical DVR, a cloud DVR, or a recorder for other content such as from streaming sources or for the playback of video-on-demand (VOD) content. Some devices, e.g. the ones that play VOD content or streaming content, may not explicitly record content, but rather may receive a file or a link to a file that is sent from a service provider. In various embodiments, the service provider may send the file or the link to the file to the VOD device, a STB, a mobile device, or the like. The recorder 375 may be integrated into the STB 320, provided via one or more networked devices, including but not limited to servers, may be a standalone device or otherwise provided. The recorder 375 may be configured automatically, manually, for example directly by a user, or otherwise to record a particular program at a specified time. When the program occurs, the recorder 375 will record and store the program, which can then be viewed later. In addition to this functionality, the recorder 375 may buffer a certain amount of content during a live transmission. Buffering a live transmission allows a user to pause and/or rewind the content of the transmission and then display the content in a non-live or delayed manner. When the recorder 375 is configured to record a particular program, such recording may be listed on one or more recording lists. Such recording lists may be generated automatically or based on user input.
STB 320 may also include a dynamic storage device, referred to as memory 370, or a random access memory (RAM) or other devices coupled to the STB for storing information and instructions to be executed by the microprocessor 350. Memory 370 also may be used for storing temporary variables or other intermediate information during execution of instructions by the microprocessor 350. According to at least one embodiment, the implementations described below may be performed by a STB 320 in response to microprocessor 350 executing one or more sequences of one or more instructions contained in memory 370. These instructions may be read into memory 370 from another machine-readable medium, such as a storage device. Execution of the sequences of instructions contained in memory 370 may cause the microprocessor 350 to perform the process steps described herein. In alternative embodiments, circuitry may be used in place of or in combination with the software instructions. Thus, embodiments of the present disclosure may include both hardware and software components.
A machine readable medium includes any mechanism for storing or transmitting information in a form (e.g., software, processing application) readable by a machine (e.g., a computer). Such media may take the form of, but is not limited to, non-volatile media and volatile media. Non-volatile media includes optical or magnetic disks. Volatile media includes dynamic memory, such as memory 370. Common forms of machine-readable medium may include, but are not limited to, magnetic storage medium (e.g., floppy diskette); optical storage medium (e.g., CD-ROM); magneto-optical storage medium; read only memory (ROM); random access memory (RAM); erasable programmable memory (e.g., EPROM and EEPROM); flash memory; or other types of medium suitable for storing electronic instructions.
As shown in
In any embodiment or component of the system described herein, the computer system 400 includes a processor 402 and a system memory 406 connected by a system bus 404 that also operatively couples various system components. There may be one or more processors 402, e.g., a single central processing unit (CPU), or a plurality of processing units, commonly referred to as a parallel processing environment (for example, a dual-core, quad-core, or other multi-core processing device). The system bus 404 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, a switched fabric, point to point connection, and a local bus using any of a variety of bus architectures. The system memory 406 may include read only memory (ROM) 408 and random access memory (RAM) 410. A basic input/output system (BIOS) 412 or the like, containing those basic routines that help to transfer information between elements within the computer system 400, such as during start up, may be stored in ROM 408. A cache 414 may be set aside in RAM 410 to provide a high speed memory storage for frequently accessed data.
A hard disk drive interface 416 may be connected with the system bus 404 to provide read and write access to a data storage device, e.g., a hard disk drive 418. It is to be appreciated that such hard disk drive 418 or comparable device may be configured to provide nonvolatile storage for applications, files, content and other data. A number of program modules and other data may be stored on the hard disk 418, including an operating system 420, one or more application programs 422, and data files 424. In an exemplary implementation, the hard disk drive 418 may store code associated with data processing and aggregating server 108 according to at least one of the embodiments described herein. As shown in
The computer system 400 may further include a magnetic disk drive 430 for reading from or writing to a removable magnetic disk 432, tape, or other magnetic media. The magnetic disk drive 430 may be connected with the system bus 404 via a magnetic drive interface 428 to provide read and write access to the magnetic disk drive 430 initiated by other components or applications within the computer system 400. The magnetic disk drive 430 and the associated computer readable media may be used to provide nonvolatile storage of computer readable instructions, data structures, program modules, and other data for the computer system 400.
The computer system 400 may additionally include an optical disk drive 436 for reading from or writing to a removable optical disk 438 such as a CD ROM or other optical media. The optical disk drive 436 may be connected with the system bus 404 via an optical drive interface 434 to provide read and write access to the optical disk drive 436 initiated by other components or applications within the computer system 400. The optical disk drive 436 and the associated computer readable optical media may be used to provide nonvolatile storage of computer readable instructions, data structures, program modules, and other data for the computer system 400.
A display device 442, e.g., a monitor, a television, or a projector, or other type of presentation device may also be connected to the system bus 404 via an interface, such as a video adapter 440 or video card. Similarly, audio devices, for example, external speakers or a microphone (not shown), may be directly or indirectly connected to the system bus 404 through an audio card or other audio interface (not shown).
In addition to the monitor 442, the computer system 400 may include other peripheral input and output devices, which are often connected to the processor 402 and memory 406 through the serial port interface 444 that is coupled to the system bus 404. Input and output devices may also or alternately be connected with the system bus 404 by other interfaces, for example, a universal serial bus (USB), an IEEE 1394 interface (“Firewire”), a parallel port, or a game port. A user may enter commands and information into the computer system 400 through various input devices including, for example, a keyboard 446 and pointing device 448, for example, a mouse. Other input devices (not shown) may include, for example and not by means of limitation, a joystick, a game pad, a tablet, a touch screen device, an antenna, a scanner, a facsimile machine, a microphone, a digital camera, and a digital video camera.
Output devices may include a printer 450 and one or more loudspeakers (not shown) for presenting audio. Other output devices (not shown) may include, for example and not by means of limitation, a plotter, a photocopier, a photo printer, a facsimile machine, and a press. In some implementations, several of these input and output devices may be combined into single devices, for example, a printer/scanner/fax/photocopier. It should also be appreciated that other types of computer readable media and associated drives for storing data, for example, magnetic cassettes or flash memory drives, may be accessed by the computer system 400 via the serial port interface 444 (e.g., USB) or similar port interface.
The computer system 400 may operate in a networked environment using logical connections through a network interface 452 coupled with the system bus 404 to communicate with one or more remote devices. The logical connections depicted in
To connect with a WAN 460, the computer system 400 typically includes a modem 462 for establishing communications over the WAN 460. Typically the WAN 460 may be the Internet. However, in some instances the WAN 460 may be a large private network spread among multiple locations, or a virtual private network (VPN). The modem 462 may be a telephone modem, a high speed modem (e.g., a digital subscriber line (DSL) modem), a cable modem, or similar type of communications device. The modem 462, which may be internal or external, is connected to the system bus 404 via the network interface 452. In at least one embodiment, the modem 462 may be connected via the serial port interface 444. It should be appreciated that the network connections shown are exemplary and other means of and communications devices for establishing a network communications link between the computer system 400 and other devices or networks may be used.
One aspect of the user interface provided to the user may be requesting and/or using bookmarks provided by a data processing and aggregating server 108. A data processing and aggregating server 108 in accordance with the present disclosure may use or parse a data feed to bookmark specific segments in a show, movie or sporting event (collectively “event”) to thereby allow a user to skip to a specific moment of the event using those bookmarks. By way of example and not limitation, bookmarks may be in displayed in connection with one or more “reality TV” shows or game shows. Bookmarks in this case may correspond to relevant moments in the show such as the introduction, different contestant performances, judges' feedback, guest performances, results, or the like. Bookmarks may be displayed in connection with talk shows. Bookmarks in this case may correspond to the intro/monologue, segments before guests, segments where the guests appear, content guests chat about, musical performances, or the like. Bookmarks may be displayed in connection with news and/or sports news shows. Bookmarks in this case may correspond to segments in the program. Bookmarks may be displayed in connection with sporting events, such as football, baseball, soccer, tennis, hockey, etc. Bookmarks in this case may correspond to sports based data like periods of the game, scoring plays or exciting moments such as outs in baseball games, blocks, tackles, scoring attempts, moments of controversy, or the like.
Bookmarks in accordance with the at least one embodiment of the present disclosure many include one or more particular features that provide advantage to users. With respect to the placement on the display area, bookmarks may be presented to the user in a variety of locations. For example and not limitation, bookmarks may be displayed in the info page/section of the event, in a popup after a user selects play/resume/start over, in a progress bar for the show/event, above the current moment of playback in the progress bar, and/or as a notification. Bookmarks may be actionable. More specifically, when a user taps/clicks on a topic, the device may skip to within a few seconds of the start bookmarked time. By way of example and not limitation, a data feed for a bookmark may contain descriptive information such as bookmark title, bookmark description, bookmark start time, bookmark end time, bookmark category (Sports: score updates, time periods, game highlights, or the like; talk show/news: themes, breaking news, reality shows, performance, results, judge's feedback, guest performer, or the like), and bookmark length. Bookmarks may be colored based on the category (scoring vs. end/beginning of time period, performance, judging, results, breaking news, or the like). Additionally, in the case that the bookmarks are displayed over a progress bar where the scrubbing of playback to a particular point is allowed, the cursor/playback head may gravitate to the start of a topic as it gets close to the start time of the bookmark.
As shown in
As shown in
As shown in
As shown in
As shown in
As shown in
As shown in
By way of example and not limitation, menu 1204 shown in
By way of example and not limitation, menu 1304 shown in
As shown in
As shown in
In one example, the request for bookmarking data may originate in the client device 104. In this embodiment, the client device 104 requests bookmarking information and passes the necessary data to fulfill the request to the server 108, which receives the request in operation 1604. The data passed to the server in operation 1604 may include currently playing info, current position of the play head, type of information requested, and the like. In this implementation, the information requested by the client device 104 is delivered to the client device 104 responsive to the request in operation 1628. Additionally, if the request cannot be processed for any reason, the server 108 returns one or more relevant error messages to the client device 104 in operation 1628.
In another example, the request for bookmarking data may originate in the server 108. In this embodiment, the data processing and aggregating server 108 generates its own request to create bookmarking data and initiates processing of that request in operation 1604. The request is then processed as described above in connection with other embodiments, including operation 1628 where the bookmarking data is delivered to the client device 104. Thus, in this example, the data processing and aggregating server 108 delivers bookmarking data to the client device 104 without a direct request from the client device 104.
In another example, the request for bookmarking data may originate in an external server 120. In this embodiment, the external server 120 requests bookmarking information and passes the necessary data to fulfill the request to the server 108, which receives the request in operation 1604. In this implementation, the information requested by the client device 104 is delivered to the client device 104 responsive to the request from the external server 120 in operation 1628. In this example, the server 108 additionally sends, in operation 1628, an acknowledgement of the delivery of the bookmark data to the external server 120 that generated the request. If the request cannot be processed for any reason, the server 108 returns relevant error messages to the external server 120 and/or the client device 104 in operation 1628.
In another example, the request for bookmarking data may originate in a data feed 116. In this embodiment, the data feed 116 requests bookmarking information and passes the necessary data to fulfill the request to the server 108, which receives the request in operation 1604. In this implementation, the information requested by the client device 104 is delivered to the client device 104 responsive to the request from the data feed in operation 1628. In this regard, the data processing and aggregating server 108 may deliver the bookmarking data to the client device 104 with an update request from the data feed 116.
One aspect of the user interface provided to the user may be requesting and/or using commercial identifying information provided by a data processing and aggregating server 108. A data processing and aggregating server 108 in accordance with the present disclosure may use or parse a data feed to identify content and commercial spots in the recorded or buffered video and optionally replacing that commercial segment with another video feed/spot or image. By way of example, the server 108 may use or parse a data feed that identifies a single or multiple successive (aggregate) commercial segment(s). By way of example and not limitation, a data feed for a commercial segment may contain descriptive information such as the start time of a commercial, the end time of the commercial, the length of the commercial, the title of the commercial, the category of the commercial (insurance, automobile, pharmaceutical, political, or the like), and a commercial description. These identifiers can be presented to the user in various ways, as shown in
As shown in
As shown in
As shown in
As shown in
As shown in
In accordance with some embodiments, the content identifier may be actionable. Specifically, the device may be instructed, for example upon a user pressing a single button (or multiple) on a remote (physical or on screen), to skip over a single commercial, multiple commercials or to the beginning of the next segment of content. In some embodiments, the cursor/playback head on the progress bar may gravitate to the end of a single commercial, to the end of a commercial break or to the beginning of the next segment. Once identified, an alternate video feed can be used to replace or overlaid over a single commercial or multiple commercials.
As shown in
Embodiments that include the automated skipping feature may use or parse a data feed to automate the skipping of commercials. Here, the embodiment may use a data feed to identify and automatically skip over commercial breaks in a recorded or buffered video feed. By way of example and not limitation, the identification of a commercial segment may contain information such as the start time of a commercial, the end time of a commercial, the length of a commercial, the title of a commercial, the category of a commercial (insurance, automobile, pharmaceutical, political, etc.), and/or a commercial description.
As shown in
In one example, the request for commercial identifying data may originate in the client device 104. In this embodiment, the client device 104 requests commercial identifying data and passes the necessary data to fulfill the request to the server 108, which receives the request in operation 2304. The data passed to the server in operation 2304 may include currently playing program info, a list of recordings along with title and content ID's, current position of a play head, etc. In this implementation, the information requested by the client device 104 is delivered to the client device 104 responsive to that request in operation 2328. Additionally, if the request cannot be processed for any reason, the server 108 returns relevant error messages to the client device 104 in operation 2328.
In another example, the request for commercial identifying data may originate in an external server 120. In this embodiment, the external server 120 requests commercial identifying data and passes the necessary data to fulfill the request to the server 108, which receives the request in operation 2304. In this implementation, the information requested by the external server 120 is delivered to the client device 104 in response to the request from the external server 120 in operation 2328. In this example, the server 108 additionally sends, in operation 2328, an acknowledgement of the delivery of the commercial identifying data to the external server 120 that generated the request. If the request cannot be processed for any reason, the server 108 returns relevant error messages to the external server 120 and/or the client device 104 in operation 2328.
The client device 104 may use commercial identifying data to automatically skip commercials in embodiments that provide for that option. Here, the client device 104 uses the data to skip over commercials during playback of the recorded or buffered content for the show if a user exercises the option. Individual commercials may also be skipped over with a click of a button. In some cases, the client device 104 and the commercials can be skipped for recorded or buffered content if initiated by the user.
One aspect of the user interface provided to the user may be selecting options and receiving information for skipping over age restricted content provided by a data processing and aggregating server 108. A data processing and aggregating server 108 in accordance with the present disclosure may use or parse a data feed to skip over age restricted material in the recorded or buffered video and optionally replace the skipped material with another video feed or image. Age restriction may be identified by standard rating or by third party providers that classify content based on age of the target viewer. By way of example, the server 108 may use or parse a data feed that identifies age restricted content. By way of example and not limitation, a data feed that identifies age restricted content may contain descriptive information such as rating information (G, PG, PG-13, R, NC-17, NR/AO, TV-Y, TV-Y7, TV-G, TV-PG, TV-14, TV-MA, etc.), start time, end time, length, title, description, category (strong language, violence, nudity, etc.).
These identifiers can be presented to the user in various ways as shown in the example configurations of
In accordance with at least one embodiment, the content identifier may be actionable. Specifically, the users may be allowed to press a single button (or multiple) on a remote (physical or on screen) to skip over a single commercial, multiple commercials or to the beginning of the next segment of content. In some embodiments, the cursor/playback head on the progress bar may gravitate to the end of a single commercial, to the end of a commercial break or to the beginning of the next segment. Once identified, an alternate video feed can be used to replace or overlay a single commercial or multiple commercials. In accordance with some embodiments, the age restricted segments may be colored based on the category. In some embodiments, the content identifier may be actionable. Specifically, the users may be allowed to press a single button (or multiple) on a remote (physical or on screen) to skip over a single age restricted segment, multiple age restricted segment or to the beginning of the next age unrestricted segment of content. In some embodiments, the cursor/playback head on the progress bar may gravitate to the end of a single age restricted segment, to the end of an age restricted segment or to the beginning of the next age unrestricted segment. Users may restrict certain segments in parental control settings or before the start of a recorded or buffered event. Once identified, a single age restricted segment or multiple age restricted segments can be skipped over using the information from the data feed. Alternatively, once identified, a single age restricted segment or multiple age restricted segments can be replaced or overlaid with another video feed using the information from the data feed.
As shown in
In one example, the request for data on age restricted content may originate in the client device 104. In this embodiment, the client device 104 requests data on age restricted content and passes the necessary data to fulfill request to the server 108, which receives the request in operation 2704. The data passed to the server in operation 2704 may include currently playing info, current position of play head, type of information requested, or the like. In this implementation, the information requested by the client device 104 is delivered to the client device 104 in response to that request in operation 2728. Additionally, if the request cannot be processed for any reason, the server 108 returns relevant error messages to the client device 104 in operation 2728.
A data processing and aggregating server 108 in accordance with the present disclosure may improve a timer accuracy by using or parsing a data feed. More specifically, the server 108 may use the data feed to improve the accuracy of the start and stop time of a recording timer. By way of example, the server 108 may use or parse a data feed that identifies the start and stop time of a media content to be provided by a content source. By way of example and not limitation, a data feed that identifies the start and stop time of a media content may contain descriptive information such as the start time of event, the end of event, the length of event, the title of event, a category of event (news, sports, reality, competition, etc.), and an event description.
Using the data feed to enhance timer accuracy, the start time of the event may be corrected to reflect the actual start of the event. For example, the start time may be corrected at times such as at the time of timer creation, before the start of the event, after the start of the event, and after the end of the event. Using the data feed to enhance timer accuracy, the end time of the event may be corrected to reflect the actual start of the event. For example, the end time may be corrected at such times as at the time of timer creation, before the start of the event, after the start of the event, and after the end of the event. Using the data feed to enhance timer accuracy, embodiments may modify the length of a previously recorded or buffered event by cropping, fast forwarding or beginning playback at the start of the actual event and ending playback or cropping the extra portion of the previously recorded event.
As shown in
A data processing and aggregating server 108 in accordance with at least one of the various embodiments of the present disclosure may be configured to manipulate lists of viewer measurement (VM) data. By way of example, the server 108 may use or parse a data feed that provides viewer measurement statistics or similar data. A list of content ordered by VM statistics can be modified or certain elements can be highlighted using a data feed. In accordance with one or more of the various embodiments, the viewer measurement statistics are aggregated on one or more of the following levels or combination of levels such as personal, account/household level, zip code, county, city, state, national, or international. Lists can may be modified and/or individual items can be highlighted based on an external data feed. The modified list may then be delivered to the STB, client, mobile device or computer where further modification of the list may be performed.
In one example, the request for viewer measurement modified list data may originate in the client device 104. In this embodiment, the client device 104 requests viewer measurement modified list data and passes the necessary data to fulfill request to the server 108, which receives the request in operation 2904. The data passed to the server in operation 2904 may include currently playing info, current position of play head, type of information requested, or the like. In this implementation, the information requested by the client device 104 is delivered to the client device 104 responsive to that request in operation 2928. Additionally, if the request cannot be processed for any reason, the server 108 returns relevant error messages to the client device 104 in operation 2928.
In another example, the request for viewer measurement modified list data may originate in the server 108. In this embodiment, the data processing and aggregating server 108 generates its own request to create viewer measurement modified list data and initiates processing of that request in operation 2904. The request is then processed as described above in connection with other embodiments, including operation 2928 where the viewer measurement modified list data is delivered to the client device 104. Thus, in this example, the data processing and aggregating server 108 delivers viewer measurement modified list data to the client device 104 without a direct request from the client device 104.
In another example, the request for viewer measurement modified list data may originate in an external server 120. In this embodiment, the external server 120 requests bookmarking information and passes the necessary data to fulfill the request to the server 108, which receives the request in operation 2904. In this implementation, the information requested by the client device 104 is delivered to the client device 104 responsive to the request from the external server 120 in operation 2928. In this example, the server 108 additionally sends, in operation 2928, an acknowledgement of the delivery of the viewer measurement modified list data to the external server 120 that generated the request. If the request cannot be processed for any reason, the server 108 returns relevant error messages to the external server 120 and/or the client device 104 in operation 2928.
In another example, the request for viewer measurement modified list data may originate in a data feed 116. In this embodiment, the data feed 116 requests viewer measurement modified list data and passes the necessary data to fulfill the request to the server 108, which receives the request in operation 2904. In this implementation, the information requested by the client device 104 is delivered to the client device 104 responsive to the request from the data feed in operation 2928. In this regard, the data processing and aggregating server 108 may deliver the viewer measurement modified list data to the client device 104 with a update request from the data feed 116.
A data processing and aggregating server 108 in accordance with at least one embodiment of the present disclosure may use a data feed to generate a timer. In at least one embodiment, the server 108 may use a data feed to generate a timer to record a DVR event. In at least one embodiment, a data feed initiates a request to create a recording on a DVR through the server 108. This data feed can generate this request to record an event on its own or if certain conditions of a user's profile are met. For example, a sporting event can be recorded if a user's favorite team is playing. A game can be recorded if it crosses a certain excitement level that may or may not be defined by a user. By way of further example and not limitation, a data feed that generates timers may do so based on certain events such as a favorite actor could be in the cast of the content, a trending event is being discussed, or a trending event in a piece of content could be on a list of topics generated or selected, manually or automatically, for a given user or users. A timer can be created for a specific piece of content available to the user or it could be for a particular period of time across a certain channel or within a piece of content.
As shown in
In one example, the request for creation of a timer may originate in the client device 104. In this embodiment, the client device 104 requests creation of a timer and passes the necessary data to fulfill the request to the server 108, which receives the request in operation 3004. The data passed to the server in operation 3004 may include currently playing info, current position of play head, type of information requested, or the like. In this implementation, the information requested by the client device 104 is delivered to the client device 104 responsive to that request in operation 3028. Additionally, if the request cannot be processed for any reason, the server 108 returns relevant error messages to the client device 104 in operation 3028.
In another example, the request for creation of a timer may originate in the server 108. In this embodiment, the data processing and aggregating server 108 generates its own request to create a timer and initiates processing of that request in operation 3004. The request is then processed as described above in connection with at least one of the other embodiments, including operation 3028 where the data for the requested creation of a timer is delivered to the client device 104. Thus, in this example, the data processing and aggregating server 108 delivers data for the requested creation of a timer to the client device 104 without a direct request from the client device 104.
In another example, the request for creation of a timer may originate in an external server 120. In this embodiment, the external server 120 requests bookmarking information and passes the necessary data to fulfill the request to the server 108, which receives the request in operation 3004. In this implementation, the information requested by the client device 104 is delivered to the client device 104 responsive to the request from the external server 120 in operation 3028. In this example, the server 108 additionally sends, in operation 3028, an acknowledgement of the delivery of the data for the requested creation of a timer to the external server 120 that generated the request. If the request cannot be processed for any reason, the server 108 returns relevant error messages to the external server 120 and/or the client device 104 in operation 3028.
In another example, the request for creation of a timer may originate in a data feed 116. In this embodiment, the data feed 116 requests creation of a timer and passes the necessary data to fulfill the request to the server 108, which receives the request in operation 3004. In this implementation, the information requested by the client device 104 is delivered to the client device 104 responsive to the request from the data feed in operation 3028. In this regard, the data processing and aggregating server 108 may deliver the data for the requested creation of a timer to the client device 104 with an update request from the data feed 116.
The technology described herein may be implemented as logical operations and/or modules in one or more devices systems and/or methods. The logical operations may be implemented as a sequence of processor implemented steps executing in one or more computer systems and as interconnected machine or circuit modules within one or more computer systems. Likewise, the descriptions of various component modules may be provided in terms of operations executed or effected by the modules. The resulting implementation is a matter of choice, dependent on the performance requirements of the underlying system implementing the described technology. Accordingly, the logical operations making up the embodiments of the technology described herein are referred to variously as operations, steps, objects, or modules. Furthermore, it should be understood that logical operations may be performed in any order, unless explicitly claimed otherwise or a specific order is inherently necessitated by the claim language.
In some implementations, articles of manufacture are provided as computer program products that cause the instantiation of operations on a computer system to implement the invention. One implementation of a computer program product provides a non-transitory computer program storage medium readable by a computer system and encoding a computer program. It should further be understood that the described technology may be employed in special purpose devices independent of a personal computer.
The above specification, examples and data provide a complete description of the structure and use of the various embodiments of the invention as defined in the claims. Although various embodiments of the claimed invention have been described above with a certain degree of particularity, or with reference to one or more individual embodiments, those skilled in the art could make numerous alterations to the disclosed embodiments without departing from the spirit or scope of the claimed invention. Other embodiments are therefore contemplated. It is intended that all matter contained in the above description and shown in the accompanying drawings shall be interpreted as illustrative only of particular embodiments and not limiting. Changes in detail or structure may be made without departing from the basic elements of the invention as defined in the following claims.
This application claims priority to U.S. provisional application No. 62/059,734 entitled “Bookmarking Data” filed Oct. 3, 2014, the disclosure of which is hereby incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
4750213 | Novak | Jun 1988 | A |
5333091 | Iggulden et al. | Jul 1994 | A |
5614940 | Cobbley et al. | Mar 1997 | A |
5659539 | Porter et al. | Aug 1997 | A |
5692093 | Iggulden et al. | Nov 1997 | A |
5696866 | Iggulden et al. | Dec 1997 | A |
5703655 | Corey et al. | Dec 1997 | A |
5742730 | Couts et al. | Apr 1998 | A |
5987210 | Iggulden et al. | Nov 1999 | A |
5999688 | Iggulden et al. | Dec 1999 | A |
6005603 | Flavin | Dec 1999 | A |
6057893 | Kojima et al. | May 2000 | A |
6243676 | Witteman | Jun 2001 | B1 |
6425127 | Bates et al. | Jul 2002 | B1 |
6850691 | Stam et al. | Feb 2005 | B1 |
7032177 | Novak et al. | Apr 2006 | B2 |
7110658 | Iggulden et al. | Sep 2006 | B1 |
7197758 | Blackketter et al. | Mar 2007 | B1 |
7251413 | Dow et al. | Jul 2007 | B2 |
7320137 | Novak et al. | Jan 2008 | B1 |
7631331 | Sie et al. | Dec 2009 | B2 |
7634785 | Smith | Dec 2009 | B2 |
7661121 | Smith et al. | Feb 2010 | B2 |
7889964 | Barton et al. | Feb 2011 | B1 |
8136140 | Hodge | Mar 2012 | B2 |
8156520 | Casagrande et al. | Apr 2012 | B2 |
8165451 | Casagrande | Apr 2012 | B2 |
8606085 | Gratton | Dec 2013 | B2 |
20020069218 | Sull et al. | Jun 2002 | A1 |
20020090198 | Rosenberg et al. | Jul 2002 | A1 |
20020097235 | Rosenberg et al. | Jul 2002 | A1 |
20020124249 | Shintani et al. | Sep 2002 | A1 |
20020131511 | Zenoni | Sep 2002 | A1 |
20030004933 | Ben-Yehezkel | Jan 2003 | A1 |
20030066078 | Bjorgan et al. | Apr 2003 | A1 |
20030093790 | Logan et al. | May 2003 | A1 |
20030154128 | Liga et al. | Aug 2003 | A1 |
20030192060 | Levy | Oct 2003 | A1 |
20030194213 | Schultz et al. | Oct 2003 | A1 |
20030202773 | Dow et al. | Oct 2003 | A1 |
20030231854 | Derrenberger | Dec 2003 | A1 |
20040010807 | Urdang et al. | Jan 2004 | A1 |
20040083484 | Annon Ryal | Apr 2004 | A1 |
20040128317 | Sull | Jul 2004 | A1 |
20040172650 | Hawkins et al. | Sep 2004 | A1 |
20040177317 | Bradstreet | Sep 2004 | A1 |
20040190853 | Dow et al. | Sep 2004 | A1 |
20040221311 | Dow | Nov 2004 | A1 |
20050020223 | Ellis et al. | Jan 2005 | A1 |
20050076359 | Pierson et al. | Apr 2005 | A1 |
20050081252 | Chefalas et al. | Apr 2005 | A1 |
20050097135 | Epperson | May 2005 | A1 |
20050166258 | Vasilevsky | Jul 2005 | A1 |
20050262539 | Barton et al. | Nov 2005 | A1 |
20060013555 | Poslinski | Jan 2006 | A1 |
20060080716 | Nishikawa | Apr 2006 | A1 |
20060218617 | Bradstreet et al. | Sep 2006 | A1 |
20070030386 | Cha et al. | Feb 2007 | A1 |
20070050837 | Lopez-Estrada | Mar 2007 | A1 |
20070098350 | Gibbon | May 2007 | A1 |
20070136742 | Sparrell | Jun 2007 | A1 |
20070168543 | Krikorian et al. | Jul 2007 | A1 |
20070171303 | Barbieri et al. | Jul 2007 | A1 |
20070212030 | Koga et al. | Sep 2007 | A1 |
20070244903 | Ratliff | Oct 2007 | A1 |
20070300249 | Smith et al. | Dec 2007 | A1 |
20070300250 | Smith et al. | Dec 2007 | A1 |
20080052739 | Logan | Feb 2008 | A1 |
20080112690 | Shahraray et al. | May 2008 | A1 |
20080177858 | Aarnio | Jul 2008 | A1 |
20080183587 | Joo et al. | Jul 2008 | A1 |
20080267584 | Green | Oct 2008 | A1 |
20080320523 | Morris | Dec 2008 | A1 |
20090129747 | Casagrande | May 2009 | A1 |
20090133093 | Hodge | May 2009 | A1 |
20090238536 | Gratton | Sep 2009 | A1 |
20090254823 | Barrett | Oct 2009 | A1 |
20090300699 | Casagrande | Dec 2009 | A1 |
20090304358 | Rashkovskiy et al. | Dec 2009 | A1 |
20090307741 | Casagrande | Dec 2009 | A1 |
20100046919 | Song | Feb 2010 | A1 |
20100053452 | Abe et al. | Mar 2010 | A1 |
20100088726 | Curtis | Apr 2010 | A1 |
20100138761 | Barnes | Jun 2010 | A1 |
20110047571 | Zhang | Feb 2011 | A1 |
20110075990 | Eyer | Mar 2011 | A1 |
20110194838 | Meijer | Aug 2011 | A1 |
20110197224 | Meijer | Aug 2011 | A1 |
20120070129 | Lin | Mar 2012 | A1 |
20150181300 | Rajan | Jan 2015 | A1 |
Number | Date | Country |
---|---|---|
1536362 | Jun 2005 | EP |
1705908 | Sep 2006 | EP |
2001359079 | Dec 2001 | JP |
2006262057 | Sep 2006 | JP |
2008131150 | Jun 2008 | JP |
4336364 | Sep 2009 | JP |
2001022729 | Mar 2001 | WO |
2005096625 | Oct 2005 | WO |
2006003585 | Jan 2006 | WO |
Entry |
---|
European Patent Office, International Search Report (ISR) for PCT/US2009/037183 (Publication No. WO2009117326), dated Jul. 15, 2009, 4 Pages. |
European Patent Office, International Search Report (ISR) for PCT/US2010/038836 (Publication No. WO2010148096), dated Oct. 1, 2010, 5 Pages. |
European Patent Office, International Search Report (ISR) for PCT/EP2011/051335 (Publication No. WO2011098366), dated Sep. 1, 2011, 6 Pages. |
Comskip, http://www.kaashoek.com/comskip/, Jan. 26, 2007, 3 pages. |
Mythtv, “How to Write a New Method of Commercial Detection”, http://www.mythtv.org/wiki/index.php/, Jan. 26, 2007, 2 pages. |
Electronic Frontier Foundation (EFF), Paramount Pictures Corp. V. Replaytv & Sonicblue, https://www.eff.org/document/original-complaint-filed-mpaa-members-paramount-pictures-corp-et-al-v-replaytv-sonicblue-0, Oct. 30, 2001, 31 pages. |
Dimitrova et al., “Real Time Commercial Detection Using MPEG Features”, Philips Research, Dec. 24, 2013, 6 pages. |
Haughey, “EFF's ReplayTV Suit Ends”, http://www.pvrblog.com/pvr/2004/01/effs_replaytv_s.html, Jan. 12, 2004, 4 pages. |
Manjoo, “They Know What You're Watching”, Wired News, http://www.wired.com/news/politics/0.1283.52302.00.html, May 3, 2002, 4 pages. |
Mizutani et al., “Commercial Detection in Heterogeneous Video Streams Using Fused Multi-Modal and Temporal Features”, IEEE ICASSP, Philadelphia, Mar. 22, 2005, 19 pages. |
Pricegrabber, “RCA DRC8060N DVD Recorder”, http://www.pricegrabber.com/rating_getprodrev.php/product_id=12462074/id, Jan. 26, 2007, 8 pages. |
Tew, “How MythTV Detects Commercials”, http://www.pvrwire.com/2006/10/27/how-mythtv-detects-commercials/, Oct. 27, 2006, 6 pages. |
Pogue, “Networks Start to Offer TV on the Web”, http://www.nytimes.com/2007/10/18/technology/circuits, Oct. 18, 2007, 5 Pages. |
Satterwhite, “Automatic Detection of TV Commercials”, IEEE Potentials, IEEE, 2004, pp. 9-12, 4 pages. |
Number | Date | Country | |
---|---|---|---|
20160100226 A1 | Apr 2016 | US |
Number | Date | Country | |
---|---|---|---|
62059734 | Oct 2014 | US |