US7656461B2 - Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows - Google Patents
Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows Download PDFInfo
- Publication number
- US7656461B2 US7656461B2 US10/402,044 US40204403A US7656461B2 US 7656461 B2 US7656461 B2 US 7656461B2 US 40204403 A US40204403 A US 40204403A US 7656461 B2 US7656461 B2 US 7656461B2
- Authority
- US
- United States
- Prior art keywords
- video
- sub
- video data
- buffer
- buffers
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active, expires
Links
- 239000000872 buffer Substances 0.000 title claims abstract description 190
- 238000000034 method Methods 0.000 title abstract description 23
- 238000005192 partition Methods 0.000 claims abstract description 14
- 238000000638 solvent extraction Methods 0.000 claims description 15
- 241000269627 Amphiuma means Species 0.000 claims 1
- 238000012545 processing Methods 0.000 description 10
- 238000013475 authorization Methods 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 238000007796 conventional method Methods 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000010586 diagram Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 230000000737 periodic effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N5/00—Details of television systems
- H04N5/222—Studio circuitry; Studio devices; Studio equipment
- H04N5/262—Studio circuits, e.g. for mixing, switching-over, change of character of image, other special effects ; Cameras specially adapted for the electronic generation of special effects
- H04N5/2624—Studio circuits, e.g. for mixing, switching-over, change of character of image, other special effects ; Cameras specially adapted for the electronic generation of special effects for obtaining an image which is composed of whole input images, e.g. splitscreen
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G5/00—Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators
- G09G5/36—Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the display of a graphic pattern, e.g. using an all-points-addressable [APA] memory
- G09G5/39—Control of the bit-mapped memory
- G09G5/393—Arrangements for updating the contents of the bit-mapped memory
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/41—Structure of client; Structure of client peripherals
- H04N21/426—Internal components of the client ; Characteristics thereof
- H04N21/42653—Internal components of the client ; Characteristics thereof for processing graphics
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/43—Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
- H04N21/431—Generation of visual interfaces for content selection or interaction; Content or additional data rendering
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/43—Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
- H04N21/44—Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs
- H04N21/44004—Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs involving video buffer management, e.g. video decoder buffer or video display buffer
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/43—Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
- H04N21/44—Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs
- H04N21/4402—Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs involving reformatting operations of video signals for household redistribution, storage or real-time display
- H04N21/440263—Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs involving reformatting operations of video signals for household redistribution, storage or real-time display by altering the spatial resolution, e.g. for displaying on a connected PDA
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/80—Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
- H04N21/81—Monomedia components thereof
- H04N21/8146—Monomedia components thereof involving graphical data, e.g. 3D object, 2D graphics
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N5/00—Details of television systems
- H04N5/14—Picture signal circuitry for video frequency region
- H04N5/147—Scene change detection
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N5/00—Details of television systems
- H04N5/44—Receiver circuitry for the reception of television signals according to analogue transmission standards
- H04N5/445—Receiver circuitry for the reception of television signals according to analogue transmission standards for displaying additional information
- H04N5/45—Picture in picture, e.g. displaying simultaneously another television channel in a region of the screen
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G2340/00—Aspects of display data processing
- G09G2340/04—Changes in size, position or resolution of an image
- G09G2340/0407—Resolution change, inclusive of the use of different resolutions for different screen areas
- G09G2340/0414—Vertical resolution change
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G2340/00—Aspects of display data processing
- G09G2340/04—Changes in size, position or resolution of an image
- G09G2340/0407—Resolution change, inclusive of the use of different resolutions for different screen areas
- G09G2340/0421—Horizontal resolution change
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G2340/00—Aspects of display data processing
- G09G2340/12—Overlay of images, i.e. displayed pixel being the result of switching between the corresponding input pixels
- G09G2340/125—Overlay of images, i.e. displayed pixel being the result of switching between the corresponding input pixels wherein one of the images is motion video
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G5/00—Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators
- G09G5/36—Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the display of a graphic pattern, e.g. using an all-points-addressable [APA] memory
- G09G5/363—Graphics controllers
Definitions
- the present invention relates to the field of video and graphics displays. More particularly, the present invention relates to the field of efficient simultaneous display of video and graphics.
- the display In applications involving video displays, there is oftentimes a need for the display to include both a video screen as well as a graphics screen. These two elements may be mixed on a display if the hardware utilized is capable of performing such an operation.
- a common problem arises, as using multiple video buffers for each video image tends to consume large amounts of memory as well as bandwidth. Additional problems arise in the case where a hardware system only has the capacity to utilize one video buffer.
- FIG. 1 depicts a conventional process 100 in a system where two video buffers 110 , 120 are utilized to mix multiple video images 112 , 114 with a graphics frame 130 to produce a display frame 140 simultaneously containing both the video images 112 , 114 and the graphics frame 130 .
- a first image 112 is loaded into a first video buffer 110 and a second video image 114 is loaded into a second video buffer 120 .
- the video buffers 110 and 120 are sized as if the first image 112 and the second image 114 were to be full-size images and each displayed in the full display window.
- the two video buffers 110 , 120 are then mixed with the graphics frame 130 and the video images 112 , 114 are scaled to produce the display frame 140 as shown with both video images 112 , 114 .
- this process takes up a considerable amount of memory and bandwidth as multiple full-size buffers are needed when multiple video images are present.
- the present invention includes a method and device that allows efficient mixing of multiple video images with a graphics screen while utilizing only one video buffer.
- the present invention partitions the sole video buffer, pre-scales the plurality of video images and inserts them into the partitioned video buffer in a predetermined range of buffer addresses.
- the present invention mixes the partitioned video including the pre-scaled video images with the graphics screen to produce a video display including both a video screen and a graphics screen.
- a method produces a display frame.
- the display method comprises partitioning a video buffer into a plurality of sub-buffers wherein a size of each sub-buffer corresponds to a display size of a corresponding display window, scaling a first set of video data, wherein the first set of video data represents a first video image, further wherein the first set of video data is scaled to be loaded in a corresponding one of the plurality of sub-buffers, loading the first set of video data in to one of the plurality of sub-buffers of the video buffers and displaying the first set of video data in the video buffer in the display frame.
- the method also includes displaying the display frame on a display device.
- the display device can be a television.
- the first and second set of video data are received from a source device by an input/output interface in a playback device.
- the number of the plurality of sub-buffers generated is predetermined by a user, further wherein the sub-buffers are defined by an address range.
- the first set of data is loaded in to a predetermined sub-buffer according to the desired location of the first video image in the display frame.
- a playback device produces a display frame.
- the playback device comprises means for partitioning a video buffer into a plurality of sub-buffers wherein a size of each sub-buffer corresponds to a display size of a corresponding display window, means for scaling a first set of video data, wherein the first set of video data represents a first video image, further wherein the first set of video data is scaled to be loaded in a corresponding one of the plurality of sub-buffers, means for loading the first set of video data in to one of the plurality of sub-buffers of the video buffers and means for displaying the first set of video data in the video buffer in the display frame.
- the playback device also includes means for displaying the display frame on a display device.
- the display device can be a television.
- the first and second set of video data are received from a source device by an input/output interface in the playback device.
- the number of the plurality of sub-buffers generated by the means for partitioning is predetermined by a user, further wherein the sub-buffers are defined by an address range.
- a method produces a display frame.
- the method comprises partitioning a video buffer into a plurality of sub-buffers wherein a size of each sub-buffer corresponds to a display size of a corresponding display window, scaling a first set of video data, wherein the first set of video data represents a first video image, further wherein the first set of video data is scaled to be loaded in a corresponding one of the plurality of sub-buffers, loading the first set of video data in to one of the plurality of sub-buffers of the video buffers and mixing a graphics frame and the video buffer for display.
- a second set of video data is scaled, further wherein the second set of video data represents a second video image.
- the method also includes displaying the display frame on a display device.
- the display device can be a television.
- the first and second set of video data are received from a source device by an input/output interface in a playback device.
- the number of the plurality of sub-buffers generated is predetermined by a user, further wherein the sub-buffers are defined by an address range.
- the first set of data is loaded in to a predetermined sub-buffer according to the desired location of the first video image in the display frame.
- a playback device produces a display frame.
- the playback device comprises a partitioning circuit configured to partition a video buffer into a plurality of sub-buffers wherein a size of each sub-buffer corresponds to a display size of a corresponding display window and a processor configured to scale a first set of video data, wherein the first set of video data represents a first video image, further wherein the first set of video data is scaled to be loaded in a corresponding one of the plurality of sub-buffers, wherein the processor is also configured to load the first set of video data in to one of the plurality of sub-buffers of the video buffers, and further wherein the processor is also configured to mix a graphics frame and the video buffer.
- the playback device also includes means for displaying the display frame on a display device.
- the display device can be a television.
- the first and second set of video data are received from a source device by an input/output interface in the playback device.
- the number of the plurality of sub-buffers generated by the means for partitioning is predetermined by a user, further wherein the sub-buffers are defined by an address range.
- a device to mixes a graphics frame and a video buffer to produce a display frame comprises an input/output interface to receive a stream of video data from a source device and a processing circuit coupled to the input/output interface, the processing circuit configured to receive the stream of video data, to partition the video buffer into a plurality of sub-buffers, to scale the video data, to load the stream of video data in to the plurality of sub-buffers and to mix the video buffer with the graphics frame to produce the display frame.
- the device also includes a display device coupled to the device through the input/output interface for displaying the display frame.
- the display device comprises a television.
- the source device comprises a home server.
- the device comprises a set-top box.
- the device resides within a home network.
- the video buffer is partitioned into a plurality of sub-buffers.
- the number of the plurality of sub-buffers created is predetermined by a user, further wherein the sub-buffers are defined by an address range.
- Each frame of the stream of video data is scaled before being loaded in to the video buffer.
- the stream of video data is loaded into a predetermined sub-buffer according to the desired location of the video image in the display frame.
- a set-top box to mixes a graphics frame and a video buffer to produce a display frame.
- the set-top box comprises an input/output interface to receive a stream of video data from a source device and a processing circuit coupled to the input/output interface, the processing circuit configured to receive the stream of video data, to partition the video buffer into a plurality of sub-buffers, to scale the video data, to load the stream of video data in to the plurality of sub-buffers and to mix the video buffer with the graphics frame to produce the display frame.
- the set-top box also includes a display device coupled to the set-top box through the input/output interface for displaying the display frame.
- the display device comprises a television.
- the source device comprises a home server.
- the set-top box resides within a home network.
- the video buffer is partitioned into a plurality of sub-buffers.
- the number of the plurality of sub-buffers created is predetermined by a user, further wherein the sub-buffers are defined by an address range.
- Each frame of the stream of video data is scaled before being loaded in to the video buffer.
- the stream of video data is loaded into a predetermined sub-buffer according to the desired location of the video image in the display frame.
- a network of devices mixes a graphics frame and a video buffer to produce a display frame.
- the network of devices comprises a source device to provide a stream of video data, a set-top box including an input/output interface to receive a stream of video data from the source device and a processing circuit coupled to the input/output interface, the processing circuit configured to receive the stream of video data, to partition the video buffer into a plurality of sub-buffers, to scale the video data, to load the stream of video data in to the plurality of sub-buffers and to mix the video buffer with the graphics frame to produce the display frame and a display device coupled to the set-top box through the input/output interface for displaying the display frame.
- the source device comprises a home server.
- the display device comprises a television.
- the video buffer is partitioned into a plurality of sub-buffers.
- the number of the plurality of sub-buffers created is predetermined by a user, further wherein the sub-buffers are defined by an address range.
- Each frame of the stream of video data is scaled before being loaded in to the video buffer.
- the stream of video data is loaded into a predetermined sub-buffer according to the desired location of the video image in the display frame.
- FIG. 1 illustrates a conventional simultaneous display process including multiple video windows and graphics.
- FIG. 2 illustrates a block diagram of an exemplary playback device according to the present invention.
- FIG. 3 illustrates a logical representation of a video buffer according to the present invention.
- FIG. 4 illustrates a simultaneous display process according to the present invention.
- FIG. 5 illustrates a method of simultaneous display of video and graphics on a display according to the present invention.
- Embodiments of the present invention include a playback device that efficiently displays video and graphics simultaneously.
- the device is powered on.
- the playback device utilizes a single video buffer and a single graphics screen, which are to be mixed or overlaid to create one single display including multiple video objects on the display at the same time with only one video buffer.
- the playback device of the present invention achieves this end by first partitioning the single video buffer into several sub-buffers having predetermined address ranges. The multiple video images are then scaled such that each image is inserted into a corresponding partition of the video buffer. When the video images are all inserted into the partitioned video buffer, then the video data within the video buffer is mixed with the graphics screen to produce the single display including both the video and graphics components.
- This playback device reduces memory and bandwidth consumption by utilizing a single video buffer, pre-scaling the video data representing each video window while still allowing multiple video images to be combined with a graphics screen.
- FIG. 2 illustrates an exemplary playback device according to the present invention.
- the playback device is a set-top box.
- the set-top box preferably controls the transmission of multimedia from a local storage device, such as a personal computer (PC), to a television or from a remote content provider, such as a cable television provider, to the television.
- the set-top box 210 includes an input/output (I/O) interface 220 , a secondary memory 230 , a system memory 240 , a central processing unit (CPU) 250 , a user interface 280 , and a decoder 260 all coupled via a bi-directional bus 270 .
- I/O input/output
- the I/O interface 220 preferably couples the set-top box 210 to a content source 215 for receiving multimedia and to the television 225 or other display device for displaying the multimedia received from the content source. In the preferred embodiment of the present invention, the mixed display is sent to the television for viewing.
- the I/O interface 220 can also be coupled to a conventional network, such as the Internet, to receive periodic software upgrades including new versions of operating software and new or upgraded applications.
- the I/O interface 220 also sends and receives control signals to and from the user interface 280 and the television.
- the user interface 280 preferably comprises a keypad and display, as is well known in the art. Alternatively, the user interface 280 comprises any conventional user interface.
- the secondary memory 230 stores the software used to enable operation of the set-top box 210 along with a plurality of applications. Exemplary applications include, but are not limited to a menu of available content such as an on-screen television guide, and display parameter settings such as color, tint, and brightness.
- the secondary memory 230 is flash memory. Alternatively, any conventional type of memory can be used.
- the system memory 240 includes random access memory (RAM).
- the system memory 240 can also include additional buffers, registers, and cache according to specific design implementations.
- Multimedia received by the set-top box 210 is preferably encrypted to prevent unauthorized access and use, and the decoder 260 decrypts the multimedia according to access authorization provided by the CPU 250 .
- the playback device 210 connects to a home server (not shown) to access encrypted content and to a license server (not shown) to obtain access to the rights for the playback.
- the playback device 210 preferably only initiates connections and does not accept connections initiated from other devices.
- the encrypted content is decrypted by the playback device 210 in secure hardware and preferably outputs the content as analog, macrovision-protected video.
- Functionality of the playback device 210 includes browsing capability, video playback, audio playback, and network configuration.
- the playback device 210 includes protocol stacks to allow for network connectivity with many different networking environments.
- FIG. 3 depicts a logical representation of a video buffer 300 of the preferred embodiment of the present invention.
- the video buffer 300 is partitioned into four sub-buffers 310 , 320 , 330 , 340 , each sub-buffer 310 , 320 , 330 , 340 having an address range derived from the original whole video buffer 300 .
- partitioning the video buffer 300 into four sub-buffers 310 , 320 , 330 , 340 is for exemplary purposes only. It will be apparent to one skilled in the art that the video buffer 300 may be partitioned into more or less sub-buffers 310 , 320 , 330 , 340 depending on system constraints and application requirements.
- the video buffer 300 is partitioned into a number of sub-buffers 310 , 320 , 300 , 340 corresponding to the number of separate windows being displayed by the set top box 210 ( FIG. 2 ) on the display device 325 .
- each sub-buffer 310 , 320 , 330 , 340 is of a proportionate size within the video buffer 300 corresponding to the window in which its video data is displayed.
- FIG. 4 depicts a simultaneous display process 400 according to the preferred embodiment of the present invention.
- a single video buffer 410 is utilized.
- the video buffer 410 is partitioned into four equal parts and the video images 412 , 414 are scaled to fit into an address range designated by one of the partitions.
- One advantage of utilizing only one video buffer 410 is that multiple video buffers require greater memory space. By pre-scaling the video data to fit into the appropriately sized sub-buffer 310 , 320 , 330 , 340 , the amount of video data required to be stored is reduced from a conventional system, in which video data representing a full-size video buffer is stored for each video window.
- each video buffer 110 , 120 requires 1 Mega Byte per second (MB/s) of bandwidth in normal operation.
- the conventional process 100 depicted in FIG. 1 would require 2 MB/s of bandwidth, 1 MB/s for each video buffer 110 , 120 .
- a partitioned video buffer 410 of the preferred embodiment of the present invention only requires bandwidth proportional to the percentage of the video buffer 410 used.
- the video images 412 , 414 occupy two of the four, or half of the partitions of the video buffer 410 .
- the display frame 140 in the conventional method of FIG. 1 and the display frame 430 of the present invention in FIG. 4 are similar in appearance, thereby magnifying the importance of a 75% bandwidth requirement.
- the video buffer 410 and the graphics frame 420 are mixed by overlaying one over the other to produce the display frame 430 as shown, resulting in a display frame having both the video images 412 , 414 and the graphics frame 420 , while utilizing only one video buffer 410 , thus greatly reducing the memory and bandwidth resources needed to conventionally produce such a display frame.
- a method generating a display frame including both a video component and a graphics component of the preferred embodiment of the present invention starts when a video component and a graphics component are to be combined into a display frame.
- a single video buffer representing a display area is partitioned into a plurality of sub-buffers according to any system constraints, application requirements or user needs.
- the data representing the video image is scaled in step 520 to the appropriate size required such that the data will fit into a corresponding partition of the video buffer.
- the scaled data is loaded into the partitioned video buffer in step 530 .
- each piece of scaled data is loaded into a preassigned partition according to the final desired display location of that scaled data in the display frame.
- the scaled data in step 530 is also loaded into the partitioned buffer such that the graphics frame will not overlay the video images created by the scaled data.
- Step 540 includes mixing the video and graphics components by overlaying one over the other.
- step 550 of the method returns to step 520 where scaling of the next frame of data begins. The method returns to step 520 rather than to step 510 in the preferred embodiment as the single partitioned buffer remains partitioned after the initial step 510 and does not require an additional partitioning.
- step 550 if there are no more frames to combine, the method ends.
- the set-top box of the present invention is powered on.
- the central processing unit of the set-top box partitions the video buffer in the system memory in to a number of sub-buffers corresponding to each of the separate display windows currently open on the display device.
- the size of each sub-buffer within the system memory is preferably proportionate to the size of its corresponding display window with the display.
- the set-top box receives video data from a content source such as a satellite dish or cable provider, etc.
- the video signal enters the set-top box via an I/O interface, where the first frame of the video data is loaded into the sub-buffers of the video buffer in the system memory.
- Each video image in the first frame of the video data is pre-scaled by the central processing unit, to fit the video image into its corresponding sub-buffer.
- Each video image is assigned to a corresponding sub-buffer according to the display window for which the video image will be displayed on the display device.
- the central processing unit will then preferably mix in any graphics frame by overlaying the graphics frame on to the video buffer and displaying this hybrid (video and graphics) display frame on the display device. If no graphics frame exists, then the video data within the video buffer will be displayed on the display device, with each sub-buffer being displayed in its appropriate display window. This process continues as long as there is video data entering the set-top box.
- the set-top box of the present invention utilizes a single video buffer and a single graphics screen, which are to be mixed or overlaid to generate one single display including multiple video objects on the display at the same time with only one video buffer.
- the sole video buffer is partitioned into sub-buffers each corresponding to a display window.
- the video data to be displayed in each display window is pre-scaled and then stored in its corresponding sub-buffer. Once all the video data has been loaded into the appropriate sub-buffers, then any appropriate graphics data is overlaid and the video data is displayed.
- This set-top box of the present invention reduces memory and bandwidth consumption by utilizing a single video buffer, pre-scaling the video data representing each video window while still allowing multiple video images to be combined with a graphics screen.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Computer Graphics (AREA)
- Physics & Mathematics (AREA)
- Computer Hardware Design (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Controls And Circuits For Display Device (AREA)
Abstract
Description
Claims (17)
Priority Applications (7)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/402,044 US7656461B2 (en) | 2003-03-27 | 2003-03-27 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US12/544,669 US7777814B2 (en) | 2003-03-27 | 2009-08-20 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US12/832,639 US8004611B2 (en) | 2003-03-27 | 2010-07-08 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US12/974,174 US8120709B2 (en) | 2003-03-27 | 2010-12-21 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US13/311,507 US8587727B2 (en) | 2003-03-27 | 2011-12-05 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US14/055,828 US8866974B2 (en) | 2003-03-27 | 2013-10-16 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US14/175,815 US10142562B2 (en) | 2003-03-27 | 2014-02-07 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/402,044 US7656461B2 (en) | 2003-03-27 | 2003-03-27 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/544,669 Continuation US7777814B2 (en) | 2003-03-27 | 2009-08-20 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
Publications (2)
Publication Number | Publication Date |
---|---|
US20040189623A1 US20040189623A1 (en) | 2004-09-30 |
US7656461B2 true US7656461B2 (en) | 2010-02-02 |
Family
ID=32989588
Family Applications (7)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/402,044 Active 2028-12-02 US7656461B2 (en) | 2003-03-27 | 2003-03-27 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US12/544,669 Expired - Fee Related US7777814B2 (en) | 2003-03-27 | 2009-08-20 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US12/832,639 Expired - Fee Related US8004611B2 (en) | 2003-03-27 | 2010-07-08 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US12/974,174 Expired - Fee Related US8120709B2 (en) | 2003-03-27 | 2010-12-21 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US13/311,507 Expired - Fee Related US8587727B2 (en) | 2003-03-27 | 2011-12-05 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US14/055,828 Expired - Lifetime US8866974B2 (en) | 2003-03-27 | 2013-10-16 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US14/175,815 Expired - Lifetime US10142562B2 (en) | 2003-03-27 | 2014-02-07 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
Family Applications After (6)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/544,669 Expired - Fee Related US7777814B2 (en) | 2003-03-27 | 2009-08-20 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US12/832,639 Expired - Fee Related US8004611B2 (en) | 2003-03-27 | 2010-07-08 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US12/974,174 Expired - Fee Related US8120709B2 (en) | 2003-03-27 | 2010-12-21 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US13/311,507 Expired - Fee Related US8587727B2 (en) | 2003-03-27 | 2011-12-05 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US14/055,828 Expired - Lifetime US8866974B2 (en) | 2003-03-27 | 2013-10-16 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US14/175,815 Expired - Lifetime US10142562B2 (en) | 2003-03-27 | 2014-02-07 | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
Country Status (1)
Country | Link |
---|---|
US (7) | US7656461B2 (en) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070291167A1 (en) * | 2006-06-16 | 2007-12-20 | Hiroyuki Inokawa | Video signal processing device and display |
US20100295863A1 (en) * | 2003-03-27 | 2010-11-25 | Sony Corporation | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US9013633B2 (en) * | 1999-04-28 | 2015-04-21 | Intel Corporation | Displaying data on lower resolution displays |
Families Citing this family (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4612779B2 (en) * | 2001-06-14 | 2011-01-12 | キヤノン株式会社 | COMMUNICATION DEVICE AND COMMUNICATION DEVICE VIDEO DISPLAY CONTROL METHOD |
TWI272533B (en) * | 2005-06-17 | 2007-02-01 | Lite On Technology Corp | A data stream buffer |
US20080062304A1 (en) * | 2006-09-07 | 2008-03-13 | Claude Villeneuve | Method and apparatus for displaying at least one video signal on at least one display |
US20100242070A1 (en) * | 2009-03-18 | 2010-09-23 | Sony Corporation | System and method for combining information content from data transmission network with television signal |
US8990435B2 (en) | 2011-01-17 | 2015-03-24 | Mediatek Inc. | Method and apparatus for accessing data of multi-tile encoded picture stored in buffering apparatus |
US9497466B2 (en) * | 2011-01-17 | 2016-11-15 | Mediatek Inc. | Buffering apparatus for buffering multi-partition video/image bitstream and related method thereof |
EP2740270A4 (en) | 2011-10-31 | 2015-04-29 | Mediatek Inc | Apparatus and method for buffering context arrays referenced for performing entropy decoding upon multi-tile encoded picture and related entropy decoder |
US9286328B2 (en) * | 2013-07-19 | 2016-03-15 | International Business Machines Corporation | Producing an image copy of a database object based on information within database buffer pools |
TWI520610B (en) * | 2013-08-01 | 2016-02-01 | 晨星半導體股份有限公司 | Television control apparatus and associated method |
CN108206969A (en) * | 2016-12-16 | 2018-06-26 | 北京酷我科技有限公司 | A kind of video playing quick start method and system |
CN109218740B (en) * | 2017-06-29 | 2022-01-04 | 武汉斗鱼网络科技有限公司 | Display method, storage medium, electronic device and system of double-screen video stream |
CN108550103A (en) * | 2018-03-07 | 2018-09-18 | 浙江华睿科技有限公司 | A kind of image processing method and device |
CN110677554B (en) * | 2019-10-31 | 2021-09-24 | 深圳市奥拓电子股份有限公司 | Video amplification method and device, electronic equipment and storage medium |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20020085013A1 (en) * | 2000-12-29 | 2002-07-04 | Lippincott Louis A. | Scan synchronized dual frame buffer graphics subsystem |
US6442206B1 (en) * | 1999-01-25 | 2002-08-27 | International Business Machines Corporation | Anti-flicker logic for MPEG video decoder with integrated scaling and display functions |
US6449664B1 (en) * | 1998-11-16 | 2002-09-10 | Viewahead Technology, Inc. | Two dimensional direct memory access in image processing systems |
US6470051B1 (en) * | 1999-01-25 | 2002-10-22 | International Business Machines Corporation | MPEG video decoder with integrated scaling and display functions |
US20080147968A1 (en) * | 2000-01-06 | 2008-06-19 | Super Talent Electronics, Inc. | High Performance Flash Memory Devices (FMD) |
Family Cites Families (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5686960A (en) * | 1992-01-14 | 1997-11-11 | Michael Sussman | Image input device having optical deflection elements for capturing multiple sub-images |
JP3428192B2 (en) * | 1994-12-27 | 2003-07-22 | 富士通株式会社 | Window display processing device |
US5852443A (en) | 1995-08-04 | 1998-12-22 | Microsoft Corporation | Method and system for memory decomposition in a graphics rendering system |
US6111582A (en) | 1996-12-20 | 2000-08-29 | Jenkins; Barry L. | System and method of image generation and encoding using primitive reprojection |
US6373526B1 (en) * | 1999-03-19 | 2002-04-16 | Sony Corporation | Processing of closed caption in different formats |
US6477314B1 (en) * | 1999-07-29 | 2002-11-05 | Geo Vision Inc. | Method of recording image data, and computer system capable of recording image data |
JP2002140722A (en) | 2000-08-23 | 2002-05-17 | Sony Computer Entertainment Inc | Device and method for plotting image removing aliasing |
PL350983A1 (en) | 2001-11-30 | 2003-06-02 | Advanced Digital Broadcast Ltd | Method of scanning a high-frequency signal band and apparatus therefor |
US7656461B2 (en) * | 2003-03-27 | 2010-02-02 | Sony Corporation | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
-
2003
- 2003-03-27 US US10/402,044 patent/US7656461B2/en active Active
-
2009
- 2009-08-20 US US12/544,669 patent/US7777814B2/en not_active Expired - Fee Related
-
2010
- 2010-07-08 US US12/832,639 patent/US8004611B2/en not_active Expired - Fee Related
- 2010-12-21 US US12/974,174 patent/US8120709B2/en not_active Expired - Fee Related
-
2011
- 2011-12-05 US US13/311,507 patent/US8587727B2/en not_active Expired - Fee Related
-
2013
- 2013-10-16 US US14/055,828 patent/US8866974B2/en not_active Expired - Lifetime
-
2014
- 2014-02-07 US US14/175,815 patent/US10142562B2/en not_active Expired - Lifetime
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6449664B1 (en) * | 1998-11-16 | 2002-09-10 | Viewahead Technology, Inc. | Two dimensional direct memory access in image processing systems |
US6442206B1 (en) * | 1999-01-25 | 2002-08-27 | International Business Machines Corporation | Anti-flicker logic for MPEG video decoder with integrated scaling and display functions |
US6470051B1 (en) * | 1999-01-25 | 2002-10-22 | International Business Machines Corporation | MPEG video decoder with integrated scaling and display functions |
US6996174B2 (en) * | 1999-01-25 | 2006-02-07 | International Business Machines Corporation | MPEG video decoder with integrated scaling and display functions |
US20080147968A1 (en) * | 2000-01-06 | 2008-06-19 | Super Talent Electronics, Inc. | High Performance Flash Memory Devices (FMD) |
US20020085013A1 (en) * | 2000-12-29 | 2002-07-04 | Lippincott Louis A. | Scan synchronized dual frame buffer graphics subsystem |
Cited By (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9013633B2 (en) * | 1999-04-28 | 2015-04-21 | Intel Corporation | Displaying data on lower resolution displays |
US20100295863A1 (en) * | 2003-03-27 | 2010-11-25 | Sony Corporation | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US20110090404A1 (en) * | 2003-03-27 | 2011-04-21 | Sony Corporartion | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US8004611B2 (en) * | 2003-03-27 | 2011-08-23 | Sony Corporation | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US8120709B2 (en) | 2003-03-27 | 2012-02-21 | Sony Corporation | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US20120075533A1 (en) * | 2003-03-27 | 2012-03-29 | Sony Electronics Inc. | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US8587727B2 (en) * | 2003-03-27 | 2013-11-19 | Sony Corporation | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US8866974B2 (en) * | 2003-03-27 | 2014-10-21 | Sony Corporation | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US10142562B2 (en) | 2003-03-27 | 2018-11-27 | Sony Corporation | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows |
US20070291167A1 (en) * | 2006-06-16 | 2007-12-20 | Hiroyuki Inokawa | Video signal processing device and display |
US8212797B2 (en) * | 2006-06-16 | 2012-07-03 | Sony Corporation | Video signal processing device and display |
Also Published As
Publication number | Publication date |
---|---|
US8004611B2 (en) | 2011-08-23 |
US8587727B2 (en) | 2013-11-19 |
US20090310024A1 (en) | 2009-12-17 |
US20100295863A1 (en) | 2010-11-25 |
US20040189623A1 (en) | 2004-09-30 |
US20140152896A1 (en) | 2014-06-05 |
US20140043537A1 (en) | 2014-02-13 |
US10142562B2 (en) | 2018-11-27 |
US8120709B2 (en) | 2012-02-21 |
US7777814B2 (en) | 2010-08-17 |
US8866974B2 (en) | 2014-10-21 |
US20110090404A1 (en) | 2011-04-21 |
US20120075533A1 (en) | 2012-03-29 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10142562B2 (en) | Method of and apparatus for utilizing video buffer in a multi-purpose fashion to extend the video buffer to multiple windows | |
KR100386579B1 (en) | format converter for multi source | |
US6429903B1 (en) | Video adapter for supporting at least one television monitor | |
US9066059B2 (en) | Method of and apparatus for maintaining smooth video transition between distinct applications | |
US10937120B2 (en) | Video processing system and processing chip | |
US20040017333A1 (en) | Universal serial bus display unit | |
US20080111823A1 (en) | Graphics processing system | |
EA003599B1 (en) | Data processing system using a dual monitor and controlling method of network system thereby | |
CN103873915A (en) | System and method for connecting a system on chip processor and an external processor | |
US7227584B2 (en) | Video signal processing system | |
WO2003085960A1 (en) | Method and apparatus for displaying graphics on an auxiliary display device using low level graphics drivers | |
TWI246326B (en) | Image processing circuit of digital TV | |
US20040194145A1 (en) | Leveraging PC processing power to handle CPU intensive tasks | |
US7474311B2 (en) | Device and method for processing video and graphics data | |
Gass | Architecture trends of MPEG decoders for set-top box | |
JP2001034248A (en) | Graphics display device |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: SONY CORPORATION, JAPAN Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:DUNN, TED;AMENDOLAGINE, JAMES;REEL/FRAME:013927/0134 Effective date: 20030327 Owner name: SONY ELECTRONICS INC, NEW JERSEY Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:DUNN, TED;AMENDOLAGINE, JAMES;REEL/FRAME:013927/0134 Effective date: 20030327 Owner name: SONY CORPORATION,JAPAN Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:DUNN, TED;AMENDOLAGINE, JAMES;REEL/FRAME:013927/0134 Effective date: 20030327 Owner name: SONY ELECTRONICS INC,NEW JERSEY Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:DUNN, TED;AMENDOLAGINE, JAMES;REEL/FRAME:013927/0134 Effective date: 20030327 |
|
FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
CC | Certificate of correction | ||
FPAY | Fee payment |
Year of fee payment: 4 |
|
FPAY | Fee payment |
Year of fee payment: 8 |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 12 |