|
|
@@ -31,21 +31,21 @@ class WXDLLEXPORT wxWindow;
|
|
|
|
class WXDLLEXPORT wxWindowDC : public wxDC
|
|
|
|
class WXDLLEXPORT wxWindowDC : public wxDC
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DECLARE_DYNAMIC_CLASS(wxWindowDC)
|
|
|
|
DECLARE_DYNAMIC_CLASS(wxWindowDC)
|
|
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
public:
|
|
|
|
wxWindowDC();
|
|
|
|
wxWindowDC();
|
|
|
|
wxWindowDC( wxWindow *win );
|
|
|
|
wxWindowDC( wxWindow *win );
|
|
|
|
|
|
|
|
|
|
|
|
~wxWindowDC();
|
|
|
|
~wxWindowDC();
|
|
|
|
|
|
|
|
|
|
|
|
// TODO this function is Motif-only for now - should it go into base class?
|
|
|
|
// TODO this function is Motif-only for now - should it go into base class?
|
|
|
|
void Clear(const wxRect& rect);
|
|
|
|
void Clear(const wxRect& rect);
|
|
|
|
|
|
|
|
|
|
|
|
// implement base class pure virtuals
|
|
|
|
// implement base class pure virtuals
|
|
|
|
// ----------------------------------
|
|
|
|
// ----------------------------------
|
|
|
|
|
|
|
|
|
|
|
|
virtual void Clear();
|
|
|
|
virtual void Clear();
|
|
|
|
|
|
|
|
|
|
|
|
virtual void SetFont(const wxFont& font);
|
|
|
|
virtual void SetFont(const wxFont& font);
|
|
|
|
virtual void SetPen(const wxPen& pen);
|
|
|
|
virtual void SetPen(const wxPen& pen);
|
|
|
|
virtual void SetBrush(const wxBrush& brush);
|
|
|
|
virtual void SetBrush(const wxBrush& brush);
|
|
|
@@ -53,10 +53,10 @@ public:
|
|
|
|
virtual void SetBackgroundMode(int mode);
|
|
|
|
virtual void SetBackgroundMode(int mode);
|
|
|
|
virtual void SetPalette(const wxPalette& palette);
|
|
|
|
virtual void SetPalette(const wxPalette& palette);
|
|
|
|
virtual void SetLogicalFunction( int function );
|
|
|
|
virtual void SetLogicalFunction( int function );
|
|
|
|
|
|
|
|
|
|
|
|
virtual void SetTextForeground(const wxColour& colour);
|
|
|
|
virtual void SetTextForeground(const wxColour& colour);
|
|
|
|
virtual void SetTextBackground(const wxColour& colour);
|
|
|
|
virtual void SetTextBackground(const wxColour& colour);
|
|
|
|
|
|
|
|
|
|
|
|
virtual wxCoord GetCharHeight() const;
|
|
|
|
virtual wxCoord GetCharHeight() const;
|
|
|
|
virtual wxCoord GetCharWidth() const;
|
|
|
|
virtual wxCoord GetCharWidth() const;
|
|
|
|
virtual void DoGetTextExtent(const wxString& string,
|
|
|
|
virtual void DoGetTextExtent(const wxString& string,
|
|
|
@@ -64,27 +64,27 @@ public:
|
|
|
|
wxCoord *descent = NULL,
|
|
|
|
wxCoord *descent = NULL,
|
|
|
|
wxCoord *externalLeading = NULL,
|
|
|
|
wxCoord *externalLeading = NULL,
|
|
|
|
wxFont *theFont = NULL) const;
|
|
|
|
wxFont *theFont = NULL) const;
|
|
|
|
|
|
|
|
|
|
|
|
virtual bool CanDrawBitmap() const;
|
|
|
|
virtual bool CanDrawBitmap() const;
|
|
|
|
virtual bool CanGetTextExtent() const;
|
|
|
|
virtual bool CanGetTextExtent() const;
|
|
|
|
|
|
|
|
|
|
|
|
virtual int GetDepth() const;
|
|
|
|
virtual int GetDepth() const;
|
|
|
|
virtual wxSize GetPPI() const;
|
|
|
|
virtual wxSize GetPPI() const;
|
|
|
|
|
|
|
|
|
|
|
|
virtual void DestroyClippingRegion();
|
|
|
|
virtual void DestroyClippingRegion();
|
|
|
|
|
|
|
|
|
|
|
|
// Helper function for setting clipping
|
|
|
|
// Helper function for setting clipping
|
|
|
|
void SetDCClipping(WXRegion region);
|
|
|
|
void SetDCClipping(WXRegion region);
|
|
|
|
|
|
|
|
|
|
|
|
// implementation from now on
|
|
|
|
// implementation from now on
|
|
|
|
// --------------------------
|
|
|
|
// --------------------------
|
|
|
|
|
|
|
|
|
|
|
|
WXGC GetGC() const { return m_gc; }
|
|
|
|
WXGC GetGC() const { return m_gc; }
|
|
|
|
WXGC GetBackingGC() const { return m_gcBacking; }
|
|
|
|
WXGC GetBackingGC() const { return m_gcBacking; }
|
|
|
|
WXDisplay* GetDisplay() const { return m_display; }
|
|
|
|
WXDisplay* GetDisplay() const { return m_display; }
|
|
|
|
bool GetAutoSetting() const { return m_autoSetting; }
|
|
|
|
bool GetAutoSetting() const { return m_autoSetting; }
|
|
|
|
void SetAutoSetting(bool flag) { m_autoSetting = flag; }
|
|
|
|
void SetAutoSetting(bool flag) { m_autoSetting = flag; }
|
|
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
protected:
|
|
|
|
// note that this function will call colour.SetPixel,
|
|
|
|
// note that this function will call colour.SetPixel,
|
|
|
|
// and will do one of curCol = colour, curCol = wxWHITE, curCol = wxBLACK
|
|
|
|
// and will do one of curCol = colour, curCol = wxWHITE, curCol = wxBLACK
|
|
|
@@ -100,37 +100,37 @@ protected:
|
|
|
|
|
|
|
|
|
|
|
|
virtual bool DoFloodFill(wxCoord x, wxCoord y, const wxColour& col,
|
|
|
|
virtual bool DoFloodFill(wxCoord x, wxCoord y, const wxColour& col,
|
|
|
|
int style = wxFLOOD_SURFACE);
|
|
|
|
int style = wxFLOOD_SURFACE);
|
|
|
|
|
|
|
|
|
|
|
|
virtual bool DoGetPixel(wxCoord x, wxCoord y, wxColour *col) const;
|
|
|
|
virtual bool DoGetPixel(wxCoord x, wxCoord y, wxColour *col) const;
|
|
|
|
|
|
|
|
|
|
|
|
virtual void DoDrawPoint(wxCoord x, wxCoord y);
|
|
|
|
virtual void DoDrawPoint(wxCoord x, wxCoord y);
|
|
|
|
virtual void DoDrawLine(wxCoord x1, wxCoord y1, wxCoord x2, wxCoord y2);
|
|
|
|
virtual void DoDrawLine(wxCoord x1, wxCoord y1, wxCoord x2, wxCoord y2);
|
|
|
|
|
|
|
|
|
|
|
|
virtual void DoDrawArc(wxCoord x1, wxCoord y1,
|
|
|
|
virtual void DoDrawArc(wxCoord x1, wxCoord y1,
|
|
|
|
wxCoord x2, wxCoord y2,
|
|
|
|
wxCoord x2, wxCoord y2,
|
|
|
|
wxCoord xc, wxCoord yc);
|
|
|
|
wxCoord xc, wxCoord yc);
|
|
|
|
virtual void DoDrawEllipticArc(wxCoord x, wxCoord y, wxCoord w, wxCoord h,
|
|
|
|
virtual void DoDrawEllipticArc(wxCoord x, wxCoord y, wxCoord w, wxCoord h,
|
|
|
|
double sa, double ea);
|
|
|
|
double sa, double ea);
|
|
|
|
|
|
|
|
|
|
|
|
virtual void DoDrawRectangle(wxCoord x, wxCoord y, wxCoord width, wxCoord height);
|
|
|
|
virtual void DoDrawRectangle(wxCoord x, wxCoord y, wxCoord width, wxCoord height);
|
|
|
|
virtual void DoDrawRoundedRectangle(wxCoord x, wxCoord y,
|
|
|
|
virtual void DoDrawRoundedRectangle(wxCoord x, wxCoord y,
|
|
|
|
wxCoord width, wxCoord height,
|
|
|
|
wxCoord width, wxCoord height,
|
|
|
|
double radius);
|
|
|
|
double radius);
|
|
|
|
virtual void DoDrawEllipse(wxCoord x, wxCoord y, wxCoord width, wxCoord height);
|
|
|
|
virtual void DoDrawEllipse(wxCoord x, wxCoord y, wxCoord width, wxCoord height);
|
|
|
|
|
|
|
|
|
|
|
|
virtual void DoCrossHair(wxCoord x, wxCoord y);
|
|
|
|
virtual void DoCrossHair(wxCoord x, wxCoord y);
|
|
|
|
|
|
|
|
|
|
|
|
virtual void DoDrawText(const wxString& text, wxCoord x, wxCoord y);
|
|
|
|
virtual void DoDrawText(const wxString& text, wxCoord x, wxCoord y);
|
|
|
|
virtual void DoDrawRotatedText(const wxString &text, wxCoord x, wxCoord y, double angle);
|
|
|
|
virtual void DoDrawRotatedText(const wxString &text, wxCoord x, wxCoord y, double angle);
|
|
|
|
|
|
|
|
|
|
|
|
virtual bool DoBlit(wxCoord xdest, wxCoord ydest, wxCoord width, wxCoord height,
|
|
|
|
virtual bool DoBlit(wxCoord xdest, wxCoord ydest, wxCoord width, wxCoord height,
|
|
|
|
wxDC *source, wxCoord xsrc, wxCoord ysrc,
|
|
|
|
wxDC *source, wxCoord xsrc, wxCoord ysrc,
|
|
|
|
int rop = wxCOPY, bool useMask = false, wxCoord xsrcMask = -1, wxCoord ysrcMask = -1);
|
|
|
|
int rop = wxCOPY, bool useMask = false, wxCoord xsrcMask = -1, wxCoord ysrcMask = -1);
|
|
|
|
|
|
|
|
|
|
|
|
virtual void DoSetClippingRegionAsRegion(const wxRegion& region);
|
|
|
|
virtual void DoSetClippingRegionAsRegion(const wxRegion& region);
|
|
|
|
virtual void DoSetClippingRegion(wxCoord x, wxCoord y,
|
|
|
|
virtual void DoSetClippingRegion(wxCoord x, wxCoord y,
|
|
|
|
wxCoord width, wxCoord height);
|
|
|
|
wxCoord width, wxCoord height);
|
|
|
|
|
|
|
|
|
|
|
|
virtual void DoDrawLines(int n, wxPoint points[],
|
|
|
|
virtual void DoDrawLines(int n, wxPoint points[],
|
|
|
|
wxCoord xoffset, wxCoord yoffset);
|
|
|
|
wxCoord xoffset, wxCoord yoffset);
|
|
|
|
virtual void DoDrawPolygon(int n, wxPoint points[],
|
|
|
|
virtual void DoDrawPolygon(int n, wxPoint points[],
|
|
|
@@ -164,34 +164,27 @@ protected:
|
|
|
|
int m_currentStyle ;
|
|
|
|
int m_currentStyle ;
|
|
|
|
int m_currentFill ;
|
|
|
|
int m_currentFill ;
|
|
|
|
int m_autoSetting ; // See comment in dcclient.cpp
|
|
|
|
int m_autoSetting ; // See comment in dcclient.cpp
|
|
|
|
|
|
|
|
|
|
|
|
// this is useless and should be removed, kept for now just for backwards
|
|
|
|
|
|
|
|
// compatibility
|
|
|
|
|
|
|
|
#if wxCHECK_VERSION(2, 7, 0)
|
|
|
|
|
|
|
|
#error "Remove wxClientDC::m_oldFont"
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
WXFont m_oldFont;
|
|
|
|
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class WXDLLEXPORT wxPaintDC: public wxWindowDC
|
|
|
|
class WXDLLEXPORT wxPaintDC: public wxWindowDC
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DECLARE_DYNAMIC_CLASS(wxPaintDC)
|
|
|
|
DECLARE_DYNAMIC_CLASS(wxPaintDC)
|
|
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
public:
|
|
|
|
wxPaintDC() { }
|
|
|
|
wxPaintDC() { }
|
|
|
|
wxPaintDC(wxWindow* win);
|
|
|
|
wxPaintDC(wxWindow* win);
|
|
|
|
|
|
|
|
|
|
|
|
~wxPaintDC();
|
|
|
|
~wxPaintDC();
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class WXDLLEXPORT wxClientDC: public wxWindowDC
|
|
|
|
class WXDLLEXPORT wxClientDC: public wxWindowDC
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DECLARE_DYNAMIC_CLASS(wxClientDC)
|
|
|
|
DECLARE_DYNAMIC_CLASS(wxClientDC)
|
|
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
public:
|
|
|
|
wxClientDC() { }
|
|
|
|
wxClientDC() { }
|
|
|
|
wxClientDC(wxWindow* win) : wxWindowDC(win) { }
|
|
|
|
wxClientDC(wxWindow* win) : wxWindowDC(win) { }
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
#endif // _WX_DCCLIENT_H_
|
|
|
|
// _WX_DCCLIENT_H_
|
|
|
|
|
|
|
|