initial commit
Signed-off-by: Peter Siegmund <mars3142@noreply.mars3142.dev>
This commit is contained in:
117
libs/wxWidgets-3.3.1/include/wx/overlay.h
Normal file
117
libs/wxWidgets-3.3.1/include/wx/overlay.h
Normal file
@@ -0,0 +1,117 @@
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// Name: wx/overlay.h
|
||||
// Purpose: wxOverlay class
|
||||
// Author: Stefan Csomor
|
||||
// Created: 2006-10-20
|
||||
// Copyright: (c) wxWidgets team
|
||||
// Licence: wxWindows licence
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
#ifndef _WX_OVERLAY_H_
|
||||
#define _WX_OVERLAY_H_
|
||||
|
||||
#include "wx/defs.h"
|
||||
|
||||
#include "wx/dcclient.h"
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
// creates an overlay over an existing window, allowing for manipulations like
|
||||
// rubberbanding etc.
|
||||
// ----------------------------------------------------------------------------
|
||||
|
||||
class WXDLLIMPEXP_CORE wxOverlay
|
||||
{
|
||||
public:
|
||||
class Impl;
|
||||
|
||||
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();
|
||||
|
||||
bool IsNative() const;
|
||||
|
||||
void SetOpacity(int alpha);
|
||||
|
||||
private:
|
||||
friend class WXDLLIMPEXP_FWD_CORE wxDCOverlay;
|
||||
|
||||
static Impl* Create();
|
||||
|
||||
// returns true if it has been setup
|
||||
bool IsOk();
|
||||
|
||||
void Init(wxDC* dc, int x , int y , int width , int height);
|
||||
|
||||
void BeginDrawing(wxDC* dc);
|
||||
|
||||
void EndDrawing(wxDC* dc);
|
||||
|
||||
void Clear(wxDC* dc);
|
||||
|
||||
Impl* m_impl;
|
||||
|
||||
bool m_inDrawing;
|
||||
|
||||
|
||||
wxDECLARE_NO_COPY_CLASS(wxOverlay);
|
||||
};
|
||||
|
||||
|
||||
class WXDLLIMPEXP_CORE wxDCOverlay
|
||||
{
|
||||
public:
|
||||
// connects this overlay to the corresponding drawing dc, if the overlay is
|
||||
// not initialized yet this call will do so
|
||||
wxDCOverlay(wxOverlay &overlay, wxDC *dc, int x , int y , int width , int height);
|
||||
|
||||
// convenience wrapper that behaves the same using the entire area of the dc
|
||||
wxDCOverlay(wxOverlay &overlay, wxDC *dc);
|
||||
|
||||
// removes the connection between the overlay and the dc
|
||||
virtual ~wxDCOverlay();
|
||||
|
||||
// clears the layer, restoring the state at the last init
|
||||
void Clear();
|
||||
|
||||
private:
|
||||
void Init(wxDC *dc, int x , int y , int width , int height);
|
||||
|
||||
wxOverlay& m_overlay;
|
||||
|
||||
wxDC* m_dc;
|
||||
|
||||
|
||||
wxDECLARE_NO_COPY_CLASS(wxDCOverlay);
|
||||
};
|
||||
|
||||
// Convenient class combining wxClientDC with wxDCOverlay.
|
||||
class wxOverlayDC : public wxClientDC
|
||||
{
|
||||
public:
|
||||
wxOverlayDC(wxOverlay& overlay, wxWindow* win)
|
||||
: wxClientDC(win),
|
||||
m_dcOverlay(overlay, this)
|
||||
{
|
||||
}
|
||||
|
||||
wxOverlayDC(wxOverlay& overlay, wxWindow* win, const wxRect& rect)
|
||||
: wxClientDC(win),
|
||||
m_dcOverlay(overlay, this, rect.x, rect.y, rect.width, rect.height)
|
||||
{
|
||||
}
|
||||
|
||||
void Clear()
|
||||
{
|
||||
m_dcOverlay.Clear();
|
||||
}
|
||||
|
||||
private:
|
||||
wxDCOverlay m_dcOverlay;
|
||||
|
||||
wxDECLARE_NO_COPY_CLASS(wxOverlayDC);
|
||||
};
|
||||
|
||||
#endif // _WX_OVERLAY_H_
|
||||
Reference in New Issue
Block a user