Available in LEADTOOLS Multimedia toolkits. |
Multimedia DirectShow Filters
The LEADTOOLS Multimedia SDK includes a fully enabled development license for many components, as well as evaluation versions of several optional filters and video/audio codecs. You may consider licensing these for inclusion with your multimedia application to add value to your product. For instructions on licensing any of the DirectShow filters described below, see the Licensing section of the help file or contact oemsales@leadtools.com . Evaluation versions are noted as such in the Feature column.
Video Filters
Feature |
Filter/Interface(s) |
Header |
Comments |
Help Files |
Video Add |
LMVAdd.DLL - ILMVAdd, ILMVAddDisp |
ILMVAdd.h |
The add filter can be used for enhancing night vision or dropping more light on dark sources to clarify objects. The effect is performed in 2 ways, the first yields a frame rate divided by the number of added frames, while the other almost preserves the frame rate by using previous frames to output each sample. The output is of course not the same from the two methods. The filters functionality is exposed through both user and programming interfaces. |
|
Video Auto Contrast |
LMVAutoCont.DLL - ILMVAutoCont |
ILMVAutoCont.h |
The Auto Contrast filter performs color leveling at the luminance (grayscale) level, introducing no color cast. It makes the dark values darker and the light values lighter, which automatically enhances shadows and brightens the video stream. It also maximizes the tonal range of the image and enhances the contrast and intensity using the image's histogram and a color distribution-based algorithm. |
|
Video Auto Intensity |
LMVAutoInt.DLL - ILMVAutoInt |
ILMVAutoInt.h |
The Auto Intensity filter performs color leveling on the RGB channel
(the sum of the R, G, and B channels), introducing no color cast. |
|
Video Auto Level |
LMVAutoLvl.DLL - ILMVAutoLvl |
ILMVAutoLvl.h |
The Auto Level filter performs color leveling on the individual R, G
and B channels, treating each of the R, G and B channels as a separate
entity, introducing no color cast. |
|
Video Callback (evaluation) |
LMVCalBk2.DLL- ILMVCalBk, ILMVCalBkDisp |
ILMVCalBk2.h |
The Video callback filter can be used to capture or change video data in a multimedia stream. For example, you can apply any of the LEADTOOLS Image processing filters on the frame, and then render the results. |
|
Video Color |
LMVClr.DLL - ILMVColor |
ILMVClr.h |
The Color filter provides the ability to change some color attributes of the streaming video. The filter can change the video brightness, contrast, hue, and saturation, in addition to an invert colors option. The above changes can be applied to a selected area (rectangle) only by changing the "Effect Area" attributes in the property page or using SetCropAttributes from the programming interface. |
|
Video Color Replacement |
LMVClrRp.DLL - LMVColorRep |
ColorRep.h |
The filter replaces a color with another color over the video stream. The filter uses the HSV color space. |
|
Video Crop (evaluation***) |
LMVCrop2.DLL - ILMVCrop, ILMVCropDisp |
ILMVCrop2.h |
The Crop filter is used to extract areas from a source movie, a graphical representation is provided to show and modify the desired rectangle position and size. The cropped rectangle can be as small as 1x1. The filters functionality is exposed through both user and programming interfaces. |
|
Video Deblocking |
LMVDblck.DLL - ILMVDeblock |
ILMVDblck.h |
The deblocking filter is a DirectShow transform filter that performs deblocking on a video stream. The deblocking is applied to raw RGB data and is not related to a specific decoder output. The filter accepts block size and first block offset parameters to deblocking paths and the beginning of the blocked area. If the block size and first block offset do not match the blocks in the passed video sample, the filter is not expected to give satisfactory results. Two algorithms are currently offered to perform deblocking, 2-Lines and 4-Lines. The filter exposes its functionality through both user and programming interfaces. |
|
Video Deinterlace (evaluation***) |
LMVDeitr2.DLL - ILMVDeinterlace, ILMVDeinterlaceDisp |
ILMVDeinterlace2.h |
The deinterlace filter converts interlaced video to make it a progressive
scan video. |
|
Video Edge Enhance |
LMVEdgEnh.DLL - ILMVEdgEnh |
ILMVEdgEnh.h |
The edge enhancer filter is a DirectShow transform filter that performs edge enhancement on a video stream. The filter exposes its functionality through both user and programming interfaces. |
|
Video Emboss |
LMVEmbs.DLL - ILMVEmboss, ILMVEmbossDisp |
ILMVEmboss.h |
This filter offers embossing a video stream providing different parameters to control the effect. The effect can be applied to a selected area (rectangle) only by changing the "Effect Area" attributes in the property page or using SetCropAttributes from the programming interface. |
|
Video Frame Controller (evaluation***) |
LMVFramCtrl2.DLL - ILMVFramCtrl |
ILMVFramCtrl2.h |
The Frame Rate Control filter provides the ability to change the frame rate of the passing video stream. |
|
Video Dynamic Rate Control (evaluation***) |
LMVDynRateCtrl.DLL - ILMVDynRateCtrl |
ILMVDynCtrl.h
|
The Dynamic Rate Control filter provides the ability to change the playback rate of the passing video stream. |
|
Video Gamma Correction |
LMVGamma.DLL - ILMVGamma |
ILMVGamma.h |
This filter performs gamma correction to a video stream. Possible gamma values are between 1 and 500. |
|
Video Histogram Equalize (evaluation) |
LMVHstg2.DLL - ILMVHistogEq |
ILMVHstg2.h |
This filter performs Histogram Equalization to a video stream. Equalization can be done for a single channel; Red, Green, or Blue, or for all channels; master. |
|
Video Histogram View (evaluation)
|
LMVHstg2.DLL - ILMVHistogVw |
ILMVHstg2.h |
Histogram View filter draws the running histogram of a video stream in its property page. The filter also provides access to the histogram array through its programming interface. The histogram can be viewed for a single channel or for all channels. |
|
Video EFX Aging |
LMVMiscFX.DLL - ILMVAging, ILMMCommon |
LMVMiscFX.h |
The EFX aging filter gives a movie the look and feel of an old style movie (Color or B&W). |
|
Video EFX BumpMap |
LMVMiscFX.DLL - ILMVBumpMap, ILMMCommon |
LMVMiscFX.h |
The EFX bump map filter embeds the texture of an image or frame into the movie frames. |
|
Video EFX Dizzy |
LMVMiscFX.DLL - ILMVDizzy, ILMMCommon |
LMVMiscFX.h |
The EFX dizzy filter rotates, zooms and blurs movie frames to create a dizziness-like effect. |
|
Video EFX Glass Tile |
LMVMiscFX.DLL - ILMVGlassTile, ILMMCommon |
LMVMiscFX.h |
The EFX glass tile filter will create a stained glass effect on each movie frame. |
|
Video EFX Lens |
LMVMiscFX.DLL - ILMVLens, ILMMCommon |
LMVMiscFX.h |
The EFX lens filter adds a fish eye-like effect to the movie. |
|
Video EFX Maze |
LMVMiscFX.DLL - ILMVMaze, ILMMCommon |
LMVMiscFX.h |
The EFX maze filter distorts the movie into a crystal maze. |
|
Video EFX Rain |
LMVMiscFX.DLL - ILMVRain, ILMMCommon |
LMVMiscFX.h |
The EFX rain filter adds rain drops to the video. |
|
Video EFX Fire |
LMVMtnFX.DLL - ILMVFire, ILMMCommon |
LMVMtnFX.h |
The EFX fire filter draws flames around a moving object. |
|
Video EFX Ghost |
LMVMtnFX.DLL - ILMVGhost, ILMMCommon |
LMVMtnFX.h |
The EFX ghost filter makes moving objects invisible. |
|
Video EFX Hologram |
LMVMtnFX.DLL - ILMVHologram, ILMMCommon |
LMVMtnFX.h |
The EFX hologram filter draws a holographic-like shadow of a moving object. |
|
Video EFX Lightning |
LMVMtnFX.DLL - ILMVLightning, ILMMCommon |
LMVMtnFX.h |
The EFX lightning filter draws lightning sparks around a moving object. |
|
Video EFX Motion Blur |
LMVMtnFX.DLL - ILMVMotionBlur, ILMMCommon |
LMVMtnFX.h |
The EFX motion blur filter creates a motion blur effect for moving objects. It gives the appearance of a random glow around the motion. |
|
Video EFX Motion Emboss |
LMVMtnFX.DLL - ILMVMotionEmboss, ILMMCommon |
LMVMtnFX.h |
The EFX motion emboss filter applies an Emboss effect to moving objects. |
|
Video EFX Motion Mosaic |
LMVMtnFX.DLL - ILMVMotionMosaic, ILMMCommon |
LMVMtnFX.h |
The EFX motion mosaic filter applies a mosaic effect to moving objects. |
|
Video EFX Motion Scan |
LMVMtnFX.DLL - ILMVMotionScan, ILMMCommon |
LMVMtnFX.h |
The EFX motion scan filter will scan one line per frame and draw it to the destination. This gives the effect of distorting the moving objects. |
|
Video EFX Particles |
LMVMtnFX.DLL - ILMVParticles, ILMMCommon |
LMVMtnFX.h |
The EFX particles filter distorts an object, when it moves, into small particles. It then joins the particles to reform the object when it stops moving. |
|
Video EFX Streak |
LMVMtnFX.DLL - ILMVStreak, ILMMCommon |
LMVMtnFX.h |
The EFX streak filter shows moving objects as they are traced in slow motion. |
|
Video EFX Wave |
LMVMtnFX.DLL - ILMVWave, ILMMCommon |
LMVMtnFX.h |
The EFX wave filter makes waves around moving objects. |
|
Video Mosaic |
LMVMosc.DLL - ILMVMosaic, ILMVMosaicDisp |
ILMVMosaic.h |
Mosaic effect transforms any image into something that looks as though it were created by positioning a number of tiling elements, each of constant color and an approximate size. This filter applies the mosaic effect to a video stream with the ability to set the mosaic square size. The mosaic effect can be applied to a selected area (rectangle) only by changing the "Effect Area" attributes in the property page or using SetCropAttributes from the programming interface. |
|
Video Motion Detection (evaluation) |
LMVMtnDet2.DLL - ILMVMtnDet, ILMVMtnDetUserCallback |
ILMVMtnDet2.h |
The filter compares the current frame with the previous frame. Every time there is a difference between frames, the filter calls a user callback. You can programmatically find the rectangles where motion is detected. |
|
Color Space Converter |
LMVYUVxf.DLL - none |
None |
The Color Space Converter filter can accept a variety of YUV and RGB formats and convert them to any YUV and RGB formats supported as input. Currently, neither a user interface is available nor a programming interface. |
|
RGB Converter |
LMVRGBxf.DLL - ILMVConvRGB |
ILMVRGB.h |
This is an RGB color space converter that supports conversion between different RGB formats. The filter supports the following formats: RGB1 (gray and palettized), RGB4 (gray and palettized), RGB8 (gray and palettized), RGB565, RGB555, RGB24, RGB32, LGRY12 and LGRY16. The input or output format can be set to AUTO, to enable free negotiation with the up or down stream filter. The filters functionality is exposed through both user and programming interfaces. |
|
Video Rotation (evaluation) |
LMVRot2.DLL - ILMVRotation |
ILMVRot2.h |
The Rotation filter enables rotating a video stream by the standard angles; 0, 90, 180, and 270 in addition to flip and reverse options. The filters functionality is exposed through both user and programming interfaces. |
|
Video Resize (evaluation***) |
LMVRsz2.DLL - ILMVResize |
ILMVRsz2.h |
The Resize filter is used to change the dimensions of a source movie; the result is a new media, with new dimensions and size. The resize filter offers four types of resizing algorithms: Bresenham, Resample, Bicubic interpolation and Normal. The user interface, as will as the programming interface, friendly enable the selection of the filter parameters; Width, Height, aspect ratio, etc. In addition to the ability to select any desired size through specifying the width and height, the user can select a ratio size (i.e. 2X, Normal, X/2, ...). The filter also supports outputting video with non-square pixels by specifying 4:3, 16:9 or other custom output aspect ratio. You can also correct video of incorrect input aspect ratio by overriding the input aspect ratio. |
|
Video Image Overlay (evaluation) |
LMVIOvLy2.DLL - ILMVIOvLy |
ILMVIOvLy2.h |
This is a DirectShow transform filter that enables overlaying images on a video stream. |
|
Video Overlay (evaluation) |
LMVVOvLy2.DLL - ILMVVOvLy |
ILMVVOvLy2.h |
This is a DirectShow transform filter that enables overlaying video and images on a video stream |
|
Video Text Overlay (evaluation) |
LMVTOvLy2.DLL - ILMVTOvLy |
ILMVTOvLy2.h |
This is a DirectShow transform filter that performs text overlaying on a video stream. It supports a wide range of text options from font and wrapping to rotation and transparency. The filter exposes its functionality through both user and programming interfaces. |
|
Video UnSharpMask (evaluation) |
LMVUsMsk2.DLL - ILMVUshrpMsk |
ILMVUsMsk2.h |
The unsharp mask filter is a DirectShow transform filter that performs a sharpening effect on a video stream. The filter exposes its functionality through both user and programming interfaces. The processing time of the filter is high, so the filter will be slow, and low frame rate is expected. All the functionality in the filters property page is available via the programming interface of the filter. |
|
Still Image Reader |
LTStlImgRd2.DLL - ILTStlImgRd |
ILTStlImgRd.h |
This filter allows DirectShow applications (such as Windows Media Player) to read a variety of still image file formats, including:
|
|
Still Image Writer |
LTStlImgWrt2.DLL - ILTStlImgWrt |
ILTStlImgWrt.h |
This filter allows any DirectShow application (such as Windows Media Player) to save the video stream to a variety of different still image file formats, including:
|
Audio Filters
Feature |
Filter/Interface(s) |
Header |
Comments |
Help
Online Help
Files |
Audio Callback |
LMACalBk.DLL- ILMACalBk, ILMACalBkDisp |
ILMACalBk.h |
The Audio callback filter can be used to capture or change audio in a multimedia stream. |
|
Audio Chorus |
LMAChrs.DLL - ILMAChorus, ILMAChorusDisp |
ILMAChorus.h |
The chorus filter can be used to add a chorus effect. The chorus effect makes one instrument sound like many instruments are being played. It adds some thickness to the sound. |
|
Audio Converter (evaluation) |
LMAConv.DLL- ILMAConverter |
ILMAConverter.h |
The Audio Converter filter can be used to change the sampling rate of an audio stream (use this when you need to force the audio to have a certain sampling rate). |
|
Audio Detection (evaluation) |
LMADet2.DLL - ILMADet, ILMADetUserCallback |
ILMADet2.h |
The Audio Detection filter determines whether there is sound or not. The filter uses a silence threshold: every sound above this threshold is considered sound, everything below is considered silence. |
|
Audio Echo |
LMAEcho.DLL - ILMAEcho, ILMAEchoDisp |
ILMAEcho.h |
The echo filter can be used to add an echo effect. The echo effect reflects a sound wave back to its source with sufficient strength and time lag to be separately distinguished. |
|
Audio Flanger |
LMAFlng.DLL - ILMAFlanger, ILMAFlangerDisp |
ILMAFlanger.h |
The flanger filter can be used to add a flange effect. Flanging has a characteristic sound often described as a "whooshing" sound, similar to the sound of a jet plane flying overhead. |
|
Audio Phaser |
LMAPhase.DLL - ILMAPhaser, ILMAPhaserDisp |
ILMAPhase.h |
The phase filter can be used to add the distinctive phaser sound. This distinctive sound is obtained by creating one or more notches in the frequency domain that eliminate sounds at the notch frequencies. Notches are created by filtering the signal, and mixing the filter output with the input signal. The flanger, a specific type of phasing, also makes use of notches. |
|
Audio Volume |
LMAVol.DLL - ILMAVolume |
ILMAVolume.h |
The Audio Volume filter allows the user to change the volume of sound samples. |
|
Audio VU Meter |
LMAVUMeter.DLL - ILMAVUMeter, ILMAVUMeterDisp |
ILMAVUMeter.h |
The VU meter filter can be used to add a VU meter to an audio stream. The VU meter allows the user to retrieve left and right channel audio power levels. The filter can be used to monitor the output level of other filters placed before it in the stream. |
|
MPEG Audio Converter |
LMAMpgCnv.DLL - None |
None |
This audio filter is needed to convert the audio mediatype coming from the Microsoft MPEG2 Demultiplexer/Splitter so it can be played by the MPEG Audio Converter. This filter is not needed if you use the LEAD MPEG2 Demultiplexers (Program or Transport) to play MPEG2 files. |
Miscellaneous Filters
Feature |
Filter/Interface(s) |
Header |
Comments |
Help
Online Help
Files |
ISO Multiplexer** |
LMISOMux.DLL DSKernel2.DLL |
|
The LEAD ISO Multiplexer can be used to create files based on the ISO base file format described in ISO/IEC 14496-12. The ISO base file format should not be confused with the files used to store CD images or DVD images (which have the .ISO extension). The LEAD ISO Multiplexer does not support every video and audio compression. The following compressions are supported:
|
|
Ogg Multiplexer |
LMOggMux.DLL
|
|
The Ogg Multiplexer can be used to create Ogg files. This filter will accept any media type (any audio or video compressor). Ogg is a new file format, made popular by Vorbis audio compression. |
|
MPEG-1 Multiplexer* |
LMMpg1Mx2.DLL DSKernel2.DLL
|
|
The LEAD MPEG-1 Multiplexer filter can be used to create MPEG-1 files. This filter requires compression compatible with MPEG-1 Audio and MPEG-1 Video compression. We recommend using the LEAD MPEG Audio Encoder and LEAD MPEG2 Video Encoder in conjunction with this filter. |
|
MPEG-2 Multiplexer* |
LMMpg2Mx2.DLL DSKernel2.DLL |
The LEAD MPEG-2 Multiplexer can be used to create MPEG-2 Program files. The following audio compressions are supported:
The following video compressions are supported:
There are two main reasons to create MPEG-2 Program files:
|
||
MPEG-2 Transport Multiplexer |
LMMpg2MxT.DLL DSKernel2.DLL |
The LEAD MPEG-2 Transport Multiplexer can be used to create MPEG-2 Transport files. The following audio compressions are supported:
The following video compressions are supported:
This filter also supports adding private data streams to the file (KLV or generic private data). MPEG-2 Transport files are used mainly for streaming video. This type of video is used extensively in these types of applications:
|
||
MPEG2 Transport UDP Source |
LMUDPSrc.DLL |
ILMUDPSrc.h |
The LEAD MPEG2 Transport UDP Source can be used to read data from a UDP or TCP/IP port. The data is usually in MPEG-2 Transport format, as defined in ISO/IEC 13818-1. The filter is also capable of receiving MPEG-2 Transport data packetized with RTP packets conforming to RFC 1889 and RFC 1890. This filter supports the standard IFileSourceFilter interface. Use the IFileSourceFilter::Load method to let the LEAD MPEG2 Transport Source filter know where to read the data from. |
|
MPEG2 Transport UDP Sink |
LMUDPSnk.DLL |
ILMUDPSnk.h |
The LEAD MPEG2 Transport UDP Sink can be used to sending data to a UDP or TCP/IP port. The data is usually in MPEG-2 Transport format, as defined in ISO/IEC 13818-1. The filter supports the standard IFileSinkFilter interface. Use the IFileSinkFilter::SetFileName method to let the filter know where to send the data to. |
|
ISO Demultiplexer** |
LMISODmx.DLL |
None |
The LEAD ISO Demultiplexer can be used to play files based on the ISO base file format described in ISO/IEC 14496-12. The ISO base file format should not be confused with the files used to store CD images or DVD images (which have the .ISO extension). The following common file formats use the ISO base file format:
The ISO demultiplexer can be used to parse the above file formats. |
|
Ogg Splitter |
LMOggSpl.DLL |
None |
The Ogg Splitter can be used to play Ogg files. Ogg is a new file format, made popular by Vorbis audio compression. |
|
DVD Writer** |
LTDVDWrt2.DLL |
ILTDVDWriter2.h |
This is used to create DVD images, which can be later burned to a DVD
disk using the DVD Burner filter. This filter requires the LEAD MPEG-2
Multiplexer filter. |
|
DVD Burner** |
LTDVRBrn2.DLL |
IILTDVDBurner2.h |
This is used to burn DVD and ISO images to a DVD disk. It is included in the LEADTOOLS DVD Module. |
|
Network Connection Manager |
LMNetCon2.DLL |
None |
This is used to implement the low
level network connection protocols. This filter is used internally by
the LEAD Network Sink Filter and the LEAD Network Source Filter for the
TCP/IP connections. |
|
Network Multiplexer Filter** |
LMNetMux2.DLL |
ILMNetMux2.h |
This is used to multiplex video and audio together using the LEAD streaming format. It is used together with the LEAD Network Sink in applications that send video over TCP/IP. You need to use video and audio compressors for efficient streaming. This filter will not do any compression. It is included in the Video Streaming Module. |
|
Network Sink Filter** |
LMNetSnk2.DLL |
ILMNetSnk2.h |
This is used to send data multiplexed with the LEAD Network Multiplexer. It is used together with the LEAD Network Multiplexer in applications that send video over TCP/IP. It is included in the Video Streaming Module. |
|
Network Source Filter** |
LMNetSrc2.DLL |
ILMNetSrc2.h |
This filter connects to the LEAD Network Sink filter and receives multiplexed data over TCP/IP connections. This filter is used with the LEAD Network Demultiplexer in client demos shipped with the Video Streaming Module. It is included in the Video Streaming Module. |
|
Network Demultiplexer Filter** |
LMNetDmx2.DLL |
ILMNetDmx2.h |
This filter will demultiplex (split) data in the LEAD streaming format. This filter is used with the LEAD Network Source in client demos shipped with the Video Streaming Module. It can also be used to create LEADTOOLS Streaming Files. Note: This filter will not do any decompression. You need video and audio decoders to play compressed streams. It is included in the Video Streaming Module. |
|
Screen Capture Filter |
LMScrCap2.DLL |
ILMScrCap2.h |
Used for capturing video from the screen. Normally, the video is compressed using the LEAD Screen Capture Encoder. |
* Included in the LEADTOOLS DVD Module once you sign the license agreement.
** Included in the LEADTOOLS Video Streaming Module once you sign the license agreement.
*** Included in the LEADTOOLS DVD Module or the LEADTOOLS Video Streaming Module once you sign the license agreement.
**** Included in the LEADTOOLS Medical Imaging with Medical Multimedia Module once you sign the license agreement.