X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/eba330067e87ccec9c8af7bd8b1023044e6d39e3..eedc82f4e96c7f8f0b24addbfd6b4429c9587631:/include/wx/generic/dcpsg.h diff --git a/include/wx/generic/dcpsg.h b/include/wx/generic/dcpsg.h index e35809d16c..2af1c78c46 100644 --- a/include/wx/generic/dcpsg.h +++ b/include/wx/generic/dcpsg.h @@ -4,14 +4,14 @@ // Author: Julian Smart and others // Modified by: // RCS-ID: $Id$ -// Copyright: (c) Julian Smart, Robert Roebling and Markus Holzem +// Copyright: (c) Julian Smart and Robert Roebling // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// #ifndef _WX_DCPSG_H_ #define _WX_DCPSG_H_ -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma interface "dcpsg.h" #endif @@ -38,12 +38,19 @@ class wxPostScriptDC; class WXDLLEXPORT wxPostScriptDC: public wxDC { public: - wxPostScriptDC(); + wxPostScriptDC(); - // Recommended constructor - wxPostScriptDC(const wxPrintData& printData); + // Recommended constructor + wxPostScriptDC(const wxPrintData& printData); + + // Recommended destructor :-) + ~wxPostScriptDC(); - ~wxPostScriptDC(); +#if WXWIN_COMPATIBILITY_2_2 + wxPostScriptDC( const wxString &output, bool interactive = FALSE, wxWindow *parent = NULL ) + { Create( output, interactive, parent ); } + bool Create ( const wxString &output, bool interactive = FALSE, wxWindow *parent = NULL ); +#endif virtual bool Ok() const; @@ -60,6 +67,7 @@ public: void DoDrawPoint(wxCoord x, wxCoord y); void DoDrawLines(int n, wxPoint points[], wxCoord xoffset = 0, wxCoord yoffset = 0); void DoDrawPolygon(int n, wxPoint points[], wxCoord xoffset = 0, wxCoord yoffset = 0, int fillStyle=wxODDEVEN_RULE); + void DoDrawPolyPolygon(int n, int count[], wxPoint points[], wxCoord xoffset = 0, wxCoord yoffset = 0, int fillStyle=wxODDEVEN_RULE); void DoDrawRectangle(wxCoord x, wxCoord y, wxCoord width, wxCoord height); void DoDrawRoundedRectangle(wxCoord x, wxCoord y, wxCoord width, wxCoord height, double radius = 20); void DoDrawEllipse(wxCoord x, wxCoord y, wxCoord width, wxCoord height); @@ -121,11 +129,25 @@ public: static void SetResolution(int ppi); static int GetResolution(); - + + void PsPrintf( const wxChar* fmt, ... ); + void PsPrint( const char* psdata ); + void PsPrint( int ch ); + +#if wxUSE_UNICODE + void PsPrint( const wxChar* psdata ) { PsPrint( wxConvUTF8.cWX2MB( psdata ) ); } +#endif + private: static float ms_PSScaleFactor; protected: +#if wxUSE_PANGO + PangoContext *m_context; + PangoLayout *m_layout; + PangoFontDescription *m_fontdesc; +#endif + FILE* m_pstream; // PostScript output stream wxString m_title; unsigned char m_currentRed; @@ -141,6 +163,50 @@ private: DECLARE_DYNAMIC_CLASS(wxPostScriptDC) }; + +#if WXWIN_COMPATIBILITY_2_2 +// Print Orientation +enum +{ + PS_PORTRAIT = wxPORTRAIT, + PS_LANDSCAPE = wxLANDSCAPE +}; + +// Print Actions +enum +{ + PS_NONE = wxPRINT_MODE_NONE, + PS_PREVIEW = wxPRINT_MODE_PREVIEW, + PS_FILE = wxPRINT_MODE_FILE, + PS_PRINTER = wxPRINT_MODE_PRINTER +}; + +class wxPrintSetupData: public wxPrintData +{ +public: + wxPrintSetupData() {} + + void SetPrinterOrientation( int orient ) + { SetOrientation( orient ); } + void SetPrinterMode( wxPrintMode mode ) + { SetPrintMode( mode ); } + void SetAFMPath( const wxString &path ) + { SetFontMetricPath( path ); } + + void SetPaperName(const wxString& paper) { m_paperName = paper; } + void SetPrinterFile(const wxString& file) { m_printerFile = file; } + wxString GetPaperName() const { return m_paperName; } + wxString GetPrinterFile() const { return m_printerFile; }; + + wxString m_paperName; + wxString m_printerFile; +}; + +WXDLLEXPORT_DATA(extern wxPrintSetupData*) wxThePrintSetupData; +WXDLLEXPORT extern void wxInitializePrintSetupData(bool init = TRUE); +#endif + + #endif // wxUSE_POSTSCRIPT