2006-10-24 12:29:14 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/overlay.h
|
|
|
|
// Purpose: wxOverlay class
|
|
|
|
// Author: Stefan Csomor
|
|
|
|
// Modified by:
|
|
|
|
// Created: 2006-10-20
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Copyright: (c) wxWidgets team
|
|
|
|
// Licence: wxWindows licence
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_OVERLAY_H_
|
|
|
|
#define _WX_OVERLAY_H_
|
|
|
|
|
|
|
|
#include "wx/defs.h"
|
|
|
|
|
2007-11-27 10:59:57 +00:00
|
|
|
#if defined(wxMAC_USE_CORE_GRAPHICS) && wxMAC_USE_CORE_GRAPHICS && wxMAC_USE_QUICKDRAW
|
2006-10-25 12:12:56 +00:00
|
|
|
#define wxHAS_NATIVE_OVERLAY 1
|
|
|
|
#elif defined(__WXDFB__)
|
|
|
|
#define wxHAS_NATIVE_OVERLAY 1
|
|
|
|
#else
|
|
|
|
// don't define wxHAS_NATIVE_OVERLAY
|
2006-10-24 12:29:14 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// creates an overlay over an existing window, allowing for manipulations like
|
|
|
|
// rubberbanding etc. This API is not stable yet, not to be used outside wx
|
|
|
|
// internal code
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2007-07-09 10:09:52 +00:00
|
|
|
class WXDLLIMPEXP_FWD_CORE wxOverlayImpl;
|
2007-12-22 09:06:39 +00:00
|
|
|
class WXDLLIMPEXP_FWD_CORE wxDC;
|
2006-10-24 12:29:14 +00:00
|
|
|
|
2008-03-26 15:06:00 +00:00
|
|
|
class WXDLLIMPEXP_CORE wxOverlay
|
2006-10-24 12:29:14 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
wxOverlay();
|
|
|
|
~wxOverlay();
|
|
|
|
|
|
|
|
// clears the overlay without restoring the former state
|
|
|
|
// to be done eg when the window content has been changed and repainted
|
|
|
|
void Reset();
|
|
|
|
|
|
|
|
// returns (port-specific) implementation of the overlay
|
|
|
|
wxOverlayImpl *GetImpl() { return m_impl; }
|
|
|
|
|
|
|
|
private:
|
2007-07-09 10:09:52 +00:00
|
|
|
friend class WXDLLIMPEXP_FWD_CORE wxDCOverlay;
|
2006-10-24 12:29:14 +00:00
|
|
|
|
|
|
|
// returns true if it has been setup
|
|
|
|
bool IsOk();
|
|
|
|
|
2007-12-22 09:06:39 +00:00
|
|
|
void Init(wxDC* dc, int x , int y , int width , int height);
|
2006-10-24 12:29:14 +00:00
|
|
|
|
2007-12-22 09:06:39 +00:00
|
|
|
void BeginDrawing(wxDC* dc);
|
2006-10-24 12:29:14 +00:00
|
|
|
|
2007-12-22 09:06:39 +00:00
|
|
|
void EndDrawing(wxDC* dc);
|
2006-10-24 12:29:14 +00:00
|
|
|
|
2007-12-22 09:06:39 +00:00
|
|
|
void Clear(wxDC* dc);
|
2006-10-24 12:29:14 +00:00
|
|
|
|
|
|
|
wxOverlayImpl* m_impl;
|
|
|
|
|
|
|
|
bool m_inDrawing;
|
|
|
|
|
|
|
|
|
|
|
|
DECLARE_NO_COPY_CLASS(wxOverlay)
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-26 15:06:00 +00:00
|
|
|
class WXDLLIMPEXP_CORE wxDCOverlay
|
2006-10-24 12:29:14 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
// connects this overlay to the corresponding drawing dc, if the overlay is
|
|
|
|
// not initialized yet this call will do so
|
2007-12-22 09:06:39 +00:00
|
|
|
wxDCOverlay(wxOverlay &overlay, wxDC *dc, int x , int y , int width , int height);
|
2006-10-24 12:29:14 +00:00
|
|
|
|
|
|
|
// convenience wrapper that behaves the same using the entire area of the dc
|
2007-12-22 09:06:39 +00:00
|
|
|
wxDCOverlay(wxOverlay &overlay, wxDC *dc);
|
2006-10-24 12:29:14 +00:00
|
|
|
|
|
|
|
// removes the connection between the overlay and the dc
|
|
|
|
virtual ~wxDCOverlay();
|
|
|
|
|
|
|
|
// clears the layer, restoring the state at the last init
|
|
|
|
void Clear();
|
|
|
|
|
|
|
|
private:
|
2007-12-22 09:06:39 +00:00
|
|
|
void Init(wxDC *dc, int x , int y , int width , int height);
|
2006-10-24 12:29:14 +00:00
|
|
|
|
|
|
|
wxOverlay& m_overlay;
|
|
|
|
|
2007-12-22 09:06:39 +00:00
|
|
|
wxDC* m_dc;
|
2006-10-24 12:29:14 +00:00
|
|
|
|
|
|
|
|
|
|
|
DECLARE_NO_COPY_CLASS(wxDCOverlay)
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // _WX_OVERLAY_H_
|