Video cameras for computer systems are becoming more common in today's computing environment. Further, more and more applications are capable of utilizing captured video from video cameras. However, access to video cameras by computer system applications is generally limited to a single application. Device drivers for such video cameras are mutually exclusive, prohibiting shared use of the video cameras amongst multiple applications. Once an application acquires the video capture device driver, no other application can receive output from the video camera until the controlling application relinquishes control of the driver.
In the following detailed description, reference is made to the accompanying drawings that form a part hereof, and in which is shown by way of illustration specific embodiments in which the inventive subject matter may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice them, and it is to be understood that other embodiments may be utilized and that structural, logical, and electrical changes may be made without departing from the scope of the inventive subject matter. Such embodiments of the inventive subject matter may be referred to, individually and/or collectively, herein by the term “invention” merely for convenience and without intending to voluntarily limit the scope of this application to any single invention or inventive concept if more than one is in fact disclosed.
The following description is, therefore, not to be taken in a limited sense, and the scope of the inventive subject matter is defined by the appended claims.
The functions or algorithms described herein may be implemented in hardware, software or a combination of software and hardware. The software comprises computer-executable instructions stored on a computer readable medium such as memory or other type of storage device. The term “computer readable medium” is also used to represent carrier waves on which the software may be transmitted. Further, such functions correspond to modules, which are software, hardware, firmware, or any combination thereof. Multiple functions are performed in one or more modules as desired, and the embodiments described are merely examples. The software may be executed on a digital signal processor, an Application Specific Integrated Circuit (ASIC), microprocessor, or other type of processor operating in a system, such as a personal computer, server, router, or other device capable of processing data, including network interconnection devices.
Some embodiments implement the functions in two or more specific interconnected hardware modules or devices with related control and data signals communicated between and through the modules, or as portions of an application-specific integrated circuit. Thus, the exemplary process flow is applicable to software, firmware, and hardware implementations or combinations thereof.
As used herein, the terms “video” is used to encompass captured images, still and moving. Thus, the term “video” is intended as a broad term and is not intended to limit the breadth of this disclosure or the claims.
As used herein, the term “mutually exclusive” is used in describing device drivers that prohibiting shared use of the video cameras amongst multiple applications. Such “mutually exclusive” device drivers are acquired by a first application and cannot be acquired by another application until the first application releases the driver.
The inventive subject matter provides various systems, methods, and software to share a video capture device, such as a video camera, amongst multiple applications on a computing system. Some such embodiments include a server process that acquires exclusive control over a mutually exclusive video capture device driver and writes captured video to a memory buffer that is accessible to other applications on a system. One or more other processes on the system then read the video from the memory buffer and provide the video to one or more applications. Various embodiments are illustrated in the figures and described below.
The computing device 101 represents any type of computing device capable of operating with a video capture device 1118. Some examples of such a computing device 101 include a computer, a personal computer, a server, a personal digital assistant (PDA), or virtually any other type of computing device 101. The computing device 101 can also be of any architecture utilizing virtually any operating system.
The processor 102 of the computing device 101 represents a digital signal processor or processing unit of any type of architecture, such as an ASIC (Application-Specific Integrated Circuit), a CISC (Complex Instruction Set Computer), RISC (Reduced Instruction Set Computer), VLIW (Very Long Instruction Word), or hybrid architecture, although any appropriate processor may be used. The processor 102 executes instructions. The processor 102 also includes a control unit that organizes data and program storage in memory, such as memory 104, and transfers data and other information in and out of the computing device 101, such as to and from the video capture device 118, and, in some embodiments, to and from one or more network connections (not shown) over an optional network interface (not shown). Although only a single processor is illustrated within computing device 101, the computing device 101, in some embodiments, includes multiple processors 102.
The memory 104 represents one or more mechanisms to store data. For example, the memory 104, in various embodiments, includes one or more of a random access memory (RAM), magnetic disk storage media, optical storage media, flash memory devices, and/or other volatile and non-volatile machine-readable media. In other embodiments, the memory includes any appropriate type of storage device or memory 104. Although only one memory 104 is shown, multiple memories 104 of various types and multiple types of storage devices can be present.
The video capture device 118, in some embodiments, is a device capable of capturing video, such as a video camera. In various embodiments, the video capture device 118 can capture single frames of video, multiple frames over time, or both. The video capture device 118 can be coupled to the computing device 101 in various ways. For example, the video capture device 118 can be operatively coupled to the computing device 101 via a cable, such as a Universal Serial Bus (USB) cable. Other embodiments include the video capture device operatively coupled to the computing device 101 via a wireless connection such as a Bluetoothe wireless connection, or other wired or wireless connection device or technology capable of delivering captured video from the video capture device 118 to the computing device 101.
In some embodiments, the video capture device 118 can capture color video at a rate of 30 frames per second at a resolution of 640×480 pixels. This video capture device 118 can capture still images at a resolution of 1.3 megapixels. In other embodiments, the video capture device 118 is capable of capturing video and still images at greater and lesser resolutions and at greater and lesser frame rates per second. In some embodiments, the properties of captured video can be altered by adjusting one or more parameters of the video capture device 118. Some such settings include the resolution at which video is captured. Other settings include frame rate, sharpness, brightness, focus, zoom, color, camera angle or position, and virtually any other setting to adjust one or more properties or subjects of captured video.
Some further embodiments of the video capture device 118 include a microphone. In some such embodiments, the video capture device 118 can deliver a multiplexed signal to the computing device 101, the multiplexed signal comprising video and audio.
The video capture device 118 is operatively coupled to the computing device 101, as described above. The video capture device driver 114 receives video from the video capture device 118. In some embodiments, the video capture device driver 114 also provides commands to the video capture device 118. Such commands include commands to alter the properties of the video captured by the video capture device 118. The video capture device driver 114, in some embodiments, is a mutually exclusive device driver, allowing only a single application operating on the computing device 101 to use the video capture device driver 114. In some embodiments, the video capture device driver 114 is a driver supplied by the vendor/manufacturer of the video capture device 118.
The video server process 116 is a process that acquires control over the video capture device driver 114. The video server process 116 further allocates a shared memory buffer 112 in the memory 104 if the shared memory buffer 112 has not yet been allocated. The video server process 116, once the video capture device driver 114 has been acquired and the shared memory buffer 112 has been allocated, writes video received from the video capture device driver 114 to the shared memory buffer 112. The writing of video to the shared memory buffer 112 may be performed frame-by-frame, each frame overwriting a previous frame. In some embodiments, there are two or more shared memory buffers 112. In such multi-shared memory buffer 112 embodiments, the video is written in an alternating fashion between the shared memory buffers.
The shared memory buffer 112 is an area of memory allocated to be available to the video server process 116 and other applications. The shared memory buffer 112 is of a size at least large enough to hold a video frame. In embodiments including more than one shared memory buffer 112, each shared memory buffer 112 is of a size at least large enough to hold a video frame. Video frames written to the shared memory buffer 112 by the video server process 116 can be read by other applications, such as a virtual video capture device driver 110. In some embodiments, applications, such as application 106 and application 108, can obtain video directly from the shared memory buffer 112.
The virtual video capture device driver 110, in some embodiments, appears on the computing device 101 as an actual video capture device driver that can be acquired by applications operable on the computing device 101. The virtual video capture device driver 110 reads video from the shared memory buffer 112 and provides the video to one or more applications. Some embodiments of the system 100 include more than one virtual video capture device driver 110. In some embodiments, the virtual video capture device driver 110 is mutually exclusive, allowing only a single application to acquire the virtual video capture device driver 110. In some such embodiments, there are multiple mutually exclusive virtual video capture device drivers to allow more than one application to simultaneously receive video. In other embodiments, as illustrated in
In some embodiments, the virtual video capture device driver 110 performs transformations on video according to one or more settings. In some embodiments, the video server process 116 receives video from the video capture device driver 114 captured by the video capture device 118 at a high quality, or even of the highest quality the video capture device 118 is capable of. The video server process 116 then proceeds to write this high quality video to the shared memory buffer 112. In some embodiments, the video server process performs one or more transforms on the video, altering one or more video properties, prior to writing the video to the shared memory. The virtual video capture device driver 110 then reads the video from the shared memory buffer 112 and performs any necessary transformations to the video according to one or more settings prior to providing the video to a requesting application. In some embodiments, the settings include settings for one or more of resolution, frame size, frame rate, sharpness, brightness, or virtually any other setting relating to the properties of the video. In various embodiments, these settings are provided by an application or by user manipulation of the settings.
Application 106 and application 108 are intended to reflect video-enabled applications. There can be any number of such video-enabled applications operating on the computing device. Examples of such video-enabled applications include video recording applications, video conferencing applications, instant messenger applications, video surveillance applications, and virtually any other type of application capable of receiving or requesting video originating with a video capture device 118.
The example illustration of
The shared memory buffer of the method 300 is accessible by one or more applications, such as a virtual video capture device driver. The virtual video capture device driver provides video to video-enabled applications, appearing to the applications as an actual device driver.
In some embodiments, allocating a shared memory buffer includes allocating a space in a system memory, such as a random access memory (RAM). The amount of memory allocated varies depending on the properties of the video captured. Generally, higher resolution video will require allocating a larger shared memory buffer. In addition, the format used in capturing and transmitting the video may affect the memory size required. Further, if the video is multiplexed to include associated audio, the memory space required may be affected.
In some embodiments of the method 400, creating one or more virtual device drivers 406 comprises creating a fixed number of mutually exclusive virtual device drivers. In some embodiments, the fixed number is two, while in other embodiments the fixed number is ten. However, any number of mutually exclusive device drivers can be created by the method 400. In some embodiments, the number of mutually exclusive device drivers is the maximum number of video-enabled applications that can receive video from the method 400 at one time. In some other embodiments, if all of the mutually exclusive device drivers are utilized, a system implementing the method 400 dynamically creates one or more additional mutually exclusive device drivers.
In some embodiments, a mutually exclusive device driver is a copy of a vendor-supplied device driver, altered in a fashion to cause the mutually exclusive device driver to read video data from a shared memory buffer rather than from a video capture device. In other embodiments, the mutually exclusive device driver comprises software written to appear as a device driver for a video capture device couplable to a system implementing the method 400.
Microsoft's DirectShow® architecture is based upon filters. Generally, a filter performs one operation on a data stream, such as a stream of video frames. Some filter operations include reading files or streams, passing data to a video card or other peripheral device, and transforming data to a particular frame size or to a particular format, such as MPEG-1 (Moving Pictures Experts Group; International Standards Organization/International Electrotechnical Commission Standard 11172) or RGB (Red-Green-Blue).
Generally, there are three filter classes: source filters that obtain video data, transform filters that transform video data in some manner, and render filters that output the video data. Multiple filters can be linked together in a fashion so the output of one filter is the input for the next. Groups of linked filters are called a filter graph. Generally, a filter graph includes at least a source filter and a render filter.
The method 500 includes acquiring exclusive control of a video capture device driver 502 and allocating a shared memory buffer 504. The method further includes receiving a video stream from the video capture device driver into a filter graph 506, obtaining a video stream into a source filter, wherein the source filter appears as a video capture device driver 508, and acquiring the source filter by an application, wherein the source filter is used by the application's filter graph to obtain the video stream from the shared memory buffer 510.
Receiving the video stream from the video capture device driver into a filter graph 506 includes a source filter that obtains the video stream and provides the video stream to a render filter. The render filter then renders the video stream, frame-by-frame, to a shared memory buffer.
Obtaining a video stream into a source filter, wherein the source filter appears to applications as a video capture device driver 508 includes a source filter that can be acquired as a device driver for obtaining the video stream. The source filter, once acquired by an application is then used as the source filter for the application's filter graph to obtain the video stream from the shared memory buffer.
The example illustration of
It is emphasized that the Abstract is provided to comply with 37 C.F.R. § 1.72(b) requiring an Abstract that will allow the reader to quickly ascertain the nature and gist of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims.
In the foregoing Detailed Description, various features are grouped together in a single embodiment to streamline the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claimed embodiments of the invention require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed embodiment. Thus, the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separate embodiment.
It will be readily understood to those skilled in the art that various other changes in the details, material, and arrangements of the parts and method stages that have been described and illustrated in order to explain the nature of this inventive subject matter may be made without departing from the principles and scope of the inventive subject matter as expressed in the subjoined claims.