X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c94f845b1602d44ccd7c7542afffde666adbb2f0..45b81639ef31938fbcf512519dbd74a54fbcd1d5:/include/wx/generic/dcpsg.h diff --git a/include/wx/generic/dcpsg.h b/include/wx/generic/dcpsg.h index 1958c18278..2d90c7fa64 100644 --- a/include/wx/generic/dcpsg.h +++ b/include/wx/generic/dcpsg.h @@ -13,9 +13,7 @@ #include "wx/defs.h" -#if wxUSE_PRINTING_ARCHITECTURE - -#if wxUSE_POSTSCRIPT +#if wxUSE_PRINTING_ARCHITECTURE && wxUSE_POSTSCRIPT #include "wx/dc.h" #include "wx/dialog.h" @@ -23,14 +21,6 @@ #include "wx/cmndata.h" #include "wx/strvararg.h" -extern WXDLLIMPEXP_DATA_CORE(int) wxPageNumber; - -//----------------------------------------------------------------------------- -// classes -//----------------------------------------------------------------------------- - -class wxPostScriptDC; - //----------------------------------------------------------------------------- // wxPostScriptDC //----------------------------------------------------------------------------- @@ -42,58 +32,63 @@ public: // Recommended constructor wxPostScriptDC(const wxPrintData& printData); - - // Recommended destructor :-) + virtual ~wxPostScriptDC(); - virtual bool Ok() const { return IsOk(); } - virtual bool IsOk() const; - - bool CanDrawBitmap() const { return true; } - - void Clear(); - void SetFont( const wxFont& font ); - void SetPen( const wxPen& pen ); - void SetBrush( const wxBrush& brush ); - void SetLogicalFunction( int function ); - void SetBackground( const wxBrush& brush ); - - void DestroyClippingRegion(); - - bool StartDoc(const wxString& message); - void EndDoc(); - void StartPage(); - void EndPage(); - - wxCoord GetCharHeight() const; - wxCoord GetCharWidth() const; - bool CanGetTextExtent() const { return true; } - - // Resolution in pixels per logical inch - wxSize GetPPI() const; - - void SetAxisOrientation( bool xLeftRight, bool yBottomUp ); - void SetDeviceOrigin( wxCoord x, wxCoord y ); + virtual bool Ok() const { return IsOk(); } + virtual bool IsOk() const; + + bool CanDrawBitmap() const { return true; } + + void Clear(); + void SetFont( const wxFont& font ); + void SetPen( const wxPen& pen ); + void SetBrush( const wxBrush& brush ); + void SetLogicalFunction( int function ); + void SetBackground( const wxBrush& brush ); + + void DestroyClippingRegion(); + + bool StartDoc(const wxString& message); + void EndDoc(); + void StartPage(); + void EndPage(); + + wxCoord GetCharHeight() const; + wxCoord GetCharWidth() const; + bool CanGetTextExtent() const { return true; } + + // Resolution in pixels per logical inch + wxSize GetPPI() const; + +#if wxUSE_NEW_DC +#else + // these need to be overridden as wxPostscriptDC inherits + // from the platform dependent wxDC and this we'd call + // e.g. wxMSW specific code here. + virtual void SetAxisOrientation( bool xLeftRight, bool yBottomUp ); + virtual void SetMapMode(int mode); + virtual void SetUserScale(double x, double y); + virtual void SetLogicalScale(double x, double y); + virtual void SetLogicalOrigin(wxCoord x, wxCoord y); + virtual void SetDeviceOrigin(wxCoord x, wxCoord y); +#endif + virtual void ComputeScaleAndOrigin(); - void SetBackgroundMode(int WXUNUSED(mode)) { } - void SetPalette(const wxPalette& WXUNUSED(palette)) { } + void SetBackgroundMode(int WXUNUSED(mode)) { } + void SetPalette(const wxPalette& WXUNUSED(palette)) { } - wxPrintData& GetPrintData() { return m_printData; } - void SetPrintData(const wxPrintData& data) { m_printData = data; } + void SetPrintData(const wxPrintData& data); + wxPrintData& GetPrintData() { return m_printData; } - virtual int GetDepth() const { return 24; } + virtual int GetDepth() const { return 24; } - static void SetResolution(int ppi); - static int GetResolution(); + static void SetResolution(int ppi); + static int GetResolution(); - WX_DEFINE_VARARG_FUNC_VOID(PsPrintf, DoPsPrintfFormat) - void PsPrint( const wxString& psdata ); - void PsPrint( int ch ); + void PsPrint( const wxString& psdata ); private: - void DoPsPrintfFormat(const wxChar *fmt, ... ); - - static float ms_PSScaleFactor; protected: bool DoFloodFill(wxCoord x1, wxCoord y1, const wxColour &col, int style = wxFLOOD_SURFACE); @@ -110,7 +105,7 @@ protected: void DoDrawRoundedRectangle(wxCoord x, wxCoord y, wxCoord width, wxCoord height, double radius = 20); void DoDrawEllipse(wxCoord x, wxCoord y, wxCoord width, wxCoord height); #if wxUSE_SPLINES - void DoDrawSpline(wxList *points); + void DoDrawSpline(const wxPointList *points); #endif // wxUSE_SPLINES bool DoBlit(wxCoord xdest, wxCoord ydest, wxCoord width, wxCoord height, wxDC *source, wxCoord xsrc, wxCoord ysrc, int rop = wxCOPY, bool useMask = false, @@ -138,16 +133,14 @@ protected: double m_underlinePosition; double m_underlineThickness; wxPrintData m_printData; + double m_pageHeight; private: DECLARE_DYNAMIC_CLASS(wxPostScriptDC) }; #endif - // wxUSE_POSTSCRIPT - -#endif - // wxUSE_PRINTING_ARCHITECTURE + // wxUSE_POSTSCRIPT && wxUSE_PRINTING_ARCHITECTURE #endif // _WX_DCPSG_H_