Share via


IDirectDrawSurface::SetClipper

Send Feedback

This method attaches a Clipper object to or deletes one from a surface.

HRESULT SetClipper(
  LPDIRECTDRAWCLIPPER lpDDClipper
); 

Parameters

  • lpDDClipper
    Address of the IDirectDrawClipper interface for the DirectDrawClipper object that will be attached to the DirectDrawSurface object. If this parameter is NULL, the current DirectDrawClipper object will be detached.

Return Values

If the method succeeds, the return value is DD_OK.

If the method fails, the return value may be one of the following error values:

DDERR_INVALIDOBJECT
DDERR_INVALIDPARAMS
DDERR_NOCLIPPERATTACHED

Remarks

When setting a clipper to a surface for the first time, this method increments the clipper's reference count; subsequent calls do not affect the clipper's reference count.

If you pass NULL as the lpDDClipper parameter, the clipper is removed from the surface, and the clipper's reference count is decremented.

If you do not delete the clipper, the surface releases its reference to the clipper when the surface itself is released.

According to COM rules, your application is responsible for releasing references it holds to the clipper when the object is no longer needed.

This method is mainly used by surfaces that are being overlaid on or blitted to the primary surface. However, it can be used on any surface.

After a DirectDrawClipper object has been attached and a clip list is associated with it, the DirectDrawClipper object will be used for the IDirectDrawSurface::Blt and IDirectDrawSurface::UpdateOverlay operations involving the parent DirectDrawSurface object.

This method can also detach a DirectDrawSurface object's current DirectDrawClipper object.

Requirements

Pocket PC: Windows Mobile 5.0 and later
Smartphone: Windows Mobile 5.0 and later
OS Versions: Windows CE 5.01 and later
Header: Ddraw.h.
Library: Ddraw.lib.

See Also

IDirectDrawSurface::GetClipper

Send Feedback on this topic to the authors

Feedback FAQs

© 2006 Microsoft Corporation. All rights reserved.