// 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
class WXDLLEXPORT wxPostScriptDC: public wxDC
{
- DECLARE_DYNAMIC_CLASS(wxPostScriptDC)
-
public:
+ wxPostScriptDC();
- wxPostScriptDC();
-
- // Deprecated constructor
- wxPostScriptDC(const wxString& output, bool interactive = TRUE, wxWindow *parent = (wxWindow *) NULL);
-
- // Recommended constructor
- wxPostScriptDC(const wxPrintData& printData);
-
- ~wxPostScriptDC();
+ // Recommended constructor
+ wxPostScriptDC(const wxPrintData& printData);
+
+ // Recommended destructor :-)
+ ~wxPostScriptDC();
- // Deprecated
- bool Create(const wxString& output, bool interactive = TRUE, wxWindow *parent = (wxWindow *) NULL);
+#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;
- // Deprecated: use wxGenericPrintDialog instead
- virtual bool PrinterDialog(wxWindow *parent = (wxWindow *) NULL);
-
virtual void BeginDrawing() {}
virtual void EndDrawing() {}
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);
static void SetResolution(int ppi);
static int GetResolution();
-
-private:
- static float ms_PSScaleFactor;
-protected:
+ void PsPrintf( const wxChar* fmt, ... );
+ void PsPrint( const char* psdata );
+ void PsPrint( int ch );
- FILE* m_pstream; // PostScript output stream
- wxString m_title;
- unsigned char m_currentRed;
- unsigned char m_currentGreen;
- unsigned char m_currentBlue;
- int m_pageNumber;
- bool m_clipping;
- double m_underlinePosition;
- double m_underlineThickness;
- wxPrintData m_printData;
-};
+#if wxUSE_UNICODE
+ void PsPrint( const wxChar* psdata ) { PsPrint( wxConvUTF8.cWX2MB( psdata ) ); }
+#endif
-// Deprecated: should use wxGenericPrintDialog instead.
-#if 1
-enum
-{
- wxID_PRINTER_COMMAND = 1,
- wxID_PRINTER_OPTIONS,
- wxID_PRINTER_ORIENTATION,
- wxID_PRINTER_MODES,
- wxID_PRINTER_X_SCALE,
- wxID_PRINTER_Y_SCALE,
- wxID_PRINTER_X_TRANS,
- wxID_PRINTER_Y_TRANS
-};
+private:
+ static float ms_PSScaleFactor;
-class WXDLLEXPORT wxPostScriptPrintDialog: public wxDialog
-{
-DECLARE_CLASS(wxPostScriptPrintDialog)
-public:
- wxPostScriptPrintDialog (wxWindow *parent, const wxString& title,
- const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize,
- wxCoord style = wxDEFAULT_DIALOG_STYLE);
+protected:
+#if wxUSE_PANGO
+ PangoContext *m_context;
+ PangoLayout *m_layout;
+ PangoFontDescription *m_fontdesc;
+#endif
- virtual int ShowModal();
+ FILE* m_pstream; // PostScript output stream
+ wxString m_title;
+ unsigned char m_currentRed;
+ unsigned char m_currentGreen;
+ unsigned char m_currentBlue;
+ int m_pageNumber;
+ bool m_clipping;
+ double m_underlinePosition;
+ double m_underlineThickness;
+ wxPrintData m_printData;
+
+private:
+ DECLARE_DYNAMIC_CLASS(wxPostScriptDC)
};
-#endif // 1
-// Print Orientation (Should also add Left, Right)
+
+#if WXWIN_COMPATIBILITY_2_2
+// Print Orientation
enum
{
- PS_PORTRAIT = 1,
- PS_LANDSCAPE = 2
-};// ps_orientation = PS_PORTRAIT;
+ PS_PORTRAIT = wxPORTRAIT,
+ PS_LANDSCAPE = wxLANDSCAPE
+};
// Print Actions
enum
{
- PS_NONE,
- PS_PREVIEW,
- PS_FILE,
- PS_PRINTER
-};// ps_action = PS_PREVIEW;
-
-// PostScript printer settings
-WXDLLEXPORT void wxSetPrinterCommand(const wxString& cmd);
-WXDLLEXPORT void wxSetPrintPreviewCommand(const wxString& cmd);
-WXDLLEXPORT void wxSetPrinterOptions(const wxString& flags);
-WXDLLEXPORT void wxSetPrinterOrientation(int orientation);
-WXDLLEXPORT void wxSetPrinterScaling(double x, double y);
-WXDLLEXPORT void wxSetPrinterTranslation(wxCoord x, wxCoord y);
-WXDLLEXPORT void wxSetPrinterMode(int mode);
-WXDLLEXPORT void wxSetPrinterFile(const wxString& f);
-WXDLLEXPORT void wxSetAFMPath(const wxString& f);
-
-// Get current values
-WXDLLEXPORT wxString wxGetPrinterCommand();
-WXDLLEXPORT wxString wxGetPrintPreviewCommand();
-WXDLLEXPORT wxString wxGetPrinterOptions();
-WXDLLEXPORT int wxGetPrinterOrientation();
-WXDLLEXPORT void wxGetPrinterScaling(double* x, double* y);
-WXDLLEXPORT void wxGetPrinterTranslation(wxCoord *x, wxCoord *y);
-WXDLLEXPORT int wxGetPrinterMode();
-WXDLLEXPORT wxString wxGetPrinterFile();
-WXDLLEXPORT wxString wxGetAFMPath();
-
-/*
- * PostScript print setup information.
- * This is now obsolete, but retained for a while for compatibility
- */
-
-class WXDLLEXPORT wxPrintSetupData: public wxObject
+ 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();
- ~wxPrintSetupData();
-
- void SetPrinterCommand(const wxString& cmd) { m_printerCommand = cmd; };
- void SetPaperName(const wxString& paper) { m_paperName = paper; };
- void SetPrintPreviewCommand(const wxString& cmd) { m_previewCommand = cmd; };
- void SetPrinterOptions(const wxString& flags) { m_printerFlags = flags; };
- void SetPrinterFile(const wxString& f) { m_printerFile = f; };
- void SetPrinterOrientation(int orient) { m_printerOrient = orient; };
- void SetPrinterScaling(double x, double y) { m_printerScaleX = x; m_printerScaleY = y; };
- void SetPrinterTranslation(wxCoord x, wxCoord y) { m_printerTranslateX = x; m_printerTranslateY = y; };
- // 1 = Preview, 2 = print to file, 3 = send to printer
- void SetPrinterMode(int mode) { m_printerMode = mode; };
- void SetAFMPath(const wxString& f) { m_afmPath = f; };
- void SetColour(bool col) { m_printColour = col; };
-
- // Get current values
- wxString GetPrinterCommand() const { return m_printerCommand; } ;
- wxString GetPrintPreviewCommand() const { return m_previewCommand; } ;
- wxString GetPrinterOptions() const { return m_printerFlags; };
- wxString GetPrinterFile() const { return m_printerFile; };
+ 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; }
- int GetPrinterOrientation() const { return m_printerOrient; };
- void GetPrinterScaling(double* x, double* y) const { *x = m_printerScaleX; *y = m_printerScaleY; };
- void GetPrinterTranslation(wxCoord *x, wxCoord *y) const { *x = m_printerTranslateX; *y = m_printerTranslateY; };
- int GetPrinterMode() const { return m_printerMode; };
- wxString GetAFMPath() const { return m_afmPath; };
- bool GetColour() const { return m_printColour; };
-
- void operator=(wxPrintSetupData& data);
-
- // Initialize from a wxPrintData object (wxPrintData should now be used instead of wxPrintSetupData).
- // There is also an operator for initializing a wxPrintData from a wxPrintSetupData.
- void operator=(const wxPrintData& data);
-
-#ifndef __WIN16__
- void GetPrinterTranslation(long *x, long *y) const
- { *x = m_printerTranslateX; *y = m_printerTranslateY; }
-#endif // !Win16
-
-public:
- wxString m_printerCommand;
- wxString m_previewCommand;
- wxString m_printerFlags;
- wxString m_printerFile;
- int m_printerOrient;
- double m_printerScaleX;
- double m_printerScaleY;
- wxCoord m_printerTranslateX;
- wxCoord m_printerTranslateY;
- // 1 = Preview, 2 = print to file, 3 = send to printer
- int m_printerMode;
- wxString m_afmPath;
- // A name in the paper database (see paper.h)
+ wxString GetPrinterFile() const { return m_printerFile; };
+
wxString m_paperName;
- bool m_printColour;
-
- DECLARE_DYNAMIC_CLASS(wxPrintSetupData)
+ wxString m_printerFile;
};
WXDLLEXPORT_DATA(extern wxPrintSetupData*) wxThePrintSetupData;
WXDLLEXPORT extern void wxInitializePrintSetupData(bool init = TRUE);
+#endif
+
#endif
// wxUSE_POSTSCRIPT