1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: Base classes for printing framework
4 // Author: Julian Smart
8 // Copyright: (c) Julian Smart and Markus Holzem
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
12 #ifndef _WX_PRNTBASEH__
13 #define _WX_PRNTBASEH__
16 #pragma interface "prntbase.h"
21 #if wxUSE_PRINTING_ARCHITECTURE
24 #include "wx/cmndata.h"
26 #include "wx/scrolwin.h"
27 #include "wx/dialog.h"
30 class WXDLLEXPORT wxDC
;
31 class WXDLLEXPORT wxButton
;
32 class WXDLLEXPORT wxChoice
;
33 class WXDLLEXPORT wxPrintout
;
34 class WXDLLEXPORT wxPrinterBase
;
35 class WXDLLEXPORT wxPrintDialog
;
36 class WXDLLEXPORT wxPrintPreviewBase
;
37 class WXDLLEXPORT wxPreviewCanvas
;
38 class WXDLLEXPORT wxPreviewControlBar
;
39 class WXDLLEXPORT wxPreviewFrame
;
42 * Represents the printer: manages printing a wxPrintout object
45 class WXDLLEXPORT wxPrinterBase
: public wxObject
47 DECLARE_CLASS(wxPrinterBase
)
50 wxPrinterBase(wxPrintDialogData
*data
= (wxPrintDialogData
*) NULL
);
51 virtual ~wxPrinterBase();
53 virtual wxWindow
*CreateAbortWindow(wxWindow
*parent
, wxPrintout
*printout
);
54 virtual void ReportError(wxWindow
*parent
, wxPrintout
*printout
, char *message
);
56 wxPrintDialogData
& GetPrintDialogData() const
57 { return (wxPrintDialogData
&) m_printDialogData
; }
58 bool GetAbort() const { return sm_abortIt
; }
60 ///////////////////////////////////////////////////////////////////////////
63 virtual bool Setup(wxWindow
*parent
) = 0;
64 virtual bool Print(wxWindow
*parent
, wxPrintout
*printout
, bool prompt
= TRUE
) = 0;
65 virtual wxDC
* PrintDialog(wxWindow
*parent
) = 0;
68 wxPrintDialogData m_printDialogData
;
69 wxPrintout
* m_currentPrintout
;
71 static wxWindow
* sm_abortWindow
;
72 static bool sm_abortIt
;
78 * Represents an object via which a document may be printed.
79 * The programmer derives from this, overrides (at least) OnPrintPage,
80 * and passes it to a wxPrinter object for printing, or a wxPrintPreview
81 * object for previewing.
84 class WXDLLEXPORT wxPrintout
: public wxObject
86 DECLARE_ABSTRACT_CLASS(wxPrintout
)
89 wxPrintout(const wxString
& title
= "Printout");
90 virtual ~wxPrintout();
92 virtual bool OnBeginDocument(int startPage
, int endPage
);
93 virtual void OnEndDocument();
94 virtual void OnBeginPrinting();
95 virtual void OnEndPrinting();
97 // Guaranteed to be before any other functions are called
98 virtual void OnPreparePrinting() { }
100 virtual bool HasPage(int page
);
101 virtual bool OnPrintPage(int page
) = 0;
102 virtual void GetPageInfo(int *minPage
, int *maxPage
, int *pageFrom
, int *pageTo
);
104 virtual wxString
GetTitle() const { return m_printoutTitle
; }
106 wxDC
*GetDC() const { return m_printoutDC
; }
107 void SetDC(wxDC
*dc
) { m_printoutDC
= dc
; }
108 void SetPageSizePixels(int w
, int h
) { m_pageWidthPixels
= w
; m_pageHeightPixels
= h
; }
109 void GetPageSizePixels(int *w
, int *h
) const { *w
= m_pageWidthPixels
; *h
= m_pageHeightPixels
; }
110 void SetPageSizeMM(int w
, int h
) { m_pageWidthMM
= w
; m_pageHeightMM
= h
; }
111 void GetPageSizeMM(int *w
, int *h
) const { *w
= m_pageWidthMM
; *h
= m_pageHeightMM
; }
113 void SetPPIScreen(int x
, int y
) { m_PPIScreenX
= x
; m_PPIScreenY
= y
; }
114 void GetPPIScreen(int *x
, int *y
) const { *x
= m_PPIScreenX
; *y
= m_PPIScreenY
; }
115 void SetPPIPrinter(int x
, int y
) { m_PPIPrinterX
= x
; m_PPIPrinterY
= y
; }
116 void GetPPIPrinter(int *x
, int *y
) const { *x
= m_PPIPrinterX
; *y
= m_PPIPrinterY
; }
118 virtual bool IsPreview() const { return m_isPreview
; }
120 virtual void SetIsPreview(bool p
) { m_isPreview
= p
; }
123 wxString m_printoutTitle
;
126 int m_pageWidthPixels
;
127 int m_pageHeightPixels
;
142 * Canvas upon which a preview is drawn.
145 class WXDLLEXPORT wxPreviewCanvas
: public wxScrolledWindow
147 DECLARE_CLASS(wxPreviewCanvas
)
150 wxPreviewCanvas(wxPrintPreviewBase
*preview
,
152 const wxPoint
& pos
= wxDefaultPosition
,
153 const wxSize
& size
= wxDefaultSize
,
155 const wxString
& name
= "canvas");
158 void OnPaint(wxPaintEvent
& event
);
160 // Responds to colour changes
161 void OnSysColourChanged(wxSysColourChangedEvent
& event
);
164 wxPrintPreviewBase
* m_printPreview
;
166 DECLARE_EVENT_TABLE()
171 * Default frame for showing preview.
174 class WXDLLEXPORT wxPreviewFrame
: public wxFrame
176 DECLARE_CLASS(wxPreviewFrame
)
179 wxPreviewFrame(wxPrintPreviewBase
*preview
,
181 const wxString
& title
= "Print Preview",
182 const wxPoint
& pos
= wxDefaultPosition
,
183 const wxSize
& size
= wxDefaultSize
,
184 long style
= wxDEFAULT_FRAME_STYLE
,
185 const wxString
& name
= "frame");
188 void OnCloseWindow(wxCloseEvent
& event
);
189 virtual void Initialize();
190 virtual void CreateCanvas();
191 virtual void CreateControlBar();
193 wxWindow
* m_previewCanvas
;
194 wxPreviewControlBar
* m_controlBar
;
195 wxPrintPreviewBase
* m_printPreview
;
198 DECLARE_EVENT_TABLE()
202 * wxPreviewControlBar
203 * A panel with buttons for controlling a print preview.
204 * The programmer may wish to use other means for controlling
208 #define wxPREVIEW_PRINT 1
209 #define wxPREVIEW_PREVIOUS 2
210 #define wxPREVIEW_NEXT 4
211 #define wxPREVIEW_ZOOM 8
213 #define wxPREVIEW_DEFAULT wxPREVIEW_PREVIOUS|wxPREVIEW_NEXT|wxPREVIEW_ZOOM
216 #define wxID_PREVIEW_CLOSE 1
217 #define wxID_PREVIEW_NEXT 2
218 #define wxID_PREVIEW_PREVIOUS 3
219 #define wxID_PREVIEW_PRINT 4
220 #define wxID_PREVIEW_ZOOM 5
222 class WXDLLEXPORT wxPreviewControlBar
: public wxPanel
224 DECLARE_CLASS(wxPreviewControlBar
)
227 wxPreviewControlBar(wxPrintPreviewBase
*preview
,
230 const wxPoint
& pos
= wxDefaultPosition
,
231 const wxSize
& size
= wxDefaultSize
,
233 const wxString
& name
= "panel");
234 ~wxPreviewControlBar();
236 virtual void CreateButtons();
237 virtual void SetZoomControl(int zoom
);
238 virtual int GetZoomControl();
239 virtual wxPrintPreviewBase
*GetPrintPreview() const
240 { return m_printPreview
; }
242 void OnPrint(wxCommandEvent
& event
);
243 void OnWindowClose(wxCommandEvent
& event
);
246 void OnNextButton(wxCommandEvent
& WXUNUSED(event
)) { OnNext(); }
247 void OnPreviousButton(wxCommandEvent
& WXUNUSED(event
)) { OnPrevious(); }
248 void OnChar(wxKeyEvent
&event
);
249 void OnZoom(wxCommandEvent
& event
);
250 void OnPaint(wxPaintEvent
& event
);
253 wxPrintPreviewBase
* m_printPreview
;
254 wxButton
* m_closeButton
;
255 wxButton
* m_nextPageButton
;
256 wxButton
* m_previousPageButton
;
257 wxButton
* m_printButton
;
258 wxChoice
* m_zoomControl
;
262 DECLARE_EVENT_TABLE()
267 * Programmer creates an object of this class to preview a wxPrintout.
270 class WXDLLEXPORT wxPrintPreviewBase
: public wxObject
272 DECLARE_CLASS(wxPrintPreviewBase
)
275 wxPrintPreviewBase(wxPrintout
*printout
,
276 wxPrintout
*printoutForPrinting
= (wxPrintout
*) NULL
,
277 wxPrintDialogData
*data
= (wxPrintDialogData
*) NULL
);
278 wxPrintPreviewBase(wxPrintout
*printout
,
279 wxPrintout
*printoutForPrinting
,
281 virtual ~wxPrintPreviewBase();
283 virtual bool SetCurrentPage(int pageNum
);
284 int GetCurrentPage() const { return m_currentPage
; };
286 void SetPrintout(wxPrintout
*printout
) { m_previewPrintout
= printout
; };
287 wxPrintout
*GetPrintout() const { return m_previewPrintout
; };
288 wxPrintout
*GetPrintoutForPrinting() const { return m_printPrintout
; };
290 void SetFrame(wxFrame
*frame
) { m_previewFrame
= frame
; };
291 void SetCanvas(wxWindow
*canvas
) { m_previewCanvas
= canvas
; };
293 virtual wxFrame
*GetFrame() const { return m_previewFrame
; }
294 virtual wxWindow
*GetCanvas() const { return m_previewCanvas
; }
296 // The preview canvas should call this from OnPaint
297 virtual bool PaintPage(wxWindow
*canvas
, wxDC
& dc
);
299 // This draws a blank page onto the preview canvas
300 virtual bool DrawBlankPage(wxWindow
*canvas
, wxDC
& dc
);
302 // This is called by wxPrintPreview to render a page into a wxMemoryDC.
303 virtual bool RenderPage(int pageNum
);
305 wxPrintDialogData
& GetPrintDialogData() { return m_printDialogData
; }
307 virtual void SetZoom(int percent
);
308 int GetZoom() const { return m_currentZoom
; };
310 int GetMaxPage() const { return m_maxPage
; }
311 int GetMinPage() const { return m_minPage
; }
313 bool Ok() const { return m_isOk
; }
314 void SetOk(bool ok
) { m_isOk
= ok
; }
316 ///////////////////////////////////////////////////////////////////////////
319 // If we own a wxPrintout that can be used for printing, this
320 // will invoke the actual printing procedure. Called
321 // by the wxPreviewControlBar.
322 virtual bool Print(bool interactive
) = 0;
324 // Calculate scaling that needs to be done to get roughly
325 // the right scaling for the screen pretending to be
326 // the currently selected printer.
327 virtual void DetermineScaling() = 0;
330 wxPrintDialogData m_printDialogData
;
331 wxWindow
* m_previewCanvas
;
332 wxFrame
* m_previewFrame
;
333 wxBitmap
* m_previewBitmap
;
334 wxPrintout
* m_previewPrintout
;
335 wxPrintout
* m_printPrintout
;
338 float m_previewScale
;
347 bool m_printingPrepared
; // Called OnPreparePrinting?
350 void Init(wxPrintout
*printout
, wxPrintout
*printoutForPrinting
);
357 class WXDLLEXPORT wxPrintAbortDialog
: public wxDialog
360 wxPrintAbortDialog(wxWindow
*parent
,
361 const wxString
& title
,
362 const wxPoint
& pos
= wxDefaultPosition
,
363 const wxSize
& size
= wxDefaultSize
,
365 const wxString
& name
= "dialog")
366 : wxDialog(parent
, -1, title
, pos
, size
, style
, name
)
370 void OnCancel(wxCommandEvent
& event
);
373 DECLARE_EVENT_TABLE()
376 #endif // wxUSE_PRINTING_ARCHITECTURE