Home    MontiVision DirectShow SDK Documentation Prev Next
MontiVision Development Kit
Product Release Notes
What's new?
Installation
Overview
Components
The MontiVision Workbench
How to use the Workbench
How to insert an Filter
How to make a connction between two filter
How to change filter properties
How to get mediatypes of a pin or connection
How to delete a connection
How to delete a filter
How to find a filter
How to select a filter, pin or connection
How to make a video visible
How to preview a video stream
Workbench Menus and Commands
File menu commands
Edit menu commands
View menu commands
Graph menu commands
Extras menu commands
Help menu commands
Context menu commands
Status Bar
Toolbar
Sorting Filters
MontiVision DirectShow Filter
Common filter functions
MV Absolute Difference
MV Advanced Optical Flow
MV Affine Transformation
MV Alignment
MV Audio Test Source
MV Batch Image File Source
MV Background Subtraction
MV Bayer To Gray
MV Bayer To RGB
MV Bitmap Overlay
MV Blob Counter
MV Blob Finder
MV BlockRecording
MV Buffer Access
MV Camera Calibration
MV Camera Syncronisation
MV Camera Undistortion
MV Color Filter
MV Color Channel Mixer
MV Color Space Converter
MV Color To Gray
MV Color Twist
MV Constant Framerate
MV Convolution
MV Cooccurrence
MV Crop
MV Deinterlace
MV DeInterlace Temporal
MV Delay
MV Demo Source
MV Demultiplexer
MV DPS Renderer
MV DPS Source
MV Dyadic Arithmetic
MV Dyadic Logic
MV Fast Color Filter
MV Frame Access
MV Gauge
MV GDI Overlay
MV Gray To Color
MV Image File Source
MV Image Grabber
MV Image File Renderer
MV Integral
MV Inverse
MV I/O Bool Source
MV I/O Comparator
MV I/O Logic
MV I/O Not
MV I/O Renderer
MV I/O RS232
MV I/O RS232 Trigger Source
MV I/O Switch Source
MV I/O Textfile Renderer
MV I/O Textfile Source
MV I/O To String
MV IP Camera Source
MV Look Up Table
MV Mean
MV Mean Profile
MV Merge Frames
MV Mirror
MV MJPEG Compressor
MV MJPEG Decompressor
MV Mondic Arithmetic
MV Mondic Logic
MV Morphology
MV Motion Detection
MV Motion Direction
MV Multi File Writer
MV Network Renderer
MV Network Source
MV Nonlinear Filter
MV Object Tracker
MV Optical Flow
MV Playlist Source
MV Polar
MV Presence Detection
MV Profile
MV Recording
MV ReInterlace
MV Resize
MV Resized Rotation
MV Rotate90
MV Rotation
MV Segmentation
MV Select Mediatype
MV Separate Fields
MV Smooth Sequence
MV Splitter
MV Text Overlay
MV Ticker Overlay
MV Topography
MV Trigger Source
MV Video File Overlay
MV Video Overlay
MV Video Scaler
MV Watchdog
MV Zoom
Filter Event Mechanism
MontiVision DirectShow Filter SDK
Create a new Filter SDK DLL
Implement your custom Algorithm
Register the Filter SDK DLL
Use the new DirectShow Filter
Debugging a DirectShow Filter
Configure a Filter SDK DirectShow Filter
MontiVision Smart ActiveX Control
MV Smart Control Functions
MV Smart Control Interfaces
IMVSmartControl
IMVSCFilterGraph
IMVSCFilterGraph2
IMVSCVideoWindow
IMVSCVideoWindow2
IMVSCFullScreen
IMVSCSetFile
IMVSCSetSourceFilter
IMVSCSelectInput
IMVSCSetupVideoStream
IMVSCSetupVideoStream2
IMVSCClock
IMVSCFilterProperties
IMVSCLog
IMVSCCameraControl
IMVSCFilterEvents
IMVSCMediaSeeking
IMVSCMediaSeeking2
IMVSCQualityProperties
IMVSCFilterData
IMVSCCommonProperties
IMVSCExtDeviceControl
IMVSCVideoControl
IMVSCAnalogVideoFormat
IMVSCTVTuner
IMVSCTVAudio
Application Development with the MV Smart Control
Visual Basic 6.0
Visual Basic .NET
Visual C++ 6.0
Visual C++ .NET
Borland Delphi
MV Smart Control Samples
AviPlay Sample
CropVideo Sample
DirFinder Sample
FindObject Sample
FullScreen Sample
ImageStream Sample
IP Camera Sample
LiveDraw Sample
LoadFromString Sample
LumeneraCameraProperties Sample
MotionDetection Sample
PutBitmap Sample
SendReceiveRS232 Sample
MV Smart Control How To's
How to handle Input Events (Mouse, Keyboard) of the Video Window
How to Select and Configure a Video Input Device
How to handle Multiple Video Outputs
How to use Fullscreen Functionality
How to access the Results of a MontiVsion DirectShow Filter
MontiVision Utility ActiveX Controls
Video Source Combo Box
Video Format Combo Box
Video Size Combo Box
Input Selection Combo Box
Frame Rate Combo Box
Seeking Slider
Filter Property Page Display
Trigger Button
MontiVision I/O Controls
MVIODisplay
MVIOMonitor
MVIOLed
MVIOOutput
VMR Wrapper ActiveX Control
MV VMR Wrapper Interfaces
IMVVMRWrapper
IMVVMRFilterConfig
IMVVMRMixerControl
IMVVMRMixerBitmap
MV VMR Wrapper Sample Applications
VMR Control Sample
VMR Bitmap Overlay Sample
Extended Video Source ActiveX Control
MV Extended Video Source Control Interfaces
IMVExtendedVideoSource Interface
IMVLumeneraCustomConfig Interface
_IMVExtendedVideoSourceEvents Interface
MontiVision Tools
Getting Started
Create a MontiVision Project
Create a MontiVision Project using the MontiVision Workbench
Create new DirectShow Filters using the MontiVision Filter SDK
Use the new DirectShow Filter in your MontiVision Project
Integrate the MontiVision Project into your Application
Distribute your Application
Distributing your Applications
Application Development Examples
Apply standard Image Processing Operators to a Video Stream
Process a Sequence of Still Images, Do Batch Processing
Make your Existing Algorithms DirectShow compatible
Creating your own Image/Video Processing DirectShow Filters
Access the Image Data of a Video Stream directly from within a Windows Application
Capture Still Images from a running Video Stream
Convert a Video Stream to a Sequence of Still Images or vice versa
Sample Applications using the Smart Control
Camera Calibration
Additional HowTo's
How to Set Up Visual C++ for the MontiVision Development Kit
How to Set Up Borland Delphi for the MontiVision Development Kit
How to Set Up Borland Delphi 2005 for the MontiVision Development Kit
Interface Reference
_IMVFilterPropertyControlEvents
_IMVSeekingSliderEvents
_IMVSmartControlEvents
_ISelectInputComboBoxEvents
_IVideoFormatComboBoxEvents
_IVideoSizeComboBoxEvents
_IVideoSourceComboBoxEvents
IMVAbout
IMVAdvancedOpticalFlow
IMVAdvancedOpticalFlow2
IMVAffineTransformation
IMVAlignment
IMVAudioTestSource
IMVAutoCalcSetup
IMVBackgroundSubtraction
IMVBatchFileSource2
IMVBatchFileSource3
IMVBatchFileSource
IMVBinary
IMVBitmapOverlay
IMVBitmapOverlay2
IMVBlobCounter
IMVBlobCounter2
IMVBlobCounter3
IMVBlobCounter4
IMVBlobFinder
IMVBlobFinder2
IMVBlobFinder3
IMVBlobPostProcessing
IMVBlobPreProcessing
IMVBlockRecording
IMVBufferAccess
IMVBufferAccessCallbackC
IMVBufferAccessCallbackVB
IMVCameraCalibration
IMVCameraSync
IMVCameraUndistortion
IMVColor
IMVColorChannelMixer
IMVColorTwist
IMVConstantFramerate
IMVConvolution
IMVCooccurrence
IMVCrop
IMVCrypt
IMVDeinterlace
IMVDeInterlaceTemporal
IMVDelay
IMVDemoSource
IMVDemoSource2
IMVDPSRenderer
IMVDPSSource
IMVDyArith
IMVDyLogic
IMVEnumAudioEncoder
IMVEnumVideoEncoder
IMVFastColor
IMVFilterData
IMVFilterEvents
IMVFilterInfo
IMVFilterPropertyControl
IMVFilterSDK
IMVFrameAccess
IMVFrameAccessCallbackC
IMVFrameAccessCallbackVB
IMVGauge
IMVGaugeCalculations
IMVGDIOverlay
IMVGray
IMVGrayToColor
IMVGrid
IMVHistogram
IMVHistogram2
IMVHistogram3
IMVImageCapture
IMVImageCapture2
IMVImageCapture3
IMVImageFileSource
IMVImageFileSource2
IMVImageFileSource3
IMVImageInfo
IMVIntegral
IMVIOBoolSource
IMVIOBoolSource2
IMVIOComparator
IMVIOIntRenderer
IMVIOIntSource
IMVIOIntSource2
IMVIOLogic
IMVIONot
IMVIORenderer
IMVIORS232
IMVIORS232DataASCII
IMVIORS232DataHex.htm
IMVIORS232RxTxConnection
IMVIORS232TriggerSource
IMVIOSwitchSource
IMVIOTextfileRenderer
IMVIOTextfileSource
IMVIOToString
IMVIPCameraSource
IMVIPCameraSource2
IMVLinFilter
IMVLookUpTable
IMVMask
IMVMean
IMVMeanProfile
IMVMerger
IMVMirror
IMVMonArith
IMVMonLogic
IMVMorphology
IMVMotionDetection
IMVMotionDetection2
IMVMotionDirection
IMVMultiFileWriter
IMVNetworkReceiveInfo
IMVNetworkRenderer
IMVNetworkRenderer2
IMVNetworkRenderer3
IMVNetworkSendInfo
IMVNetworkSource
IMVNetworkSource2
IMVNonLinFilter
IMVObjectTracker
IMVOpticalFlow
IMVOpticalFlow2
IMVPlaylist
IMVPlaylistSource
IMVPolar
IMVPresenceDetection
IMVProfile
IMVRecording
IMVRegionOfInterest
IMVReinterlace
IMVResize
IMVResizedRotation
IMVRotate90
IMVRotation
IMVSCAnalogVideoFormat
IMVSCCameraControl
IMVSCCommonProperties
IMVSCClock
IMVSCExtDeviceControl
IMVSCFilterData
IMVSCFilterEvents
IMVSCFilterGraph
IMVSCFilterGraph2
IMVSCFilterProperties
IMVSCFullScreen
IMVSCLog
IMVSCMediaSeeking
IMVSCMediaSeeking2
IMVSCQualityProperties
IMVSCSelectInput
IMVSCSetFile
IMVSCSetSourceFilter
IMVSCTVTuner
IMVSCTVAudio
IMVSCVideoControl
IMVSCSetupVideoStream
IMVSCSetupVideoStream2
IMVSCVideoWindow
IMVSCVideoWindow2
IMVSeekingSlider
IMVSetImageFormat
IMVSmartControl
IMVSeparateFields
IMVSmoothSequence
IMVTextOverlay
IMVTextOverlay2
IMVTextOverlay3
IMVTickerOverlay
IMVTickerOverlay2
IMVTopography
IMVTrigger
IMVTriggerFilter
IMVVideoFileOverlay
IMVVideoScaler
IMVVMRFilterConfig
IMVVMRMixerBitmap
IMVVMRMixerControl
IMVVMRWrapper
IMVWatchdog
IMVZoom
IMVZoomConfig
ISelectInputComboBox
IVideoFormatComboBox
IVideoSizeComboBox
IVideoSourceComboBox

IMVConvolution

The IMVConvolution interface is used to control the filter's image processing algorithm. Read the filter description to see how the filter is used. Read the remarks for implementation details.

get_NumOfKernels Returns the number of kernels used for convolution.
put_NumOfKernels Sets the number of kernels used for convolution.
get_SelectedKernel Returns the index of the kernel that is currently being modified.
put_SelectedKernel Sets the curent kernel index to be modified.
get_KernelCombination Returns the current kernel combination method.
put_KernelCombination Sets the current kernel combination method.
get_NumOfKernelColumns Returns the number of columns in the currently selected kernel.
put_NumOfKernelColumns Sets the number of columns in the currently selected kernel.
get_NumOfKernelRows Returns the number of rows in the currently selected kernel.
put_NumOfKernelRows Sets the number of rows in the currently selected kernel.
GetKernelValue Returns the kernel value at the specified position [X,Y].
SetKernelValue Sets the kernel value at the specified position [X,Y].
get_XAnchor Returns the horizontal anchor of the currently selected kernel.
put_XAnchor Sets the horizontal anchor of the currently selected kernel.
get_YAnchor Returns the vetical anchor of the currently selected kernel.
put_YAnchor Sets the vertical anchor of the currently selected kernel.
get_RightShift Returns the pixel right shift of the currently selected kernel.
put_RightShift Sets the pixel right shift of the currently selected kernel.

Header file: iMVConvolution.h
Interface definition language file: iMVConvolution.idl
Typelib: MVConvolution
Interface ID: IID_IMVConvolution

 

HRESULT get_NumOfKernels( [out, retval] int *piNumOfKernels );

Returns the number of kernels used to convolve with the video frames.

Parameter:

piNumOfKernels A pointer to an integer value that receives the number of kernels.

 

HRESULT put_NumOfKernels( [in ] int iNumOfKernels );

Sets the number of kernels used to convolve with the video frames.

Parameter:

iNumOfKernels The number of kernels.

 

HRESULT get_SelectedKernel( [out, retval] int *piSelectedKernel );

Returns the currently selected kernel.

Parameter:

piSelectedChannel A pointer to an integer value that receives the number of thel kernel that is currently selected.

 

HRESULT put_SelectedKernel( [in ] int iSelectedKernel );

Sets the currently selected kernel.

Parameter:

iSelectedChannel The number of the kernel to be modified.

 

HRESULT get_KernelCombination( [out, retval] int *piCombination );

Returns the method for kernel combination as MV_KERNEL_COMBINATION .

Parameter:

piCombination A pointer to an integer value that receives the combination method.

 

HRESULT put_KernelCombination( [in ] int iCombination );

Sets the method for kernel combination as MV_KERNEL_COMBINATION .

Parameter:

iCombination The combination method.

 

HRESULT get_NumOfKernelColumns( [out, retval] int *piColumns );

Returns the number of columns in the selected kernel.

Parameter:

piColumns A pointer to an integer value that receives the number of columns.

 

HRESULT put_NumOfKernelColumns( [in ] int iColumns );

Sets the number of columns in the selected kernel.

Parameter:

iColumns The desired number of columns.

 

HRESULT get_NumOfKernelRows( [out, retval] int *piRows );

Returns the number of rows in the selected kernel.

Parameter:

piRows A pointer to an integer value that receives the number of rows.

 

HRESULT put_NumOfKernelRows( [in ] int iRows );

Sets the number of rows in the selected kernel.

Parameter:

iRows The number of rows.

 

HRESULT GetKernelValue( [in ] int iColumn, [in ] int iRow, [out, retval ] int *piValue );

Returns the matrix value for the selected kernel using the position passed [iColumn, iRow].

Parameter:

iColumn Matrix column
iRow Matrix row
piValue A pointer to an integer value that receives the matrix value.

 

HRESULT SetKernelValue( [in ] int iColumn, [in ] int iRow, [in ] int iValue );

Sets the matrix value for the selected kernel at position [iColumn, iRow].

Parameter:

iColumn Matrix column
iRow Matrix row
iValue Matrix value

 

HRESULT get_XAnchor( [out, retval] int *piAnchor );

Returns the horizontal anchor of the selected kernel.

Parameter:

piAnchor A pointer to an integer value that receives the horizontal anchor.

 

HRESULT put_XAnchor( [in ] int iAnchor );

Sets the horizontal anchor of the selected kernel.

Parameter:

iAnchor The horizontal anchor.

 

HRESULT get_YAnchor( [out, retval] int *piAnchor );

Returns the vertical anchor of the selected kernel.

Parameter:

piAnchor A pointer to an integer value that receives the vertical anchor.

 

HRESULT put_YAnchor( [in ] int iAnchor );

Sets the vertical anchor of the selected kernel.

Parameter:

iAnchor The vertical anchor.

 

HRESULT get_RightShift( [out, retval] int *piShift );

Returns the current pixel right shift that is used to scale the convolution result of the current kernel.

Parameter:

piShift A pointer to an integer value that receives the pixel right shift.

 

HRESULT put_RightShift( [in ] int iShift );

Sets the current pixel right shift that is used to scale the convolution result of the current kernel.

Parameter:

iShift The pixel right shift.

 

 

Filter specific structures and enumerators

typedef enum _MV_KERNEL_COMBINATION
{
    MV_MV_COMBINATION_SUM= 0,
    MV_MV_COMBINATION_SUMSQ,
    MV_MV_COMBINATION_SUMSQROOT,
    MV_MV_COMBINATION_MAX,
    MV_MV_COMBINATION_MIN
} MV_KERNEL_COMBINATION;

 

 

Remarks

The following is an example sequence using the interface.

IMVConvolution *pIMVConvolution;

...


// Use two kernels
pIMVConvolution->put_NumOfKernels( 2 );
 
// Select kernel one
pIMVConvolution->put_SelectedKernel( 0 );
 
// Init kernel one
pIMVConvolution->put_NumOfKernelColumns( 3 );
pIMVConvolution->put_NumOfKernelRows( 3 );
pIMVConvolution->put_XAnchor( 1 );
pIMVConvolution->put_YAnchor( 1 );
pIMVConvolution->put_RightShift( 0 );
 
// Create vertical sobel matrix
//  1   2   1
//  0   0   0
// -1  -2  -1
// Column 0, Row 0
pIMVConvolution->SetKernelValue( 0, 0, 1 );
// Column 0, Row 1
pIMVConvolution->SetKernelValue( 0, 1, 0 );
// Column 0, Row 2
pIMVConvolution->SetKernelValue( 0, 2, -1 );
 
...
 
// Select kernel two
pIMVConvolution->put_SelectedKernel( 1 );
 
// Init kernel two
pIMVConvolution->put_NumOfKernelColumns( 3 );
pIMVConvolution->put_NumOfKernelRows( 3 );
pIMVConvolution->put_XAnchor( 1 );
pIMVConvolution->put_YAnchor( 1 );
pIMVConvolution->put_RightShift( 0 );
 
// Create horizontal sobel matrix
// 1   0  -1
// 2   0  -2
// 1   0  -1
// Column 0, Row 0
pIMVConvolution->SetKernelValue( 0, 0, 1 );
// Column 0, Row 1
pIMVConvolution->SetKernelValue( 0, 1, 2 );
// Column 0, Row 2
pIMVConvolution->SetKernelValue( 0, 2, 1 );
 
...
 
pIMVConvolution->put_KernelCombination( MV_MV_COMBINATION_SUM );