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();
194 wxWindow
* m_previewCanvas
;
195 wxPreviewControlBar
* m_controlBar
;
196 wxPrintPreviewBase
* m_printPreview
;
199 DECLARE_EVENT_TABLE()
203 * wxPreviewControlBar
204 * A panel with buttons for controlling a print preview.
205 * The programmer may wish to use other means for controlling
209 #define wxPREVIEW_PRINT 1
210 #define wxPREVIEW_PREVIOUS 2
211 #define wxPREVIEW_NEXT 4
212 #define wxPREVIEW_ZOOM 8
214 #define wxPREVIEW_DEFAULT wxPREVIEW_PREVIOUS|wxPREVIEW_NEXT|wxPREVIEW_ZOOM
217 #define wxID_PREVIEW_CLOSE 1
218 #define wxID_PREVIEW_NEXT 2
219 #define wxID_PREVIEW_PREVIOUS 3
220 #define wxID_PREVIEW_PRINT 4
221 #define wxID_PREVIEW_ZOOM 5
223 class WXDLLEXPORT wxPreviewControlBar
: public wxPanel
225 DECLARE_CLASS(wxPreviewControlBar
)
228 wxPreviewControlBar(wxPrintPreviewBase
*preview
,
231 const wxPoint
& pos
= wxDefaultPosition
,
232 const wxSize
& size
= wxDefaultSize
,
234 const wxString
& name
= "panel");
235 ~wxPreviewControlBar();
237 virtual void CreateButtons();
238 virtual void SetZoomControl(int zoom
);
239 virtual int GetZoomControl();
240 virtual wxPrintPreviewBase
*GetPrintPreview() const
241 { return m_printPreview
; }
243 void OnPrint(wxCommandEvent
& event
);
244 void OnWindowClose(wxCommandEvent
& event
);
245 void OnNext(wxCommandEvent
& event
);
246 void OnPrevious(wxCommandEvent
& event
);
247 void OnZoom(wxCommandEvent
& event
);
248 void OnPaint(wxPaintEvent
& event
);
251 wxPrintPreviewBase
* m_printPreview
;
252 wxButton
* m_closeButton
;
253 wxButton
* m_nextPageButton
;
254 wxButton
* m_previousPageButton
;
255 wxButton
* m_printButton
;
256 wxChoice
* m_zoomControl
;
260 DECLARE_EVENT_TABLE()
265 * Programmer creates an object of this class to preview a wxPrintout.
268 class WXDLLEXPORT wxPrintPreviewBase
: public wxObject
270 DECLARE_CLASS(wxPrintPreviewBase
)
273 wxPrintPreviewBase(wxPrintout
*printout
,
274 wxPrintout
*printoutForPrinting
= (wxPrintout
*) NULL
,
275 wxPrintDialogData
*data
= (wxPrintDialogData
*) NULL
);
276 wxPrintPreviewBase(wxPrintout
*printout
,
277 wxPrintout
*printoutForPrinting
,
279 virtual ~wxPrintPreviewBase();
281 virtual bool SetCurrentPage(int pageNum
);
282 int GetCurrentPage() const { return m_currentPage
; };
284 void SetPrintout(wxPrintout
*printout
) { m_previewPrintout
= printout
; };
285 wxPrintout
*GetPrintout() const { return m_previewPrintout
; };
286 wxPrintout
*GetPrintoutForPrinting() const { return m_printPrintout
; };
288 void SetFrame(wxFrame
*frame
) { m_previewFrame
= frame
; };
289 void SetCanvas(wxWindow
*canvas
) { m_previewCanvas
= canvas
; };
291 virtual wxFrame
*GetFrame() const { return m_previewFrame
; }
292 virtual wxWindow
*GetCanvas() const { return m_previewCanvas
; }
294 // The preview canvas should call this from OnPaint
295 virtual bool PaintPage(wxWindow
*canvas
, wxDC
& dc
);
297 // This draws a blank page onto the preview canvas
298 virtual bool DrawBlankPage(wxWindow
*canvas
, wxDC
& dc
);
300 // This is called by wxPrintPreview to render a page into a wxMemoryDC.
301 virtual bool RenderPage(int pageNum
);
303 wxPrintDialogData
& GetPrintDialogData() { return m_printDialogData
; }
305 virtual void SetZoom(int percent
);
306 int GetZoom() const { return m_currentZoom
; };
308 int GetMaxPage() const { return m_maxPage
; }
309 int GetMinPage() const { return m_minPage
; }
311 bool Ok() const { return m_isOk
; }
312 void SetOk(bool ok
) { m_isOk
= ok
; }
314 ///////////////////////////////////////////////////////////////////////////
317 // If we own a wxPrintout that can be used for printing, this
318 // will invoke the actual printing procedure. Called
319 // by the wxPreviewControlBar.
320 virtual bool Print(bool interactive
) = 0;
322 // Calculate scaling that needs to be done to get roughly
323 // the right scaling for the screen pretending to be
324 // the currently selected printer.
325 virtual void DetermineScaling() = 0;
328 wxPrintDialogData m_printDialogData
;
329 wxWindow
* m_previewCanvas
;
330 wxFrame
* m_previewFrame
;
331 wxBitmap
* m_previewBitmap
;
332 wxPrintout
* m_previewPrintout
;
333 wxPrintout
* m_printPrintout
;
336 float m_previewScale
;
347 void Init(wxPrintout
*printout
, wxPrintout
*printoutForPrinting
);
354 class WXDLLEXPORT wxPrintAbortDialog
: public wxDialog
357 wxPrintAbortDialog(wxWindow
*parent
,
358 const wxString
& title
,
359 const wxPoint
& pos
= wxDefaultPosition
,
360 const wxSize
& size
= wxDefaultSize
,
362 const wxString
& name
= "dialog")
363 : wxDialog(parent
, -1, title
, pos
, size
, style
, name
)
367 void OnCancel(wxCommandEvent
& event
);
370 DECLARE_EVENT_TABLE()
373 #endif // wxUSE_PRINTING_ARCHITECTURE