]> git.saurik.com Git - wxWidgets.git/blame_incremental - include/wx/prntbase.h
clear up wxStringBuffer docs a bit
[wxWidgets.git] / include / wx / prntbase.h
... / ...
CommitLineData
1/////////////////////////////////////////////////////////////////////////////
2// Name: prntbase.h
3// Purpose: Base classes for printing framework
4// Author: Julian Smart
5// Modified by:
6// Created: 01/02/97
7// RCS-ID: $Id$
8// Copyright: (c) Julian Smart
9// Licence: wxWindows licence
10/////////////////////////////////////////////////////////////////////////////
11
12#ifndef _WX_PRNTBASEH__
13#define _WX_PRNTBASEH__
14
15#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
16 #pragma interface "prntbase.h"
17#endif
18
19#include "wx/defs.h"
20
21#if wxUSE_PRINTING_ARCHITECTURE
22
23#include "wx/event.h"
24#include "wx/cmndata.h"
25#include "wx/panel.h"
26#include "wx/scrolwin.h"
27#include "wx/dialog.h"
28#include "wx/frame.h"
29
30class WXDLLEXPORT wxDC;
31class WXDLLEXPORT wxButton;
32class WXDLLEXPORT wxChoice;
33class WXDLLEXPORT wxPrintout;
34class WXDLLEXPORT wxPrinterBase;
35class WXDLLEXPORT wxPrintDialog;
36class WXDLLEXPORT wxPrintDialogBase;
37class WXDLLEXPORT wxPrintPreviewBase;
38class WXDLLEXPORT wxPreviewCanvas;
39class WXDLLEXPORT wxPreviewControlBar;
40class WXDLLEXPORT wxPreviewFrame;
41class WXDLLEXPORT wxPrintFactory;
42class WXDLLEXPORT wxPrintNativeDataBase;
43
44//----------------------------------------------------------------------------
45// error consts
46//----------------------------------------------------------------------------
47
48enum wxPrinterError
49{
50 wxPRINTER_NO_ERROR = 0,
51 wxPRINTER_CANCELLED,
52 wxPRINTER_ERROR
53};
54
55//----------------------------------------------------------------------------
56// wxPrintFactory
57//----------------------------------------------------------------------------
58
59class WXDLLEXPORT wxPrintFactory
60{
61public:
62 wxPrintFactory() {}
63 virtual ~wxPrintFactory() {}
64
65 virtual wxPrinterBase *CreatePrinter( wxPrintDialogData* data ) = 0;
66
67 virtual wxPrintPreviewBase *CreatePrintPreview( wxPrintout *preview,
68 wxPrintout *printout = NULL,
69 wxPrintDialogData *data = NULL ) = 0;
70 virtual wxPrintPreviewBase *CreatePrintPreview( wxPrintout *preview,
71 wxPrintout *printout,
72 wxPrintData *data ) = 0;
73
74 virtual wxPrintDialogBase *CreatePrintDialog( wxWindow *parent,
75 wxPrintDialogData *data = NULL ) = 0;
76 virtual wxPrintDialogBase *CreatePrintDialog( wxWindow *parent,
77 wxPrintData *data ) = 0;
78
79 // What to do and what to show in the wxPrintDialog
80 // a) Use the generic print setup dialog or a native one?
81 virtual bool HasPrintSetupDialog() = 0;
82 virtual wxDialog *CreatePrintSetupDialog( wxWindow *parent, wxPrintData *data ) = 0;
83 // b) Provide the "print to file" option ourselves or via print setup?
84 virtual bool HasOwnPrintToFile() = 0;
85 // c) Show current printer
86 virtual bool HasPrinterLine() = 0;
87 virtual wxString CreatePrinterLine() = 0;
88 // d) Show Status line for current printer?
89 virtual bool HasStatusLine() = 0;
90 virtual wxString CreateStatusLine() = 0;
91
92
93 virtual wxPrintNativeDataBase *CreatePrintNativeData() = 0;
94
95 static void SetPrintFactory( wxPrintFactory *factory );
96 static wxPrintFactory *GetFactory();
97 static wxPrintFactory *m_factory;
98};
99
100class WXDLLEXPORT wxNativePrintFactory: public wxPrintFactory
101{
102public:
103 virtual wxPrinterBase *CreatePrinter( wxPrintDialogData *data );
104
105 virtual wxPrintPreviewBase *CreatePrintPreview( wxPrintout *preview,
106 wxPrintout *printout = NULL,
107 wxPrintDialogData *data = NULL );
108 virtual wxPrintPreviewBase *CreatePrintPreview( wxPrintout *preview,
109 wxPrintout *printout,
110 wxPrintData *data );
111
112 virtual wxPrintDialogBase *CreatePrintDialog( wxWindow *parent,
113 wxPrintDialogData *data = NULL );
114 virtual wxPrintDialogBase *CreatePrintDialog( wxWindow *parent,
115 wxPrintData *data );
116
117 virtual bool HasPrintSetupDialog();
118 virtual wxDialog *CreatePrintSetupDialog( wxWindow *parent, wxPrintData *data );
119 virtual bool HasOwnPrintToFile();
120 virtual bool HasPrinterLine();
121 virtual wxString CreatePrinterLine();
122 virtual bool HasStatusLine();
123 virtual wxString CreateStatusLine();
124
125 virtual wxPrintNativeDataBase *CreatePrintNativeData();
126};
127
128//----------------------------------------------------------------------------
129// wxPrintNativeDataBase
130//----------------------------------------------------------------------------
131
132class WXDLLEXPORT wxPrintNativeDataBase: public wxObject
133{
134public:
135 wxPrintNativeDataBase();
136 virtual ~wxPrintNativeDataBase() {}
137
138 virtual bool TransferTo( wxPrintData &data ) = 0;
139 virtual bool TransferFrom( const wxPrintData &data ) = 0;
140
141 virtual bool Ok() const = 0;
142
143 int m_ref;
144
145private:
146 DECLARE_CLASS(wxPrintNativeDataBase)
147 DECLARE_NO_COPY_CLASS(wxPrintNativeDataBase)
148};
149
150//----------------------------------------------------------------------------
151// wxPrinterBase
152//----------------------------------------------------------------------------
153
154/*
155 * Represents the printer: manages printing a wxPrintout object
156 */
157
158class WXDLLEXPORT wxPrinterBase: public wxObject
159{
160public:
161 wxPrinterBase(wxPrintDialogData *data = (wxPrintDialogData *) NULL);
162 virtual ~wxPrinterBase();
163
164 virtual wxWindow *CreateAbortWindow(wxWindow *parent, wxPrintout *printout);
165 virtual void ReportError(wxWindow *parent, wxPrintout *printout, const wxString& message);
166
167 virtual wxPrintDialogData& GetPrintDialogData() const;
168 bool GetAbort() const { return sm_abortIt; }
169
170 static wxPrinterError GetLastError() { return sm_lastError; }
171
172 ///////////////////////////////////////////////////////////////////////////
173 // OVERRIDES
174
175 virtual bool Setup(wxWindow *parent) = 0;
176 virtual bool Print(wxWindow *parent, wxPrintout *printout, bool prompt = true) = 0;
177 virtual wxDC* PrintDialog(wxWindow *parent) = 0;
178
179protected:
180 wxPrintDialogData m_printDialogData;
181 wxPrintout* m_currentPrintout;
182
183 static wxPrinterError sm_lastError;
184
185public:
186 static wxWindow* sm_abortWindow;
187 static bool sm_abortIt;
188
189private:
190 DECLARE_CLASS(wxPrinterBase)
191 DECLARE_NO_COPY_CLASS(wxPrinterBase)
192};
193
194//----------------------------------------------------------------------------
195// wxPrinter
196//----------------------------------------------------------------------------
197
198class WXDLLEXPORT wxPrinter: public wxPrinterBase
199{
200public:
201 wxPrinter(wxPrintDialogData *data = (wxPrintDialogData *) NULL);
202 virtual ~wxPrinter();
203
204 virtual wxWindow *CreateAbortWindow(wxWindow *parent, wxPrintout *printout);
205 virtual void ReportError(wxWindow *parent, wxPrintout *printout, const wxString& message);
206
207 virtual bool Setup(wxWindow *parent);
208 virtual bool Print(wxWindow *parent, wxPrintout *printout, bool prompt = true);
209 virtual wxDC* PrintDialog(wxWindow *parent);
210
211 virtual wxPrintDialogData& GetPrintDialogData() const;
212
213protected:
214 wxPrinterBase *m_pimpl;
215
216private:
217 DECLARE_CLASS(wxPrinter)
218 DECLARE_NO_COPY_CLASS(wxPrinter)
219};
220
221//----------------------------------------------------------------------------
222// wxPrintout
223//----------------------------------------------------------------------------
224
225/*
226 * Represents an object via which a document may be printed.
227 * The programmer derives from this, overrides (at least) OnPrintPage,
228 * and passes it to a wxPrinter object for printing, or a wxPrintPreview
229 * object for previewing.
230 */
231
232class WXDLLEXPORT wxPrintout: public wxObject
233{
234public:
235 wxPrintout(const wxString& title = wxT("Printout"));
236 virtual ~wxPrintout();
237
238 virtual bool OnBeginDocument(int startPage, int endPage);
239 virtual void OnEndDocument();
240 virtual void OnBeginPrinting();
241 virtual void OnEndPrinting();
242
243 // Guaranteed to be before any other functions are called
244 virtual void OnPreparePrinting() { }
245
246 virtual bool HasPage(int page);
247 virtual bool OnPrintPage(int page) = 0;
248 virtual void GetPageInfo(int *minPage, int *maxPage, int *pageFrom, int *pageTo);
249
250 virtual wxString GetTitle() const { return m_printoutTitle; }
251
252 wxDC *GetDC() const { return m_printoutDC; }
253 void SetDC(wxDC *dc) { m_printoutDC = dc; }
254 void SetPageSizePixels(int w, int h) { m_pageWidthPixels = w; m_pageHeightPixels = h; }
255 void GetPageSizePixels(int *w, int *h) const { *w = m_pageWidthPixels; *h = m_pageHeightPixels; }
256 void SetPageSizeMM(int w, int h) { m_pageWidthMM = w; m_pageHeightMM = h; }
257 void GetPageSizeMM(int *w, int *h) const { *w = m_pageWidthMM; *h = m_pageHeightMM; }
258
259 void SetPPIScreen(int x, int y) { m_PPIScreenX = x; m_PPIScreenY = y; }
260 void GetPPIScreen(int *x, int *y) const { *x = m_PPIScreenX; *y = m_PPIScreenY; }
261 void SetPPIPrinter(int x, int y) { m_PPIPrinterX = x; m_PPIPrinterY = y; }
262 void GetPPIPrinter(int *x, int *y) const { *x = m_PPIPrinterX; *y = m_PPIPrinterY; }
263
264 virtual bool IsPreview() const { return m_isPreview; }
265
266 virtual void SetIsPreview(bool p) { m_isPreview = p; }
267
268private:
269 wxString m_printoutTitle;
270 wxDC* m_printoutDC;
271
272 int m_pageWidthPixels;
273 int m_pageHeightPixels;
274
275 int m_pageWidthMM;
276 int m_pageHeightMM;
277
278 int m_PPIScreenX;
279 int m_PPIScreenY;
280 int m_PPIPrinterX;
281 int m_PPIPrinterY;
282
283 bool m_isPreview;
284
285private:
286 DECLARE_ABSTRACT_CLASS(wxPrintout)
287 DECLARE_NO_COPY_CLASS(wxPrintout)
288};
289
290/*
291 * wxPreviewCanvas
292 * Canvas upon which a preview is drawn.
293 */
294
295class WXDLLEXPORT wxPreviewCanvas: public wxScrolledWindow
296{
297public:
298 wxPreviewCanvas(wxPrintPreviewBase *preview,
299 wxWindow *parent,
300 const wxPoint& pos = wxDefaultPosition,
301 const wxSize& size = wxDefaultSize,
302 long style = 0,
303 const wxString& name = wxT("canvas"));
304 ~wxPreviewCanvas();
305
306 void OnPaint(wxPaintEvent& event);
307 void OnChar(wxKeyEvent &event);
308
309 // Responds to colour changes
310 void OnSysColourChanged(wxSysColourChangedEvent& event);
311
312private:
313 wxPrintPreviewBase* m_printPreview;
314
315 DECLARE_CLASS(wxPreviewCanvas)
316 DECLARE_EVENT_TABLE()
317 DECLARE_NO_COPY_CLASS(wxPreviewCanvas)
318};
319
320/*
321 * wxPreviewFrame
322 * Default frame for showing preview.
323 */
324
325class WXDLLEXPORT wxPreviewFrame: public wxFrame
326{
327public:
328 wxPreviewFrame(wxPrintPreviewBase *preview,
329 wxWindow *parent,
330 const wxString& title = wxT("Print Preview"),
331 const wxPoint& pos = wxDefaultPosition,
332 const wxSize& size = wxDefaultSize,
333 long style = wxDEFAULT_FRAME_STYLE,
334 const wxString& name = wxT("frame"));
335 ~wxPreviewFrame();
336
337 void OnCloseWindow(wxCloseEvent& event);
338 virtual void Initialize();
339 virtual void CreateCanvas();
340 virtual void CreateControlBar();
341
342 inline wxPreviewControlBar* GetControlBar() const { return m_controlBar; }
343
344protected:
345 wxPreviewCanvas* m_previewCanvas;
346 wxPreviewControlBar* m_controlBar;
347 wxPrintPreviewBase* m_printPreview;
348 wxWindowDisabler* m_windowDisabler;
349
350private:
351 DECLARE_CLASS(wxPreviewFrame)
352 DECLARE_EVENT_TABLE()
353 DECLARE_NO_COPY_CLASS(wxPreviewFrame)
354};
355
356/*
357 * wxPreviewControlBar
358 * A panel with buttons for controlling a print preview.
359 * The programmer may wish to use other means for controlling
360 * the print preview.
361 */
362
363#define wxPREVIEW_PRINT 1
364#define wxPREVIEW_PREVIOUS 2
365#define wxPREVIEW_NEXT 4
366#define wxPREVIEW_ZOOM 8
367#define wxPREVIEW_FIRST 16
368#define wxPREVIEW_LAST 32
369#define wxPREVIEW_GOTO 64
370
371#define wxPREVIEW_DEFAULT wxPREVIEW_PREVIOUS|wxPREVIEW_NEXT|wxPREVIEW_ZOOM\
372 |wxPREVIEW_FIRST|wxPREVIEW_GOTO|wxPREVIEW_LAST
373
374// Ids for controls
375#define wxID_PREVIEW_CLOSE 1
376#define wxID_PREVIEW_NEXT 2
377#define wxID_PREVIEW_PREVIOUS 3
378#define wxID_PREVIEW_PRINT 4
379#define wxID_PREVIEW_ZOOM 5
380#define wxID_PREVIEW_FIRST 6
381#define wxID_PREVIEW_LAST 7
382#define wxID_PREVIEW_GOTO 8
383
384class WXDLLEXPORT wxPreviewControlBar: public wxPanel
385{
386 DECLARE_CLASS(wxPreviewControlBar)
387
388public:
389 wxPreviewControlBar(wxPrintPreviewBase *preview,
390 long buttons,
391 wxWindow *parent,
392 const wxPoint& pos = wxDefaultPosition,
393 const wxSize& size = wxDefaultSize,
394 long style = wxTAB_TRAVERSAL,
395 const wxString& name = wxT("panel"));
396 ~wxPreviewControlBar();
397
398 virtual void CreateButtons();
399 virtual void SetZoomControl(int zoom);
400 virtual int GetZoomControl();
401 virtual wxPrintPreviewBase *GetPrintPreview() const
402 { return m_printPreview; }
403
404 void OnWindowClose(wxCommandEvent& event);
405 void OnNext();
406 void OnPrevious();
407 void OnFirst();
408 void OnLast();
409 void OnGoto();
410 void OnPrint();
411 void OnPrintButton(wxCommandEvent& WXUNUSED(event)) { OnPrint(); }
412 void OnNextButton(wxCommandEvent & WXUNUSED(event)) { OnNext(); }
413 void OnPreviousButton(wxCommandEvent & WXUNUSED(event)) { OnPrevious(); }
414 void OnFirstButton(wxCommandEvent & WXUNUSED(event)) { OnFirst(); }
415 void OnLastButton(wxCommandEvent & WXUNUSED(event)) { OnLast(); }
416 void OnGotoButton(wxCommandEvent & WXUNUSED(event)) { OnGoto(); }
417 void OnZoom(wxCommandEvent& event);
418 void OnPaint(wxPaintEvent& event);
419
420protected:
421 wxPrintPreviewBase* m_printPreview;
422 wxButton* m_closeButton;
423 wxButton* m_nextPageButton;
424 wxButton* m_previousPageButton;
425 wxButton* m_printButton;
426 wxChoice* m_zoomControl;
427 wxButton* m_firstPageButton;
428 wxButton* m_lastPageButton;
429 wxButton* m_gotoPageButton;
430 long m_buttonFlags;
431
432private:
433 DECLARE_EVENT_TABLE()
434 DECLARE_NO_COPY_CLASS(wxPreviewControlBar)
435};
436
437//----------------------------------------------------------------------------
438// wxPrintPreviewBase
439//----------------------------------------------------------------------------
440
441/*
442 * Programmer creates an object of this class to preview a wxPrintout.
443 */
444
445class WXDLLEXPORT wxPrintPreviewBase: public wxObject
446{
447public:
448 wxPrintPreviewBase(wxPrintout *printout,
449 wxPrintout *printoutForPrinting = (wxPrintout *) NULL,
450 wxPrintDialogData *data = (wxPrintDialogData *) NULL);
451 wxPrintPreviewBase(wxPrintout *printout,
452 wxPrintout *printoutForPrinting,
453 wxPrintData *data);
454 virtual ~wxPrintPreviewBase();
455
456 virtual bool SetCurrentPage(int pageNum);
457 virtual int GetCurrentPage() const;
458
459 virtual void SetPrintout(wxPrintout *printout);
460 virtual wxPrintout *GetPrintout() const;
461 virtual wxPrintout *GetPrintoutForPrinting() const;
462
463 virtual void SetFrame(wxFrame *frame);
464 virtual void SetCanvas(wxPreviewCanvas *canvas);
465
466 virtual wxFrame *GetFrame() const;
467 virtual wxPreviewCanvas *GetCanvas() const;
468
469 // The preview canvas should call this from OnPaint
470 virtual bool PaintPage(wxPreviewCanvas *canvas, wxDC& dc);
471
472 // This draws a blank page onto the preview canvas
473 virtual bool DrawBlankPage(wxPreviewCanvas *canvas, wxDC& dc);
474
475 // Adjusts the scrollbars for the current scale
476 virtual void AdjustScrollbars(wxPreviewCanvas *canvas);
477
478 // This is called by wxPrintPreview to render a page into a wxMemoryDC.
479 virtual bool RenderPage(int pageNum);
480
481
482 virtual void SetZoom(int percent);
483 virtual int GetZoom() const;
484
485 virtual wxPrintDialogData& GetPrintDialogData();
486
487 virtual int GetMaxPage() const;
488 virtual int GetMinPage() const;
489
490 virtual bool Ok() const;
491 virtual void SetOk(bool ok);
492
493 ///////////////////////////////////////////////////////////////////////////
494 // OVERRIDES
495
496 // If we own a wxPrintout that can be used for printing, this
497 // will invoke the actual printing procedure. Called
498 // by the wxPreviewControlBar.
499 virtual bool Print(bool interactive) = 0;
500
501 // Calculate scaling that needs to be done to get roughly
502 // the right scaling for the screen pretending to be
503 // the currently selected printer.
504 virtual void DetermineScaling() = 0;
505
506protected:
507 wxPrintDialogData m_printDialogData;
508 wxPreviewCanvas* m_previewCanvas;
509 wxFrame* m_previewFrame;
510 wxBitmap* m_previewBitmap;
511 wxPrintout* m_previewPrintout;
512 wxPrintout* m_printPrintout;
513 int m_currentPage;
514 int m_currentZoom;
515 float m_previewScale;
516 int m_topMargin;
517 int m_leftMargin;
518 int m_pageWidth;
519 int m_pageHeight;
520 int m_minPage;
521 int m_maxPage;
522
523 bool m_isOk;
524 bool m_printingPrepared; // Called OnPreparePrinting?
525
526private:
527 void Init(wxPrintout *printout, wxPrintout *printoutForPrinting);
528
529 DECLARE_NO_COPY_CLASS(wxPrintPreviewBase)
530 DECLARE_CLASS(wxPrintPreviewBase)
531};
532
533//----------------------------------------------------------------------------
534// wxPrintPreview
535//----------------------------------------------------------------------------
536
537class WXDLLEXPORT wxPrintPreview: public wxPrintPreviewBase
538{
539public:
540 wxPrintPreview(wxPrintout *printout,
541 wxPrintout *printoutForPrinting = (wxPrintout *) NULL,
542 wxPrintDialogData *data = (wxPrintDialogData *) NULL);
543 wxPrintPreview(wxPrintout *printout,
544 wxPrintout *printoutForPrinting,
545 wxPrintData *data);
546 virtual ~wxPrintPreview();
547
548 virtual bool SetCurrentPage(int pageNum);
549 virtual int GetCurrentPage() const;
550 virtual void SetPrintout(wxPrintout *printout);
551 virtual wxPrintout *GetPrintout() const;
552 virtual wxPrintout *GetPrintoutForPrinting() const;
553 virtual void SetFrame(wxFrame *frame);
554 virtual void SetCanvas(wxPreviewCanvas *canvas);
555
556 virtual wxFrame *GetFrame() const;
557 virtual wxPreviewCanvas *GetCanvas() const;
558 virtual bool PaintPage(wxPreviewCanvas *canvas, wxDC& dc);
559 virtual bool DrawBlankPage(wxPreviewCanvas *canvas, wxDC& dc);
560 virtual void AdjustScrollbars(wxPreviewCanvas *canvas);
561 virtual bool RenderPage(int pageNum);
562 virtual void SetZoom(int percent);
563
564 virtual bool Print(bool interactive);
565 virtual void DetermineScaling();
566
567 virtual wxPrintDialogData& GetPrintDialogData();
568
569 virtual int GetMaxPage() const;
570 virtual int GetMinPage() const;
571
572 virtual bool Ok() const;
573 virtual void SetOk(bool ok);
574
575private:
576 wxPrintPreviewBase *m_pimpl;
577
578private:
579 DECLARE_CLASS(wxPrintPreview)
580 DECLARE_NO_COPY_CLASS(wxPrintPreview)
581};
582
583//----------------------------------------------------------------------------
584// wxPrintAbortDialog
585//----------------------------------------------------------------------------
586
587class WXDLLEXPORT wxPrintAbortDialog: public wxDialog
588{
589public:
590 wxPrintAbortDialog(wxWindow *parent,
591 const wxString& title,
592 const wxPoint& pos = wxDefaultPosition,
593 const wxSize& size = wxDefaultSize,
594 long style = 0,
595 const wxString& name = wxT("dialog"))
596 : wxDialog(parent, wxID_ANY, title, pos, size, style, name)
597 {
598 }
599
600 void OnCancel(wxCommandEvent& event);
601
602private:
603 DECLARE_EVENT_TABLE()
604 DECLARE_NO_COPY_CLASS(wxPrintAbortDialog)
605};
606
607#endif // wxUSE_PRINTING_ARCHITECTURE
608
609#endif
610 // _WX_PRNTBASEH__