1. Field of Invention
The present application relates to multi-display technology, in particular to a display system and method capable of supporting multi-display.
2. Description of Related Prior Art
With the development of various interface techniques, the notebook as a portable computer is required to support a variety of peripheral interfaces such as USB, serial and parallel port, network interface, VGA/DVI/HDMI interface and Displayport interface in the future. Accordingly, the notebook computer will become complicated and clumsy in order to support all types of these interfaces.
In view of the above issues, a concept has been proposed in the art that is based on the port replicator or docking station. That is, a peripheral device is designed as an attachment to the notebook computer and placed near the computer or under the base of the computer in a wired way, such as USB/PCIe, or in a wireless way, such as UWB. All kinds of interfaces can be integrated into the peripheral device, and thus the interface design for the notebook computer can be remarkably simplified since it needs to support only a few interfaces most commonly used. In fact, the docking station has been becoming one of the most important attachments in the field of the notebook computer.
According to Patent Reference 1 (US2004117538), the video card in a host is removed, and display signals generated by OS are directly outputted to a USB interface. And, the signals are transmitted from the interface to another remote module, in which VGA signals are regenerated from the transmitted signals and outputted directly to a VGA display device.
Patent Reference 2 (US2002135584) discloses a video graphic adapter which drives a sub display device of a dual-mode display device with USB interface. In Patent Reference 2, video signals outputted from USB are directly stored in a memory area, and the stored video signals are converted into analog VGA signal output by a D/A converter.
Furthermore, video needs to be transferred wirelessly to a remote terminal for display in many situations, for example, the communication between a wireless projector and a notebook computer. In this case, the notebook computer needs to perform a real-time acquisition of screen data and deliver the data wirelessly to the projector for output. Most of schemes for wireless display are based on such wireless technology as defined in IEEE802.11, however. In this way, the high throughput required by the display device cannot be well achieved due to the bandwidth of IEEE802.11, and thus it is necessary to employ a deeply lossy compression scheme. This would result in the problem that the displayed image cannot resemble and synchronize with the original one very well, leading to the degrading of screen quality and color distortion. Meanwhile, the above scheme burdens both of the computer and the display device with a heavy computational load, and thus affects the system performance to a great extent. Moreover, cost tends to be uncontrollable, since the display side usually requires a typical embedded system including CPU/OS/DSP to retrieve the video and output. In conclusion, because of the limited bandwidth of the existing 802.11 system, screen data of high-quality cannot be transmitted timely to the display device side while the computer is playing real-time video, especially video of high-quality.
The present invention is made in consideration of the above problems, and an object of the present invention is to provide a display system and method supporting multi-display.
In one aspect of the present invention, a display system is provided comprising a data transmitting apparatus built in a computer and a data receiving apparatus connected to a remote VGA/DVI display device, in which the data transmitting apparatus comprises a collecting unit for collecting screen data and/or audio data in video signals and a local control unit for encoding said screen data and/or audio data and transmitting said encoded screen data and/or audio data; the data receiving apparatus comprises a remote control unit for controlling the reception of said screen data and/or audio data and decoding it, a buffer unit for controlling the audio/video data decoded by the remote control unit to be placed into a memory for buffering, and an output unit for converting the buffered screen data and/or audio data into a format supported by the VGA/DVI display device and/or audio format.
Preferably, the data transmitting apparatus further comprises a compression unit for compressing said screen data and/or audio data by use of a predetermined compression algorithm, and the data receiving apparatus further comprises a decompression unit for decompressing the compressed screen data and/or audio data by use of a predetermined decompression algorithm.
Preferably, the display system supports multi-session function. The data transmitting apparatus further comprises an input/output mapping unit for mapping a remote input/output operation into a local input/output operation, and the data receiving apparatus further comprises an input/output interface unit connecting a keyboard/mouse for an input/output operation by a user.
Preferably, the data receiving apparatus is realized with embedded CPU, FPGA or chip.
Preferably, the screen data and/or audio data are obtained by the operating system of the host.
Preferably, the data transmitting apparatus captures data for display by virtualizing a video card device with Mirror Driver under Windows.
Preferably, the screen data and/or audio data are transmitted via USB/PCIe interface.
Preferably, the screen data and/or audio data are transmitted in the form of UWB.
In another aspect of the present invention, a method for a display system supporting multi-display comprises steps of collecting screen data and/or audio data from a host, transmitting said screen data and/or audio data to a remote display device and/or acoustic device, converting said screen data and/or audio data into the supported VGA/DVI format and audio format and presenting the converted data by the display device and/or acoustic device.
Preferably, the method further comprises a step of compressing said screen data and/or audio data by use of a predetermined compression algorithm before the transmitting step and a step of decompressing the compressed screen data and/or audio data before the converting step.
Preferably, the method further comprises a step of transmitting a control command, and the display device and/or acoustic device receive said control command to switch between operating modes.
Preferably, the collecting step comprises obtaining the screen data and/or audio data by the operating system of the host.
Preferably, data for display is captured by virtualizing a video card device with Mirror Driver under Windows.
With the above configuration of the present invention, requirement on bandwidth is lowered since only the dynamically changing part of the screen data in the video signals or the full-screen data is first compressed and then transmitted to the display device side via USB interface or in the form of UWB. In addition, the present invention can be realized with a low-cost embedded CPU, FPGA or application-specific chip, with a reduced complexity of the system.
The above advantages and features of the present invention will be more apparent from the following detailed description taken conjunction with the drawings in which:
Hereafter, the preferred embodiments of the present invention will be elaborated with reference to the figures, throughout which the same reference signs denote the same or like components, though shown in different figures. For the purpose of clarity and conciseness, a detail account of known functions and structures incorporated here will be omitted in case that the subject of the present invention be obscured.
As shown in
The data transmitting apparatus 100 includes a video collecting unit 110 which collects dynamically changing screen data or full-screen data in current video signals, from the host like a notebook computer, a audio collecting unit 120 which collects audio signals synchronously with the current video signals or separate audio signals from the host to obtain audio data, a data compression unit 130 which compresses the screen data and the audio data collected by the video collecting unit 110 and the audio collecting unit 120 with a predetermined compression algorithm, such as MPEG or JPEG compression algorithm or proprietary algorithm, so as to output compressed data, a packetizing unit 140 which form the compressed data into data packets of a corresponding format based on a predetermined protocol, a first USB/PCIe controller 160 which transfers the data packets formed by the packetizing unit 140 via a USB/PCIe interface, and a transmitting-side controller 150 which controls the above respective units, such as control on synchronization of audio and video data, whether to compress certain data packets as well as signaling interaction, for example, mode switching and the like.
The data receiving apparatus 200 includes a second USB/PCIe controller 260 which resembles the first USB/PCIe controller 160 in the data transmitting apparatus 100 and controls the reception of data packets transmitted from the data transmitting apparatus 100 via a USB/PCIe interface, an unpacketizing unit 240 which unpacketizes the data packets received by the USB/PCIe controller 260 according to the same protocol as that adopted in packetizing so as to obtain compressed or uncompressed screen data/audio data, a receiving-side controller 250 which controls the respective units in the data receiving apparatus 200, such as control on synchronization of audio and video data, whether to compress certain data packets as well as signaling interaction, a data decompression unit 230 which, when the receiving-side controller 250 determines that the data packets received currently have been compressed, decompresses the compressed data with a predetermined data compression algorithm so as to obtain screen data and audio data, and a video/audio output unit 210 which converts the screen data into video signals of VGA format and outputs them to the VGA/DVI/DP display device 300 for display, as well as performs D/A conversion on the audio data to output to the acoustic device 400.
Besides, the data receiving apparatus 200 includes a buffering unit (not shown) which puts the decoded audio and video data into a memory for buffering. In this case, the output unit 210 converts the buffered screen data into video data of VGA/DVI/DP format to output to the VGA/DVI/DP display device 300.
When the receiving-side controller 250 determines that the data packets outputted from the unpacketizing unit 240 is uncompressed, these data packets are transferred to the buffering unit and then to video/audio output unit directly, and the screen data or audio data are converted into corresponding display signals and analog audio signals for display on the VGA/DVI display device 300 and for output from the acoustic device 400, respectively.
As described above, the receiving-side controller 250 in the data receiving apparatus 200 can determine whether the received data packet is compressed or uncompressed and a video or audio data packet on the basis of the ‘Type’ field therein. In the case that the data in the data packet have been compressed, the compressed data is decompressed by the data decompression unit 230 so as to obtain the corresponding screen data and/or audio data.
In addition, if the video configuration played at the host side has been changed, for example, the display mode of the host is changed from 1024×768 to 720×480, the transmitting-side controller 150 controls the packetizing unit 140 to form the configuration information of display device into a control signaling packet, which is in turn transferred to the data receiving apparatus 200 via the USB interface. The receiving-side controller 250 in the data receiving apparatus 200 reconfigures the remote display device according to the configuration information of display device in the received control signaling packet in preparation for subsequent display.
The conversion module in
As shown in
Also, the data receiving apparatus 200 further has a keyboard/mouse interface 270 for connecting an input means 270 like a keyboard/mouse. As such, after the connection of the input means 270, a user can operate remotely, such as text processing and network browsing, in the same manner as performed locally. In this case, the receiving-side controller 250 transfers via the USB/PCIe bus various inputted commands and control information by the input means 270 to the data transmitting apparatus 100 at the host side, where these commands and information are mapped into local operations by the keyboard/mouse I/O mapping unit 170 and then sent to the multi-session processing drive 180 for processing.
As can be seen from
The units in the data transmitting apparatus 100 other than the first USB/PICe controller 160 can each be realized in software in the operating system of the host.
Naturally, it will be appreciated by those skilled in the art that the compression processing function may not be provided when the data transmitting apparatus at the host side is realized in the form of a data card of the host, and the description thereof will not be repeated.
As shown in
The host here can be all kinds of computer mainframes, such as the mainframe for a PC for a server, a notebook computer, a handheld device like a cell phone and PDA, etc.; the display device 300 can be various display devices, such as the monitor (LCD, CRT or the like) of a computer, a projector or a television.
In the data transmitting apparatus 100, the data collecting unit 510 acquires display data from the host OS. The packetizing unit 520 forms the display data obtained by the data collecting unit 510 into corresponding data message in accordance with a protocol for network transmission. The first UWB transceiving unit 530 transfers the data message to the data receiving apparatus 200 wirelessly with UWB.
In the transmitting apparatus 100, the transmitting-side controller 140 controls the first UWB transceiving unit 530 as well as performs, for example, authentication for both sides and negotiation on keys.
In the data receiving apparatus 200, the second UWB transceiving unit 610 receives wirelessly the data message from the data transmitting apparatus 100 with UWB. The receiving-side controller 620 controls the second UWB transceiving unit 610 as well as performs, for example, authentication for both sides and negotiation on keys. The unpacketizing unit 630 unpacketizes the data message received by the second UWB transceiving unit 610 into screen data in accordance with the protocol. The output unit 640 transfers the screen data to the display device 300 for outputting.
It should be noted that the present embodiment transmits digital pixel signals with UWB, and in the extreme case the frame rate of transmission is the frame rate at which the video or any content is played, that is, about 30 frames per second for video, other than transmitting at 60/75 frames per second of the refresh frequency of a video card.
On the other hand, in order to display pixel data at the receiving side in real-time manner, the data receiving apparatus 200 as another embodiment has a simple display control mechanism (i.e., the function of a video card) and can utilize the transmitted pixel data of 25 frames directly to perform high-speed refresh processing, for example, at 60/75 frames per second.
In the data transmitting apparatus 100 of the second embodiment, all the units except the first UWB transceiving unit 530 can be realized in software of the operating system on the host.
Obviously, it will be appreciated by those skilled in the art that the compression processing function may not be provided when the data traffic is not so large.
Now referring to
At step S711, the host is powered on and enters WinLogon.
At step S712, a display process is initiated at WinLogon interface.
WinLogon provides GINA.dll, and different logon modes for Windows can be customized. The operation of initiating the display process can be completed by modifying relevant parameters in GINA.
Then, the display process carries out a series of operation as follows.
At step S713, the connection as a TCP client to a display serving as a TCP server is established.
At step S714, after a successful connection, Bridge Driver is started, which is primarily responsible for data processing and transport.
At step S715, Mirror is bundled to a virtual desktop such that the image data of the desktop can be obtained.
At step S716, Mirror is started to obtain pixel data. Here, Mirror is short for Mirror driver which, under Windows, vitualizes a video card device to capture the Windows screen. The bundling and starting of Mirror can be fulfilled by Windows GDI.
At step S717, Bridge Driver opens a soft interrupt (22H) by means of IDT (Interrupt Dispatch table), and Mirror conducts an invocation via an assemble instruction int 22H.
At step S718, a transport thread is initiated and an interrupt is opened to obtained information sent out by Mirror. The transport thread takes charge of the transport of image data.
At step S719, Bridge Driver retrieves the information on screen change in response to the interrupt sent by Mirror.
At step S720, the rectangular region of screen change is extracted based on the information provided by Mirror and added to a list.
At step S721, the list is obtained for subsequent transport processing.
At step S722, a port-reading transport thread is responsible mainly for processing related to transport, including data synchronization, message response and the like.
At step S723, according to the obtained list of rectangular regions at step S721, corresponding data is retrieved and then transferred to the display device.
The solution shown in
The foregoing description is intended to only illustrate the embodiments of the present invention. Those skilled in the art will understand that any modification and partial substitution made within the scope of the present invention should be encompassed by the scope of the present invention in the claims. Thus, the scope of the present invention should be defined by the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
2005 1 0130572 | Dec 2005 | CN | national |
2006 1 0140642 | Sep 2006 | CN | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/CN2006/003416 | 12/14/2006 | WO | 00 | 6/6/2008 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2007/068211 | 6/21/2007 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6941395 | Galang et al. | Sep 2005 | B1 |
7484112 | Noorbakhsh et al. | Jan 2009 | B2 |
7518624 | Ford et al. | Apr 2009 | B2 |
20030208779 | Green et al. | Nov 2003 | A1 |
20040117538 | Liu | Jun 2004 | A1 |
20040181806 | Sullivan | Sep 2004 | A1 |
20070011712 | White et al. | Jan 2007 | A1 |
20070061414 | Bakke | Mar 2007 | A1 |
20070094699 | Chen | Apr 2007 | A1 |
20070260785 | Chen | Nov 2007 | A1 |
20080052428 | Liang et al. | Feb 2008 | A1 |
20080148307 | Nielsen et al. | Jun 2008 | A1 |
20080225771 | Guo et al. | Sep 2008 | A1 |
20090029647 | Wei et al. | Jan 2009 | A1 |
20090109332 | Lin | Apr 2009 | A1 |
20090174826 | Ford et al. | Jul 2009 | A1 |
Number | Date | Country |
---|---|---|
1336761 | Feb 2002 | CN |
2005204183 | Jul 2005 | JP |
Number | Date | Country | |
---|---|---|---|
20090141186 A1 | Jun 2009 | US |