X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/7aada1e05a7ed29ee5a0afb5f3464b803e966d7c..fef4c27a1c5467c2ad291d2cff14eabd9c5b1d3b:/wxPython/src/_printfw.i diff --git a/wxPython/src/_printfw.i b/wxPython/src/_printfw.i index 897e48a954..64ff548e78 100644 --- a/wxPython/src/_printfw.i +++ b/wxPython/src/_printfw.i @@ -133,6 +133,7 @@ public: %nokwargs wxPageSetupDialogData; wxPageSetupDialogData(); wxPageSetupDialogData(const wxPageSetupDialogData& data); // for making copies + wxPageSetupDialogData(const wxPrintData& data); ~wxPageSetupDialogData(); void EnableHelp(bool flag); @@ -140,6 +141,7 @@ public: void EnableOrientation(bool flag); void EnablePaper(bool flag); void EnablePrinter(bool flag); + bool GetDefaultMinMargins(); bool GetEnableMargins(); bool GetEnableOrientation(); @@ -155,11 +157,6 @@ public: wxSize GetPaperSize(); wxPrintData& GetPrintData(); -// %addmethods { -// %new wxPrintData* GetPrintData() { -// return new wxPrintData(self->GetPrintData()); // force a copy -// } -// } bool Ok(); @@ -171,22 +168,34 @@ public: void SetMinMarginBottomRight(const wxPoint& pt); void SetPaperId(wxPaperSize id); void SetPaperSize(const wxSize& size); + void SetPrintData(const wxPrintData& printData); + // Use paper size defined in this object to set the wxPrintData + // paper id + void CalculateIdFromPaperSize(); + + // Use paper id in wxPrintData to set this object's paper size + void CalculatePaperSizeFromId(); + %pythoncode { def __nonzero__(self): return self.Ok() } }; +// NOTE: Contrary to it's name, this class doesn't derive from wxDialog. It +// is a facade in front of a platform-specific (native dialog) provided by the +// wxPrintFactory. + MustHaveApp(wxPageSetupDialog); -class wxPageSetupDialog : public wxDialog { +class wxPageSetupDialog : public wxObject +{ public: - %pythonAppend wxPageSetupDialog "self._setOORInfo(self)" - wxPageSetupDialog(wxWindow* parent, wxPageSetupDialogData* data = NULL); wxPageSetupDialogData& GetPageSetupData(); + wxPageSetupDialogData& GetPageSetupDialogData(); int ShowModal(); }; @@ -197,7 +206,8 @@ class wxPrintDialogData : public wxObject { public: %nokwargs wxPrintDialogData; wxPrintDialogData(); - wxPrintDialogData(const wxPrintData& printData); // for making copies + wxPrintDialogData(const wxPrintData& printData); + wxPrintDialogData(const wxPrintDialogData& printData); // for making copies ~wxPrintDialogData(); int GetFromPage() const; @@ -245,12 +255,16 @@ public: }; + MustHaveApp(wxPrintDialog); -class wxPrintDialog : public wxDialog { -public: - %pythonAppend wxPrintDialog "self._setOORInfo(self)" +// NOTE: Contrary to it's name, this class doesn't derive from wxDialog. It +// is a facade in front of a platform-specific (native dialog) provided by the +// wxPrintFactory. + +class wxPrintDialog : public wxObject { +public: wxPrintDialog(wxWindow* parent, wxPrintDialogData* data = NULL); // TODO?: wxPrintDialog(wxWindow *parent, wxPrintData* data); @@ -285,11 +299,11 @@ public: wxPrinter(wxPrintDialogData* data = NULL); ~wxPrinter(); - virtual wxWindow *CreateAbortWindow(wxWindow *parent, wxPrintout *printout); - virtual void ReportError(wxWindow *parent, wxPrintout *printout, const wxString& message); + virtual wxWindow *CreateAbortWindow(wxWindow *parent, wxPyPrintout *printout); + virtual void ReportError(wxWindow *parent, wxPyPrintout *printout, const wxString& message); virtual bool Setup(wxWindow *parent); - virtual bool Print(wxWindow *parent, wxPrintout *printout, bool prompt = true); + virtual bool Print(wxWindow *parent, wxPyPrintout *printout, bool prompt = true); virtual wxDC* PrintDialog(wxWindow *parent); virtual wxPrintDialogData& GetPrintDialogData() const; @@ -300,9 +314,12 @@ public: //--------------------------------------------------------------------------- -// Custom wxPrintout class that knows how to call python +// Custom wxPrintout class that knows how to call python, See implementation in +// include/sx/wxPython/printfw.h + %{ +IMPLEMENT_ABSTRACT_CLASS(wxPyPrintout, wxPrintout); // Since this one would be tough and ugly to do with the Macros... void wxPyPrintout::GetPageInfo(int *minPage, int *maxPage, int *pageFrom, int *pageTo) { @@ -365,7 +382,8 @@ IMP_PYCALLBACK_BOOL_INT(wxPyPrintout, wxPrintout, HasPage); MustHaveApp(wxPyPrintout); // Now define the custom class for SWIGging -%name(Printout) class wxPyPrintout : public wxObject { +%rename(Printout) wxPyPrintout; +class wxPyPrintout : public wxObject { public: %pythonAppend wxPyPrintout "self._setCallbackInfo(self, Printout)" @@ -780,101 +798,6 @@ public: void base_SetZoomControl(int zoom); }; -//--------------------------------------------------------------------------- -// wxPrintFactory -//--------------------------------------------------------------------------- - -class wxPrintFactory -{ -public: - // wxPrintFactory() {} *** It's an ABC - // virtual ~wxPrintFactory(); - - virtual wxPrinterBase *CreatePrinter( wxPrintDialogData* data ); - - %nokwargs CreatePrintPreview; - virtual wxPrintPreviewBase *CreatePrintPreview( wxPrintout *preview, - wxPrintout *printout = NULL, - wxPrintDialogData *data = NULL ); - virtual wxPrintPreviewBase *CreatePrintPreview( wxPrintout *preview, - wxPrintout *printout, - wxPrintData *data ); - - %nokwargs CreatePrintDialog; - virtual wxPrintDialogBase *CreatePrintDialog( wxWindow *parent, - wxPrintDialogData *data = NULL ); - virtual wxPrintDialogBase *CreatePrintDialog( wxWindow *parent, - wxPrintData *data ); - - // What to do and what to show in the wxPrintDialog - // a) Use the generic print setup dialog or a native one? - virtual bool HasPrintSetupDialog(); - virtual wxDialog *CreatePrintSetupDialog( wxWindow *parent, wxPrintData *data ); - - // b) Provide the "print to file" option ourselves or via print setup? - virtual bool HasOwnPrintToFile(); - - // c) Show current printer - virtual bool HasPrinterLine(); - virtual wxString CreatePrinterLine(); - - // d) Show Status line for current printer? - virtual bool HasStatusLine(); - virtual wxString CreateStatusLine(); - - - virtual wxPrintNativeDataBase *CreatePrintNativeData(); - - static void SetPrintFactory( wxPrintFactory *factory ); - static wxPrintFactory *GetFactory(); - //static wxPrintFactory *m_factory; -}; - -// class wxNativePrintFactory: public wxPrintFactory -// { -// public: -// virtual wxPrinterBase *CreatePrinter( wxPrintDialogData *data ); - -// virtual wxPrintPreviewBase *CreatePrintPreview( wxPrintout *preview, -// wxPrintout *printout = NULL, -// wxPrintDialogData *data = NULL ); -// virtual wxPrintPreviewBase *CreatePrintPreview( wxPrintout *preview, -// wxPrintout *printout, -// wxPrintData *data ); - -// virtual wxPrintDialogBase *CreatePrintDialog( wxWindow *parent, -// wxPrintDialogData *data = NULL ); -// virtual wxPrintDialogBase *CreatePrintDialog( wxWindow *parent, -// wxPrintData *data ); - -// virtual bool HasPrintSetupDialog(); -// virtual wxDialog *CreatePrintSetupDialog( wxWindow *parent, wxPrintData *data ); -// virtual bool HasOwnPrintToFile(); -// virtual bool HasPrinterLine(); -// virtual wxString CreatePrinterLine(); -// virtual bool HasStatusLine(); -// virtual wxString CreateStatusLine(); - -// virtual wxPrintNativeDataBase *CreatePrintNativeData(); -// }; - - -class wxPrintNativeDataBase: public wxObject -{ -public: - wxPrintNativeDataBase(); - virtual ~wxPrintNativeDataBase() {} - - virtual bool TransferTo( wxPrintData &data ) = 0; - virtual bool TransferFrom( const wxPrintData &data ) = 0; - - virtual bool Ok() const = 0; - - int m_ref; -}; - - - //--------------------------------------------------------------------------- //--------------------------------------------------------------------------- %init %{