2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: print.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxPreviewControlBar
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxPreviewControlBar
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
This is the default implementation of the preview control bar, a panel
|
2008-04-10 21:16:38 +00:00
|
|
|
with buttons and a zoom control.
|
|
|
|
|
|
|
|
You can derive a new class from this and override some or all member functions
|
|
|
|
to change the behaviour and appearance; or you can leave it as it is.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxbase}
|
|
|
|
@category{printing}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxPreviewFrame, wxPreviewCanvas, wxPrintPreview
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxPreviewControlBar : public wxPanel
|
|
|
|
{
|
|
|
|
public:
|
2008-04-10 21:16:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Constructor.
|
|
|
|
|
|
|
|
The @a buttons parameter may be a combination of the following, using the bitwise
|
|
|
|
'or' operator:
|
|
|
|
|
2008-04-10 22:09:29 +00:00
|
|
|
@beginFlagTable
|
|
|
|
@flag{wxPREVIEW_PRINT}
|
2008-04-10 21:16:38 +00:00
|
|
|
Create a print button.
|
2008-04-10 22:09:29 +00:00
|
|
|
@flag{wxPREVIEW_NEXT}
|
2008-04-10 21:16:38 +00:00
|
|
|
Create a next page button.
|
2008-04-10 22:09:29 +00:00
|
|
|
@flag{wxPREVIEW_PREVIOUS}
|
2008-04-10 21:16:38 +00:00
|
|
|
Create a previous page button.
|
2008-04-10 22:09:29 +00:00
|
|
|
@flag{wxPREVIEW_ZOOM}
|
2008-04-10 21:16:38 +00:00
|
|
|
Create a zoom control.
|
2008-04-10 22:09:29 +00:00
|
|
|
@flag{wxPREVIEW_DEFAULT}
|
2008-04-10 21:16:38 +00:00
|
|
|
Equivalent to a combination of @c wxPREVIEW_PREVIOUS, @c wxPREVIEW_NEXT
|
|
|
|
and @c wxPREVIEW_ZOOM.
|
2008-04-10 22:09:29 +00:00
|
|
|
@endFlagTable
|
2008-04-10 21:16:38 +00:00
|
|
|
*/
|
|
|
|
wxPreviewControlBar(wxPrintPreview* preview,
|
|
|
|
long buttons,
|
|
|
|
wxWindow* parent,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = 0,
|
|
|
|
const wxString& name = "panel");
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
Destructor.
|
|
|
|
*/
|
|
|
|
~wxPreviewControlBar();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Creates buttons, according to value of the button style flags.
|
2008-04-10 22:04:29 +00:00
|
|
|
|
|
|
|
@todo which flags??
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void CreateButtons();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the print preview object associated with the control bar.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
wxPrintPreview* GetPrintPreview();
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the current zoom setting in percent.
|
|
|
|
*/
|
|
|
|
int GetZoomControl();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the zoom control.
|
|
|
|
*/
|
|
|
|
void SetZoomControl(int percent);
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxPreviewCanvas
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
A preview canvas is the default canvas used by the print preview
|
|
|
|
system to display the preview.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxbase}
|
|
|
|
@category{printing}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxPreviewFrame, wxPreviewControlBar, wxPrintPreview
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxPreviewCanvas : public wxScrolledWindow
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Constructor.
|
|
|
|
*/
|
|
|
|
wxPreviewCanvas(wxPrintPreview* preview, wxWindow* parent,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = 0,
|
|
|
|
const wxString& name = "canvas");
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor.
|
|
|
|
*/
|
|
|
|
~wxPreviewCanvas();
|
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Calls wxPrintPreview::PaintPage() to refresh the canvas.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void OnPaint(wxPaintEvent& event);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxPreviewFrame
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
This class provides the default method of managing the print preview interface.
|
|
|
|
Member functions may be overridden to replace functionality, or the
|
|
|
|
class may be used without derivation.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxbase}
|
|
|
|
@category{printing}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxPreviewCanvas, wxPreviewControlBar, wxPrintPreview
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxPreviewFrame : public wxFrame
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Constructor.
|
|
|
|
|
|
|
|
Pass a print preview object plus other normal frame arguments.
|
2008-03-08 13:52:38 +00:00
|
|
|
The print preview object will be destroyed by the frame when it closes.
|
|
|
|
*/
|
|
|
|
wxPreviewFrame(wxPrintPreview* preview, wxWindow* parent,
|
|
|
|
const wxString& title,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size size = wxDefaultSize,
|
|
|
|
long style = wxDEFAULT_FRAME_STYLE,
|
|
|
|
const wxString& name = "frame");
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor.
|
|
|
|
*/
|
|
|
|
~wxPreviewFrame();
|
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Creates a wxPreviewCanvas.
|
|
|
|
|
|
|
|
Override this function to allow a user-defined preview canvas object
|
|
|
|
to be created.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void CreateCanvas();
|
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Creates a wxPreviewControlBar.
|
|
|
|
|
|
|
|
Override this function to allow a user-defined preview control bar object
|
|
|
|
to be created.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void CreateControlBar();
|
|
|
|
|
|
|
|
/**
|
2008-04-10 22:04:29 +00:00
|
|
|
Creates the preview canvas and control bar, and calls wxWindow::MakeModal(@true)
|
|
|
|
to disable other top-level windows in the application.
|
2008-04-10 21:16:38 +00:00
|
|
|
|
2008-04-10 22:04:29 +00:00
|
|
|
This function should be called by the application prior to showing the frame.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void Initialize();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Enables the other frames in the application, and deletes the print preview
|
|
|
|
object, implicitly deleting any printout objects associated with the print
|
|
|
|
preview object.
|
|
|
|
*/
|
|
|
|
void OnCloseWindow(wxCloseEvent& event);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxPrintPreview
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Objects of this class manage the print preview process. The object is passed
|
|
|
|
a wxPrintout object, and the wxPrintPreview object itself is passed to
|
|
|
|
a wxPreviewFrame object. Previewing is started by initializing and showing
|
2008-04-10 21:16:38 +00:00
|
|
|
the preview frame. Unlike wxPrinter::Print(), flow of control returns to the
|
|
|
|
application immediately after the frame is shown.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-06-16 08:45:39 +00:00
|
|
|
@note
|
|
|
|
The preview shown is only exact on Windows. On other platforms, the wxDC
|
|
|
|
used for preview is different from what is used for printing and the
|
|
|
|
results may be significantly different, depending on how is the output
|
|
|
|
created. In particular, printing code relying on wxDC::GetTextExtent()
|
|
|
|
heavily (for example, wxHtmlEasyPrinting and other wxHTML classes do) is
|
|
|
|
affected. It is recommended to use native preview functionality on
|
|
|
|
platforms that offer it (OS X, GTK+).
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxbase}
|
|
|
|
@category{printing}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-04-10 22:04:29 +00:00
|
|
|
@see @ref overview_printing, wxPrinterDC, wxPrintDialog, wxPrintout, wxPrinter,
|
|
|
|
wxPreviewCanvas, wxPreviewControlBar, wxPreviewFrame
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxPrintPreview : public wxObject
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Constructor.
|
|
|
|
|
|
|
|
Pass a printout object, an optional printout object to be used for actual
|
|
|
|
printing, and the address of an optional block of printer data, which will
|
|
|
|
be copied to the print preview object's print data.
|
|
|
|
|
2008-04-10 22:04:29 +00:00
|
|
|
If @a printoutForPrinting is non-@NULL, a @b "Print..." button will be placed on
|
2008-04-10 21:16:38 +00:00
|
|
|
the preview frame so that the user can print directly from the preview interface.
|
|
|
|
|
|
|
|
@remarks
|
2008-03-08 13:52:38 +00:00
|
|
|
Do not explicitly delete the printout objects once this destructor has been
|
|
|
|
called, since they will be deleted in the wxPrintPreview constructor.
|
2008-03-09 12:33:59 +00:00
|
|
|
The same does not apply to the @a data argument.
|
2008-04-10 21:16:38 +00:00
|
|
|
|
2008-04-10 22:04:29 +00:00
|
|
|
Use IsOk() to check whether the wxPrintPreview object was created correctly.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
wxPrintPreview(wxPrintout* printout,
|
|
|
|
wxPrintout* printoutForPrinting,
|
2008-03-09 12:33:59 +00:00
|
|
|
wxPrintData* data = NULL);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Destructor.
|
|
|
|
|
|
|
|
Deletes both print preview objects, so do not destroy these objects
|
2008-03-08 13:52:38 +00:00
|
|
|
in your application.
|
|
|
|
*/
|
|
|
|
~wxPrinter();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the preview window used for displaying the print preview image.
|
|
|
|
*/
|
|
|
|
wxPreviewCanvas* GetCanvas();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the page currently being previewed.
|
|
|
|
*/
|
|
|
|
int GetCurrentPage();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the frame used for displaying the print preview canvas
|
|
|
|
and control bar.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
wxFrame* GetFrame();
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the maximum page number.
|
|
|
|
*/
|
|
|
|
int GetMaxPage();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the minimum page number.
|
|
|
|
*/
|
|
|
|
int GetMinPage();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the preview printout object associated with the wxPrintPreview object.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
wxPrintout* GetPrintout();
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the printout object to be used for printing from within the preview
|
|
|
|
interface,
|
|
|
|
or @NULL if none exists.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
wxPrintout* GetPrintoutForPrinting();
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Returns @true if the wxPrintPreview is valid, @false otherwise.
|
|
|
|
|
|
|
|
It could return @false if there was a problem initializing the printer
|
|
|
|
device context (current printer not set, for example).
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-04-10 22:04:29 +00:00
|
|
|
bool IsOk();
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
This refreshes the preview window with the preview image.
|
|
|
|
It must be called from the preview window's OnPaint member.
|
2008-04-10 21:16:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
The implementation simply blits the preview bitmap onto
|
|
|
|
the canvas, creating a new preview bitmap if none exists.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
bool PaintPage(wxPreviewCanvas* canvas, wxDC dc);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Invokes the print process using the second wxPrintout object
|
|
|
|
supplied in the wxPrintPreview constructor.
|
|
|
|
Will normally be called by the @b Print... panel item on the
|
|
|
|
preview frame's control bar.
|
2008-04-10 21:16:38 +00:00
|
|
|
|
|
|
|
Returns @false in case of error -- call wxPrinter::GetLastError()
|
|
|
|
to get detailed information about the kind of the error.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
bool Print(bool prompt);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Renders a page into a wxMemoryDC. Used internally by wxPrintPreview.
|
|
|
|
*/
|
|
|
|
bool RenderPage(int pageNum);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the window to be used for displaying the print preview image.
|
|
|
|
*/
|
|
|
|
void SetCanvas(wxPreviewCanvas* window);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the current page to be previewed.
|
|
|
|
*/
|
|
|
|
void SetCurrentPage(int pageNum);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the frame to be used for displaying the print preview canvas
|
|
|
|
and control bar.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
void SetFrame(wxFrame* frame);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Associates a printout object with the wxPrintPreview object.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
void SetPrintout(wxPrintout* printout);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-04-10 22:04:29 +00:00
|
|
|
Sets the percentage preview zoom, and refreshes the preview canvas accordingly.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void SetZoom(int percent);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxPrinter
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
This class represents the Windows or PostScript printer, and is the vehicle
|
2008-04-10 21:16:38 +00:00
|
|
|
through which printing may be launched by an application.
|
2008-04-10 22:04:29 +00:00
|
|
|
|
2008-04-10 21:16:38 +00:00
|
|
|
Printing can also be achieved through using of lower functions and classes,
|
|
|
|
but this and associated classes provide a more convenient and general method
|
|
|
|
of printing.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxbase}
|
|
|
|
@category{printing}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-04-10 22:04:29 +00:00
|
|
|
@see @ref overview_printing, wxPrinterDC, wxPrintDialog, wxPrintout, wxPrintPreview
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxPrinter : public wxObject
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Constructor.
|
|
|
|
|
|
|
|
Pass an optional pointer to a block of print dialog data, which will be
|
|
|
|
copied to the printer object's local data.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
@see wxPrintDialogData, wxPrintData
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
wxPrinter(wxPrintDialogData* data = NULL);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Creates the default printing abort window, with a cancel button.
|
|
|
|
*/
|
|
|
|
void CreateAbortWindow(wxWindow* parent, wxPrintout* printout);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if the user has aborted the print job.
|
|
|
|
*/
|
|
|
|
bool GetAbort();
|
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Return last error. Valid after calling Print(), PrintDialog() or
|
|
|
|
wxPrintPreview::Print().
|
2008-04-10 22:04:29 +00:00
|
|
|
|
|
|
|
These functions set last error to @c wxPRINTER_NO_ERROR if no error happened.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-04-10 21:16:38 +00:00
|
|
|
Returned value is one of the following:
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-04-10 21:16:38 +00:00
|
|
|
@beginTable
|
2008-04-10 22:04:29 +00:00
|
|
|
@row2col{wxPRINTER_NO_ERROR, No error happened.}
|
|
|
|
@row2col{wxPRINTER_CANCELLED, The user cancelled printing.}
|
|
|
|
@row2col{wxPRINTER_ERROR, There was an error during printing.}
|
2008-04-10 21:16:38 +00:00
|
|
|
@endTable
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
static wxPrinterError GetLastError();
|
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Returns the @ref overview_printing_printdata "print data" associated with
|
|
|
|
the printer object.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-04-10 21:16:38 +00:00
|
|
|
wxPrintDialogData& GetPrintDialogData();
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Starts the printing process. Provide a parent window, a user-defined wxPrintout
|
2008-04-10 21:16:38 +00:00
|
|
|
object which controls the printing of a document, and whether the print dialog
|
|
|
|
should be invoked first.
|
|
|
|
|
|
|
|
Print() could return @false if there was a problem initializing the printer device
|
|
|
|
context (current printer not set, for example) or the user cancelled printing.
|
|
|
|
Call GetLastError() to get detailed information about the kind of the error.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
bool Print(wxWindow* parent, wxPrintout* printout,
|
|
|
|
bool prompt = true);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Invokes the print dialog.
|
|
|
|
|
|
|
|
If successful (the user did not press Cancel and no error occurred),
|
2008-04-10 22:04:29 +00:00
|
|
|
a suitable device context will be returned; otherwise @NULL is returned;
|
|
|
|
call GetLastError() to get detailed information about the kind of the error.
|
2008-04-10 21:16:38 +00:00
|
|
|
|
|
|
|
@remarks
|
2008-03-08 13:52:38 +00:00
|
|
|
The application must delete this device context to avoid a memory leak.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
wxDC* PrintDialog(wxWindow* parent);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Default error-reporting function.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
void ReportError(wxWindow* parent, wxPrintout* printout,
|
2008-03-08 13:52:38 +00:00
|
|
|
const wxString& message);
|
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Invokes the print setup dialog.
|
|
|
|
|
|
|
|
@remarks
|
|
|
|
The setup dialog is obsolete from Windows 95, though retained
|
|
|
|
for backward compatibility.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
bool Setup(wxWindow* parent);
|
2008-03-08 13:52:38 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxPrintout
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-04-10 21:16:38 +00:00
|
|
|
This class encapsulates the functionality of printing out an application document.
|
|
|
|
|
|
|
|
A new class must be derived and members overridden to respond to calls such as
|
|
|
|
OnPrintPage() and HasPage() and to render the print image onto an associated wxDC.
|
|
|
|
Instances of this class are passed to wxPrinter::Print() or
|
2008-03-08 13:52:38 +00:00
|
|
|
to a wxPrintPreview object to initiate printing or previewing.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Your derived wxPrintout is responsible for drawing both the preview image and
|
|
|
|
the printed page. If your windows' drawing routines accept an arbitrary DC as an
|
|
|
|
argument, you can re-use those routines within your wxPrintout subclass to draw
|
|
|
|
the printout image. You may also add additional drawing elements within your
|
|
|
|
wxPrintout subclass, like headers, footers, and/or page numbers. However, the
|
|
|
|
image on the printed page will often differ from the image drawn on the screen,
|
|
|
|
as will the print preview image -- not just in the presence of headers and
|
|
|
|
footers, but typically in scale. A high-resolution printer presents a much
|
|
|
|
larger drawing surface (i.e., a higher-resolution DC); a zoomed-out preview
|
|
|
|
image presents a much smaller drawing surface (lower-resolution DC). By using
|
|
|
|
the routines FitThisSizeToXXX() and/or MapScreenSizeToXXX() within your
|
|
|
|
wxPrintout subclass to set the user scale and origin of the associated DC, you
|
|
|
|
can easily use a single drawing routine to draw on your application's windows,
|
|
|
|
to create the print preview image, and to create the printed paper image, and
|
|
|
|
achieve a common appearance to the preview image and the printed page.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxbase}
|
|
|
|
@category{printing}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-04-10 22:04:29 +00:00
|
|
|
@see @ref overview_printing, wxPrinterDC, wxPrintDialog, wxPageSetupDialog,
|
|
|
|
wxPrinter, wxPrintPreview
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxPrintout : public wxObject
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Constructor.
|
|
|
|
|
|
|
|
Pass an optional title argument - the current filename would be a
|
|
|
|
good idea. This will appear in the printing list (at least in MSW)
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
wxPrintout(const wxString& title = "Printout");
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor.
|
|
|
|
*/
|
|
|
|
~wxPrintout();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the user scale and device origin of the wxDC associated with this wxPrintout
|
|
|
|
so that the given image size fits entirely within the page rectangle and the
|
2008-04-10 21:16:38 +00:00
|
|
|
origin is at the top left corner of the page rectangle.
|
|
|
|
|
|
|
|
On MSW and Mac, the page rectangle is the printable area of the page.
|
|
|
|
On other platforms and PostScript printing, the page rectangle is the entire paper.
|
|
|
|
|
|
|
|
Use this if you want your printed image as large as possible, but with the caveat
|
|
|
|
that on some platforms, portions of the image might be cut off at the edges.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void FitThisSizeToPage(const wxSize& imageSize);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the user scale and device origin of the wxDC associated with this wxPrintout
|
|
|
|
so that the given image size fits entirely within the page margins set in the
|
2008-04-10 21:16:38 +00:00
|
|
|
given wxPageSetupDialogData object.
|
|
|
|
|
|
|
|
This function provides the greatest consistency across all platforms because it
|
|
|
|
does not depend on having access to the printable area of the paper.
|
|
|
|
|
|
|
|
@remarks
|
|
|
|
On Mac, the native wxPageSetupDialog does not let you set the page margins;
|
|
|
|
you'll have to provide your own mechanism, or you can use the Mac-only class
|
|
|
|
wxMacPageMarginsDialog.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void FitThisSizeToPageMargins(const wxSize& imageSize,
|
|
|
|
const wxPageSetupDialogData& pageSetupData);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the user scale and device origin of the wxDC associated with this wxPrintout
|
|
|
|
so that the given image size fits entirely within the paper and the origin is at
|
2008-04-10 21:16:38 +00:00
|
|
|
the top left corner of the paper.
|
|
|
|
|
|
|
|
Use this if you're managing your own page margins.
|
|
|
|
|
|
|
|
@note
|
|
|
|
With most printers, the region around the edges of the paper are not
|
|
|
|
printable so that the edges of the image could be cut off.
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void FitThisSizeToPaper(const wxSize& imageSize);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the device context associated with the printout (given to the printout
|
2008-04-10 21:16:38 +00:00
|
|
|
at start of printing or previewing).
|
|
|
|
|
|
|
|
The application can use GetDC() to obtain a device context to draw on.
|
|
|
|
|
|
|
|
This will be a wxPrinterDC if printing under Windows or Mac, a wxPostScriptDC
|
|
|
|
if printing on other platforms, and a wxMemoryDC if previewing.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
wxDC* GetDC();
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Return the rectangle corresponding to the page margins specified by the given
|
|
|
|
wxPageSetupDialogData object in the associated wxDC's logical coordinates for
|
2008-04-10 21:16:38 +00:00
|
|
|
the current user scale and device origin.
|
|
|
|
|
|
|
|
The page margins are specified with respect to the edges of the paper on all
|
|
|
|
platforms.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
wxRect GetLogicalPageMarginsRect(const wxPageSetupDialogData& pageSetupData);
|
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Return the rectangle corresponding to the page in the associated wxDC 's
|
2008-03-08 14:43:31 +00:00
|
|
|
logical coordinates for the current user scale and device origin.
|
2008-04-10 21:16:38 +00:00
|
|
|
|
|
|
|
On MSW and Mac, this will be the printable area of the paper.
|
|
|
|
On other platforms and PostScript printing, this will be the full paper
|
|
|
|
rectangle.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
wxRect GetLogicalPageRect();
|
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Return the rectangle corresponding to the paper in the associated wxDC 's
|
2008-03-08 13:52:38 +00:00
|
|
|
logical coordinates for the current user scale and device origin.
|
|
|
|
*/
|
|
|
|
wxRect GetLogicalPaperRect();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the number of pixels per logical inch of the printer device context.
|
2008-04-10 21:16:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Dividing the printer PPI by the screen PPI can give a suitable scaling factor
|
2008-04-10 21:16:38 +00:00
|
|
|
for drawing text onto the printer.
|
|
|
|
|
|
|
|
Remember to multiply this by a scaling factor to take the preview DC size into
|
|
|
|
account.
|
|
|
|
Or you can just use the FitThisSizeToXXX() and MapScreenSizeToXXX routines below,
|
|
|
|
which do most of the scaling calculations for you.
|
|
|
|
|
|
|
|
@beginWxPythonOnly
|
|
|
|
This method returns the output-only parameters as a tuple.
|
|
|
|
@endWxPythonOnly
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
void GetPPIPrinter(int* w, int* h);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the number of pixels per logical inch of the screen device context.
|
2008-04-10 21:16:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Dividing the printer PPI by the screen PPI can give a suitable scaling factor
|
2008-04-10 21:16:38 +00:00
|
|
|
for drawing text onto the printer.
|
|
|
|
|
|
|
|
If you are doing your own scaling, remember to multiply this by a scaling
|
|
|
|
factor to take the preview DC size into account.
|
|
|
|
|
|
|
|
@beginWxPythonOnly
|
|
|
|
This method returns the output-only parameters as a tuple.
|
|
|
|
@endWxPythonOnly
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
void GetPPIScreen(int* w, int* h);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Called by the framework to obtain information from the application about minimum
|
|
|
|
and maximum page values that the user can select, and the required page range to
|
2008-04-10 21:16:38 +00:00
|
|
|
be printed.
|
|
|
|
|
|
|
|
By default this returns (1, 32000) for the page minimum and maximum values, and
|
|
|
|
(1, 1) for the required page range.
|
|
|
|
|
2008-05-29 23:36:26 +00:00
|
|
|
@a minPage must be greater than zero and @a maxPage must be greater
|
|
|
|
than @a minPage.
|
2008-04-10 21:16:38 +00:00
|
|
|
|
|
|
|
@beginWxPythonOnly
|
|
|
|
When this method is implemented in a derived Python class, it should be designed
|
|
|
|
to take no parameters (other than the self reference) and to return a tuple of
|
|
|
|
four integers.
|
|
|
|
@endWxPythonOnly
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
void GetPageInfo(int* minPage, int* maxPage, int* pageFrom,
|
|
|
|
int* pageTo);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the size of the printer page in millimetres.
|
2008-04-10 21:16:38 +00:00
|
|
|
|
|
|
|
@beginWxPythonOnly
|
|
|
|
This method returns the output-only parameters as a tuple.
|
|
|
|
@endWxPythonOnly
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
void GetPageSizeMM(int* w, int* h);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the size of the printer page in pixels, called the page rectangle.
|
2008-04-10 21:16:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
The page rectangle has a top left corner at (0,0) and a bottom right corner at
|
|
|
|
(w,h). These values may not be the same as the values returned from
|
2008-04-10 21:16:38 +00:00
|
|
|
wxDC::GetSize(); if the printout is being used for
|
2008-03-08 13:52:38 +00:00
|
|
|
previewing, a memory device context is used, which uses a bitmap size reflecting
|
|
|
|
the current preview zoom. The application must take this discrepancy into
|
|
|
|
account if previewing is to be supported.
|
2008-04-10 21:16:38 +00:00
|
|
|
|
|
|
|
@beginWxPythonOnly
|
|
|
|
This method returns the output-only parameters as a tuple.
|
|
|
|
@endWxPythonOnly
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
void GetPageSizePixels(int* w, int* h);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the rectangle that corresponds to the entire paper in pixels, called the
|
2008-04-10 21:16:38 +00:00
|
|
|
paper rectangle.
|
|
|
|
|
|
|
|
This distinction between paper rectangle and page rectangle reflects the fact that
|
|
|
|
most printers cannot print all the way to the edge of the paper.
|
|
|
|
The page rectangle is a rectangle whose top left corner is at (0,0) and whose width
|
|
|
|
and height are given by wxDC::GetPageSizePixels().
|
|
|
|
|
|
|
|
On MSW and Mac, the page rectangle gives the printable area of the paper, while the
|
|
|
|
paper rectangle represents the entire paper, including non-printable borders.
|
|
|
|
Thus, the rectangle returned by wxDC::GetPaperRectPixels() will have a top left corner
|
|
|
|
whose coordinates are small negative numbers and the bottom right corner will have
|
|
|
|
values somewhat larger than the width and height given by wxDC::GetPageSizePixels().
|
|
|
|
|
|
|
|
On other platforms and for PostScript printing, the paper is treated as if its entire
|
2008-03-08 13:52:38 +00:00
|
|
|
area were printable, so this function will return the same rectangle as the page
|
|
|
|
rectangle.
|
|
|
|
*/
|
|
|
|
wxRect GetPaperRectPixels();
|
|
|
|
|
|
|
|
/**
|
2008-04-10 22:04:29 +00:00
|
|
|
Returns the title of the printout.
|
|
|
|
|
|
|
|
@todo the python note here was wrong
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
wxString GetTitle();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Should be overridden to return @true if the document has this page, or @false
|
2008-04-10 21:16:38 +00:00
|
|
|
if not.
|
|
|
|
|
|
|
|
Returning @false signifies the end of the document. By default,
|
2008-03-08 13:52:38 +00:00
|
|
|
HasPage behaves as if the document has only one page.
|
|
|
|
*/
|
|
|
|
bool HasPage(int pageNum);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if the printout is currently being used for previewing.
|
|
|
|
*/
|
|
|
|
bool IsPreview();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the user scale and device origin of the wxDC associated with this wxPrintout
|
2008-04-10 21:16:38 +00:00
|
|
|
so that one screen pixel maps to one device pixel on the DC.
|
|
|
|
That is, the user scale is set to (1,1) and the device origin is set to (0,0).
|
|
|
|
|
|
|
|
Use this if you want to do your own scaling prior to calling wxDC drawing calls,
|
|
|
|
for example, if your underlying model is floating-point and you want to achieve
|
|
|
|
maximum drawing precision on high-resolution printers.
|
|
|
|
|
|
|
|
You can use the GetLogicalXXXRect() routines below to obtain the paper rectangle,
|
|
|
|
page rectangle, or page margins rectangle to perform your own scaling.
|
|
|
|
|
|
|
|
@note
|
|
|
|
While the underlying drawing model of Mac OS X is floating-point,
|
|
|
|
wxWidgets's drawing model scales from integer coordinates.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void MapScreenSizeToDevice();
|
|
|
|
|
|
|
|
/**
|
|
|
|
This sets the user scale of the wxDC assocated with this wxPrintout to the same
|
2008-04-10 21:16:38 +00:00
|
|
|
scale as MapScreenSizeToPaper() but sets the logical origin to the top left corner
|
|
|
|
of the page rectangle.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void MapScreenSizeToPage();
|
|
|
|
|
|
|
|
/**
|
|
|
|
This sets the user scale of the wxDC assocated with this wxPrintout to the same
|
2008-04-10 21:16:38 +00:00
|
|
|
scale as MapScreenSizeToPageMargins() but sets the logical origin to the top left
|
|
|
|
corner of the page margins specified by the given wxPageSetupDialogData object.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void MapScreenSizeToPageMargins(const wxPageSetupDialogData& pageSetupData);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the user scale and device origin of the wxDC associated with this wxPrintout
|
|
|
|
so that the printed page matches the screen size as closely as possible
|
|
|
|
and the logical origin is in the top left corner of the paper rectangle.
|
2008-04-10 22:04:29 +00:00
|
|
|
|
|
|
|
That is, a 100-pixel object on screen should appear at the same size on the
|
|
|
|
printed page.
|
2008-04-10 21:16:38 +00:00
|
|
|
(It will, of course, be larger or smaller in the preview image, depending on the
|
|
|
|
zoom factor.)
|
|
|
|
|
|
|
|
Use this if you want WYSIWYG behavior, e.g., in a text editor.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void MapScreenSizeToPaper();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Shift the device origin by an amount specified in logical coordinates.
|
|
|
|
*/
|
|
|
|
void OffsetLogicalOrigin(wxCoord xoff, wxCoord yoff);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Called by the framework at the start of document printing. Return @false from
|
2008-04-10 21:16:38 +00:00
|
|
|
this function cancels the print job.
|
|
|
|
|
|
|
|
OnBeginDocument() is called once for every copy printed.
|
|
|
|
|
|
|
|
@remarks
|
|
|
|
The base OnBeginDocument() must be called (and the return value
|
|
|
|
checked) from within the overridden function, since it calls wxDC::StartDoc().
|
|
|
|
|
|
|
|
@beginWxPythonOnly
|
|
|
|
If this method is overridden in a Python class then the base class version can
|
|
|
|
be called by using the method <tt>base_OnBeginDocument(startPage, endPage)</tt>.
|
|
|
|
@endWxPythonOnly
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
bool OnBeginDocument(int startPage, int endPage);
|
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Called by the framework at the start of printing.
|
|
|
|
|
|
|
|
OnBeginPrinting() is called once for every print job
|
|
|
|
(regardless of how many copies are being printed).
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void OnBeginPrinting();
|
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Called by the framework at the end of document printing.
|
|
|
|
|
|
|
|
OnEndDocument() is called once for every copy printed.
|
|
|
|
|
|
|
|
@remarks
|
|
|
|
The base OnEndDocument() must be called from within the overridden function,
|
|
|
|
since it calls wxDC::EndDoc().
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void OnEndDocument();
|
|
|
|
|
|
|
|
/**
|
2008-04-10 21:16:38 +00:00
|
|
|
Called by the framework at the end of printing.
|
|
|
|
|
|
|
|
OnEndPrinting is called once for every print job
|
|
|
|
(regardless of how many copies are being printed).
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void OnEndPrinting();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Called once by the framework before any other demands are made of the
|
2008-04-10 21:16:38 +00:00
|
|
|
wxPrintout object.
|
|
|
|
|
|
|
|
This gives the object an opportunity to calculate the number of pages
|
|
|
|
in the document, for example.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void OnPreparePrinting();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Called by the framework when a page should be printed. Returning @false cancels
|
2008-04-10 21:16:38 +00:00
|
|
|
the print job.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
bool OnPrintPage(int pageNum);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the device origin of the associated wxDC so that the current logical point
|
|
|
|
becomes the new logical origin.
|
|
|
|
*/
|
|
|
|
void SetLogicalOrigin(wxCoord x, wxCoord y);
|
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|