X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b45dfd0a8bfb8ad1199f8a6c28f473aaa86004b5..9fbbb8b38b390d4a28cf111e5c3ef8f49a1bda7b:/samples/printing/printing.h diff --git a/samples/printing/printing.h b/samples/printing/printing.h index 6d02f5b1e3..a138d541b4 100644 --- a/samples/printing/printing.h +++ b/samples/printing/printing.h @@ -1,5 +1,5 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: printing.h +// Name: samples/printing.h // Purpose: Printing demo for wxWidgets // Author: Julian Smart // Modified by: @@ -9,35 +9,43 @@ // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#if defined(__GNUG__) && !defined(__APPLE__) -#pragma interface -#endif - // Define a new application class MyApp: public wxApp { - public: - MyApp(){}; - bool OnInit(); - int OnExit(); +public: + MyApp() {} + + virtual bool OnInit(); + virtual int OnExit(); + + void Draw(wxDC& dc); + + void IncrementAngle() + { m_angle += 5; } + void DecrementAngle() + { m_angle -= 5; } - wxFont m_testFont; + wxFont& GetTestFont() + { return m_testFont; } + +private: + int m_angle; + wxBitmap m_bitmap; + wxFont m_testFont; }; DECLARE_APP(MyApp) - class MyCanvas; // Define a new canvas and frame class MyFrame: public wxFrame { - public: - MyCanvas *canvas; +public: MyFrame(wxFrame *frame, const wxString& title, const wxPoint& pos, const wxSize& size); - void Draw(wxDC& dc); + void OnAngleUp(wxCommandEvent& event); + void OnAngleDown(wxCommandEvent& event); - void OnSize(wxSizeEvent& event); void OnPrint(wxCommandEvent& event); void OnPrintPreview(wxCommandEvent& event); void OnPageSetup(wxCommandEvent& event); @@ -46,46 +54,75 @@ class MyFrame: public wxFrame void OnPrintPreviewPS(wxCommandEvent& event); void OnPageSetupPS(wxCommandEvent& event); #endif +#ifdef __WXMAC__ + void OnPageMargins(wxCommandEvent& event); +#endif + + void OnPreviewFrameModalityKind(wxCommandEvent& event); void OnExit(wxCommandEvent& event); void OnPrintAbout(wxCommandEvent& event); -DECLARE_EVENT_TABLE() + +private: + MyCanvas* m_canvas; + wxPreviewFrameModalityKind m_previewModality; + + DECLARE_EVENT_TABLE() }; -// Define a new canvas which can receive some events +// Define a new white canvas class MyCanvas: public wxScrolledWindow { - public: +public: MyCanvas(wxFrame *frame, const wxPoint& pos, const wxSize& size, long style = wxRETAINED); - ~MyCanvas(void){}; + //void OnPaint(wxPaintEvent& evt); virtual void OnDraw(wxDC& dc); - void OnEvent(wxMouseEvent& event); -DECLARE_EVENT_TABLE() +private: + DECLARE_EVENT_TABLE() }; +// Defines a new printout class to print our document class MyPrintout: public wxPrintout { - public: - MyPrintout(wxChar *title = _T("My printout")):wxPrintout(title) {} - bool OnPrintPage(int page); - bool HasPage(int page); - bool OnBeginDocument(int startPage, int endPage); - void GetPageInfo(int *minPage, int *maxPage, int *selPageFrom, int *selPageTo); - - void DrawPageOne(wxDC *dc); - void DrawPageTwo(wxDC *dc); +public: + MyPrintout(MyFrame* frame, const wxString &title = wxT("My printout")) + : wxPrintout(title) { m_frame=frame; } + + virtual bool OnPrintPage(int page); + virtual bool HasPage(int page); + virtual bool OnBeginDocument(int startPage, int endPage); + virtual void GetPageInfo(int *minPage, int *maxPage, int *selPageFrom, int *selPageTo); + + void DrawPageOne(); + void DrawPageTwo(); + + // Writes a header on a page. Margin units are in millimetres. + bool WritePageHeader(wxPrintout *printout, wxDC *dc, const wxString& text, float mmToLogical); + +private: + MyFrame *m_frame; }; -#define WXPRINT_QUIT 100 -#define WXPRINT_PRINT 101 -#define WXPRINT_PAGE_SETUP 103 -#define WXPRINT_PREVIEW 104 -#define WXPRINT_PRINT_PS 105 -#define WXPRINT_PAGE_SETUP_PS 107 -#define WXPRINT_PREVIEW_PS 108 +// constants: +enum +{ + WXPRINT_PAGE_SETUP = 103, + + WXPRINT_PRINT_PS, + WXPRINT_PAGE_SETUP_PS, + WXPRINT_PREVIEW_PS, -#define WXPRINT_ABOUT 109 + WXPRINT_ANGLEUP, + WXPRINT_ANGLEDOWN, +#ifdef __WXMAC__ + WXPRINT_PAGE_MARGINS, +#endif + + WXPRINT_FRAME_MODAL_APP, + WXPRINT_FRAME_MODAL_WIN, + WXPRINT_FRAME_MODAL_NON +};