Redigera

Dela via


CDrawImage class

[The feature associated with this page, DirectShow, is a legacy feature. It has been superseded by MediaPlayer, IMFMediaEngine, and Audio/Video Capture in Media Foundation. Those features have been optimized for Windows 10 and Windows 11. Microsoft strongly recommends that new code use MediaPlayer, IMFMediaEngine and Audio/Video Capture in Media Foundation instead of DirectShow, when possible. Microsoft suggests that existing code that uses the legacy APIs be rewritten to use the new APIs if possible.]

The CDrawImage class is a helper class that manages drawing for a video renderer filter. All drawing operations are performed using GDI. This class does not provide any support for rendering with DirectDraw. The CDrawImage class requires that the owning filter also use the CBaseWindow class, which manages the video window. The CDrawImage constructor takes a pointer to the CBaseWindow object.

The following diagram shows the preferred way to use this class in a custom video renderer filter.

custom video renderer using cdrawimage

To use this class, do the following:

Allocators

The filter shown in the previous diagram uses a custom allocator class, CImageAllocator. This allocator creates DIBs in shared memory, using the GDI CreateDIBSection function. The samples created by the allocator are CImageSample objects.

If the filter owns the allocator for the connection, then the media samples are guaranteed to be CImageSample objects. In that case, the CDrawImage object can optimize drawing by using BitBlt or StretchBlt. Otherwise, it must use the slower SetDIBitsToDevice or StretchDIBits functions. The faster option is implemented by the CDrawImage::FastRender method, the slower option by the CDrawImage::SlowRender method. (Despite the name, you probably won't see a large performance hit in SlowRender, especially on newer hardware.)

Palettes

If the FastRender method is used for drawing and the image is palettized, then the filter needs to manage the palette, as follows:

  • The CImageSample class contains a palette version number, stored in the DIBDATA structure. The value is initialized when the allocator creates the sample.
  • The CDrawImage class also contains a palette version number, which is initialized on creation.
  • Whenever the media type changes to a new palettized format, call CDrawImage::IncrementPaletteVersion. This method increments the CDrawImage object's palette version number. If the filter uses the CImagePalette class to manage the palette information, you can simply call CImagePalette::PreparePalette whenever the media type changes. The PreparePalette method increments the palette version only when necessary.
  • The FastRender method compares the CDrawImage palette version against the sample's palette version. If the sample's version number lags behind the CDrawImage version number, the FastRender method calls CDrawImage::UpdateColourTable. The UpdateColourTable method sets the color table in the device context, using the GDI SetDIBColorTable function. Also, the palette version on the sample is updated to the current version number.
  • If the pin reconnects, the filter should call CDrawImage::ResetPaletteVersion to reset the palette version. On pin reconnection, the allocator re-allocates all samples.
Protected Member Variables Description
m_bStretch Indicates whether the video image must be stretched to fit the destination window.
m_bUsingImageAllocator Indicates whether the allocator for the pin connection is a CImageAllocator object.
m_EndSample Specifies the stop time of the most recent sample.
m_hdc Handle to the device context of the owning window.
m_MemoryDC Handle to the memory device context of the owning window.
m_PaletteVersion Used to track when the palette changes.
m_pBaseWindow Pointer to the owning CBaseWindow object.
m_pMediaType Pointer to the current media type.
m_SourceRect Specifies the source rectangle for drawing.
m_StartSample Specifies the start time of the most recent sample.
m_TargetRect Specifies the target rectangle for drawing.
Protected Methods Description
DisplaySampleTimes Draws the time stamps of a media sample on top of the video image.
FastRender Draws the video image using the BitBlt or StretchBlt functions.
SetStretchMode Calculates whether the video image must be stretched.
SlowRender Draws the video image using the SetDIBitsToDevice or StretchDIBits functions.
UpdateColourTable Updates the color table with a new palette.
Public Methods Description
CDrawImage Constructor method.
DrawImage Draws a video frame on the video window.
DrawVideoImageHere Draws an image from a media sample to a specified device context.
GetPaletteVersion Retrieves the palette version.
GetSourceRect Retrieves the current source rectangle.
GetTargetRect Retrieves the current destination rectangle.
IncrementPaletteVersion Increments the palette version.
NotifyAllocator Informs the CDrawImage object whether the allocator for the connection is a CImageAllocator object.
NotifyEndDraw Not supported.
NotifyMediaType Notifies the object of the current media type.
NotifyStartDraw Not supported.
ResetPaletteVersion Resets the palette version.
ScaleSourceRect Scales a specified source rectangle, if there is a difference between the native video size and the media type format. Virtual.
SetDrawContext Sets the device contexts used for drawing.
SetSourceRect Sets the source rectangle.
SetTargetRect Sets the target rectangle.
UsingImageAllocator Indicates whether the current allocator is a CImageAllocator object.

Requirements

Requirement Value
Header
Winutil.h (include Streams.h)
Library
Strmbase.lib (retail builds);
Strmbasd.lib (debug builds)