Portability | portable (depends on GHC) |
---|---|
Stability | provisional |
Maintainer | gtk2hs-users@lists.sourceforge.net |
Safe Haskell | Safe-Infered |
High-level Printing API
- Module available since Gtk+ version 2.10
- data PrintOperation
- class GObjectClass o => PrintOperationClass o
- castToPrintOperation :: GObjectClass obj => obj -> PrintOperation
- toPrintOperation :: PrintOperationClass o => o -> PrintOperation
- data PrintOperationPreview
- class GObjectClass o => PrintOperationPreviewClass o
- castToPrintOperationPreview :: GObjectClass obj => obj -> PrintOperationPreview
- toPrintOperationPreview :: PrintOperationPreviewClass o => o -> PrintOperationPreview
- data PrintStatus
- data PrintOperationAction
- data PrintOperationResult
- data PrintError
- printOperationNew :: IO PrintOperation
- printOperationSetAllowAsync :: PrintOperationClass self => self -> Bool -> IO ()
- printOperationGetError :: PrintOperationClass self => self -> IO ()
- printOperationGetNPagesToPrint :: PrintOperationClass self => self -> IO Int
- printOperationRun :: (PrintOperationClass self, WindowClass parent) => self -> PrintOperationAction -> parent -> IO PrintOperationResult
- printOperationCancel :: PrintOperationClass self => self -> IO ()
- printOperationDrawPageFinish :: PrintOperationClass self => self -> IO ()
- printOperationSetDeferDrawing :: PrintOperationClass self => self -> IO ()
- printOperationGetStatus :: PrintOperationClass self => self -> IO PrintStatus
- printOperationGetStatusString :: PrintOperationClass self => self -> IO String
- printOperationIsFinished :: PrintOperationClass self => self -> IO Bool
- printRunPageSetupDialog :: (WindowClass window, PageSetupClass pageSetup, PrintSettingsClass setting) => window -> pageSetup -> setting -> IO PageSetup
- printRunPageSetupDialogAsync :: (WindowClass window, PageSetupClass pageSetup, PrintSettingsClass setting) => window -> pageSetup -> setting -> (PageSetup -> IO ()) -> IO ()
- printOperationPreviewEndPreview :: PrintOperationPreviewClass self => self -> IO ()
- printOperationPreviewIsSelected :: PrintOperationPreviewClass self => self -> Int -> IO Bool
- printOperationPreviewRenderPage :: PrintOperationPreviewClass self => self -> Int -> IO ()
- printOperationDefaultPageSetup :: (PrintOperationClass self, PageSetupClass pageSetup) => ReadWriteAttr self PageSetup pageSetup
- printOperationPrintSettings :: (PrintOperationClass self, PrintSettingsClass printSettings) => ReadWriteAttr self PrintSettings printSettings
- printOperationJobName :: PrintOperationClass self => Attr self String
- printOperationNPages :: PrintOperationClass self => Attr self Int
- printOperationCurrentPage :: PrintOperationClass self => Attr self Int
- printOperationUseFullPage :: PrintOperationClass self => Attr self Bool
- printOperationTrackPrintStatus :: PrintOperationClass self => Attr self Bool
- printOperationUnit :: PrintOperationClass self => Attr self Unit
- printOperationShowProgress :: PrintOperationClass self => Attr self Bool
- printOperationAllowAsync :: PrintOperationClass self => Attr self Bool
- printOperationExportFilename :: PrintOperationClass self => Attr self String
- printOperationStatus :: PrintOperationClass self => ReadAttr self PrintStatus
- printOperationStatusString :: PrintOperationClass self => ReadAttr self String
- printOperationCustomTabLabel :: PrintOperationClass self => Attr self String
- printOperationSupportSelection :: PrintOperationClass self => Attr self Bool
- printOperationHasSelection :: PrintOperationClass self => Attr self Bool
- printOperationEmbedPageSetup :: PrintOperationClass self => Attr self Bool
- printOperationNPagesToPrint :: PrintOperationClass self => ReadAttr self Int
- printOptDone :: PrintOperationClass self => Signal self (PrintOperationResult -> IO ())
- printOptBeginPrint :: PrintOperationClass self => Signal self (PrintContext -> IO ())
- printOptPaginate :: PrintOperationClass self => Signal self (PrintContext -> IO Bool)
- printOptRequestPageSetup :: PrintOperationClass self => Signal self (PrintContext -> Int -> PageSetup -> IO ())
- printOptDrawPage :: PrintOperationClass self => Signal self (PrintContext -> Int -> IO ())
- printOptEndPrint :: PrintOperationClass self => Signal self (PrintContext -> IO ())
- printOptStatusChanged :: PrintOperationClass self => Signal self (IO ())
- printOptCreateCustomWidget :: PrintOperationClass self => Signal self (IO Widget)
- printOptUpdateCustomWidget :: PrintOperationClass self => Signal self (Widget -> PageSetup -> PrintSettings -> IO ())
- printOptCustomWidgetApply :: PrintOperationClass self => Signal self (Widget -> IO ())
- printOptPreview :: PrintOperationClass self => Signal self (PrintOperationPreview -> PrintContext -> Window -> IO Bool)
- printOptReady :: PrintOperationPreviewClass self => Signal self (PrintContext -> IO ())
- printOptGotPageSize :: PrintOperationPreviewClass self => Signal self (PrintContext -> PageSetup -> IO ())
Detail
PrintOperation
is the high-level, portable printing API. It looks a bit
different than other Gtk+ dialogs such as the FileChooser
, since some
platforms don't expose enough infrastructure to implement a good print
dialog. On such platforms, PrintOperation
uses the native print dialog. On
platforms which do not provide a native print dialog, Gtk+ uses its own, see
PrintUnixDialog
.
The typical way to use the high-level printing API is to create a
PrintOperation
object with printOperationNew
when the user selects to
print. Then you set some properties on it, e.g. the page size, any
PrintSettings
from previous print operations, the number of pages, the
current page, etc.
Then you start the print operation by calling printOperationRun
. It
will then show a dialog, let the user select a printer and options. When the
user finished the dialog various signals will be emitted on the
PrintOperation
, the main one being 'draw-page' signal, which you are supposed to
catch and render the page on the provided PrintContext
using Cairo.
By default PrintOperation
uses an external application to do print
preview. To implement a custom print preview, an application must connect to
the preview signal. The functions printOperationPrintPreviewRenderPage
,
printOperationPreviewEndPreview
and printOperationPreviewIsSelected
are
useful when implementing a print preview.
Printing support was added in Gtk+ 2.10.
Class Hierarchy
| GObject
| +----PrintOperation
Types
data PrintOperation Source
castToPrintOperation :: GObjectClass obj => obj -> PrintOperationSource
toPrintOperation :: PrintOperationClass o => o -> PrintOperationSource
class GObjectClass o => PrintOperationPreviewClass o Source
castToPrintOperationPreview :: GObjectClass obj => obj -> PrintOperationPreviewSource
Enums
data PrintStatus Source
The status gives a rough indication of the completion of a running print operation.
data PrintOperationAction Source
The action parameter to printOperationRun
determines what action the print operation should
perform.
data PrintOperationResult Source
A value of this type is returned by printOperationRun
.
data PrintError Source
Error codes that identify various errors that can occur while using the GTK+ printing support.
Constructors
printOperationNew :: IO PrintOperationSource
Creates a new PrintOperation
.
Methods
printOperationSetAllowAsyncSource
:: PrintOperationClass self | |
=> self | |
-> Bool |
|
-> IO () |
Sets whether the printOperationRun
may return before the print
operation is completed. Note that some platforms may not allow asynchronous
operation.
printOperationGetError :: PrintOperationClass self => self -> IO ()Source
Call this when the result of a print operation is
PrintOperationResultError
, either as returned by printOperationRun
, or
in the done
signal handler. The returned
GError
will contain more details on what went wrong.
printOperationGetNPagesToPrintSource
:: PrintOperationClass self | |
=> self | |
-> IO Int | returns the number of pages that will be printed |
Returns the number of pages that will be printed.
Note that this value is set during print preparation phase
(PrintStatusPreparing
), so this function should never be called before the
data generation phase (PrintStatusGeneratingData
). You can connect to the
statusChanged
signal and call
printOperationGetNPagesToPrint
when print status is
PrintStatusGeneratingData
. This is typically used to track the progress of
print operation.
- Available since Gtk+ version 2.18
:: (PrintOperationClass self, WindowClass parent) | |
=> self | |
-> PrintOperationAction |
|
-> parent |
|
-> IO PrintOperationResult | returns the result of the print operation. A
return value of |
Runs the print operation, by first letting the user modify print settings in the print dialog, and then print the document.
Normally that this function does not return until the rendering of all
pages is complete. You can connect to the statusChanged
signal on op
to obtain some information about the
progress of the print operation. Furthermore, it may use a recursive
mainloop to show the print dialog.
If you call printOperationSetAllowAsync
or set the allowAsync
property the operation will run asynchronously
if this is supported on the platform. The done
signal will be emitted with the result of the operation when
the it is done (i.e. when the dialog is canceled, or when the print succeeds
or fails).
printOperationCancel :: PrintOperationClass self => self -> IO ()Source
Cancels a running print operation. This function may be called from a
beginPrint
, paginate
or drawPage
signal handler
to stop the currently running print operation.
printOperationDrawPageFinish :: PrintOperationClass self => self -> IO ()Source
Signalize that drawing of particular page is complete.
It is called after completion of page drawing (e.g. drawing in another
thread). If printOperationSetDeferDrawing
was called before, then this
function has to be called by application. In another case it is called by
the library itself.
- Available since Gtk+ version 2.16
printOperationSetDeferDrawing :: PrintOperationClass self => self -> IO ()Source
Sets up the PrintOperation
to wait for calling of
printOperationDrawPageFinish
from application. It can be used for drawing
page in another thread.
This function must be called in the callback of "draw-page" signal.
- Available since Gtk+ version 2.16
:: PrintOperationClass self | |
=> self | |
-> IO PrintStatus | returns the status of the print operation |
Returns the status of the print operation. Also see
printOperationGetStatusString
.
printOperationGetStatusStringSource
:: PrintOperationClass self | |
=> self | |
-> IO String | returns a string representation of the status of the print operation |
Returns a string representation of the status of the print operation. The
string is translated and suitable for displaying the print status e.g. in a
Statusbar
.
Use printOperationGetStatus
to obtain a status value that is suitable
for programmatic use.
printOperationIsFinishedSource
:: PrintOperationClass self | |
=> self | |
-> IO Bool | returns |
A convenience function to find out if the print operation is finished,
either successfully (PrintStatusFinished
) or unsuccessfully
(PrintStatusFinishedAborted
).
Note: when you enable print status tracking the print operation can be in a non-finished state even after done has been called, as the operation status then tracks the print job status on the printer.
:: (WindowClass window, PageSetupClass pageSetup, PrintSettingsClass setting) | |
=> window |
|
-> pageSetup |
|
-> setting |
|
-> IO PageSetup | returns a new |
Runs a page setup dialog, letting the user modify the values from pageSetup
. If the user cancels
the dialog, the returned PageSetup
is identical to the passed in pageSetup
, otherwise it
contains the modifications done in the dialog.
Note that this function may use a recursive mainloop to show the page setup dialog. See
printRunPageSetupDialogAsync
if this is a problem.
printRunPageSetupDialogAsyncSource
:: (WindowClass window, PageSetupClass pageSetup, PrintSettingsClass setting) | |
=> window |
|
-> pageSetup |
|
-> setting |
|
-> (PageSetup -> IO ()) |
|
-> IO () |
Runs a page setup dialog, letting the user modify the values from pageSetup
.
In contrast to printRunPageSetupDialog
, this function returns after showing the page setup
dialog on platforms that support this, and calls doneCb
from a signal handler for the response
signal of the dialog.
printOperationPreviewEndPreview :: PrintOperationPreviewClass self => self -> IO ()Source
Ends a preview.
This function must be called to finish a custom print preview.
printOperationPreviewIsSelectedSource
:: PrintOperationPreviewClass self | |
=> self |
|
-> Int |
|
-> IO Bool | returns |
Returns whether the given page is included in the set of pages that have been selected for printing.
printOperationPreviewRenderPageSource
:: PrintOperationPreviewClass self | |
=> self |
|
-> Int |
|
-> IO () |
Renders a page to the preview, using the print context that was passed to the preview handler together with preview.
A custom iprint preview should use this function in its expose
handler to render the currently
selected page.
Note that this function requires a suitable cairo context to be associated with the print context.
Attributes
printOperationDefaultPageSetup :: (PrintOperationClass self, PageSetupClass pageSetup) => ReadWriteAttr self PageSetup pageSetupSource
The PageSetup
used by default.
This page setup will be used by printOperationRun
, but it can be overridden on a per-page
basis by connecting to the requestPageSetup
signal.
Since 2.10
printOperationPrintSettings :: (PrintOperationClass self, PrintSettingsClass printSettings) => ReadWriteAttr self PrintSettings printSettingsSource
The PrintSettings
used for initializing the dialog.
Setting this property is typically used to re-establish print settings from a previous print
operation, see printOperationRun
.
Since 2.10
printOperationJobName :: PrintOperationClass self => Attr self StringSource
A string used to identify the job (e.g. in monitoring applications like eggcups).
If you don't set a job name, GTK+ picks a default one by numbering successive print jobs.
Default value: ""
Since 2.10
printOperationNPages :: PrintOperationClass self => Attr self IntSource
The number of pages in the document.
This must be set to a positive number before the rendering starts. It may be set in a beginPrint
signal hander.
Note that the page numbers passed to the requestPageSetup
and drawPage
signals are 0-based,
i.e. if the user chooses to print all pages, the last drawPage
signal will be for page nPages
-
1.
Allowed values: >= GMaxulong
Default value: -1
Since 2.10
printOperationCurrentPage :: PrintOperationClass self => Attr self IntSource
The current page in the document.
If this is set before printOperationRun
, the user will be able to select to print only the
current page.
Note that this only makes sense for pre-paginated documents.
Allowed values: >= GMaxulong
Default value: -1
Since 2.10
printOperationUseFullPage :: PrintOperationClass self => Attr self BoolSource
If True
, the transformation for the cairo context obtained from PrintContext
puts the origin at
the top left corner of the page (which may not be the top left corner of the sheet, depending on
page orientation and the number of pages per sheet). Otherwise, the origin is at the top left corner
of the imageable area (i.e. inside the margins).
Default value: False
Since 2.10
printOperationTrackPrintStatus :: PrintOperationClass self => Attr self BoolSource
If True
, the print operation will try to continue report on the status of the print job in the
printer queues and printer. This can allow your application to show things like out of paper
issues, and when the print job actually reaches the printer. However, this is often implemented
using polling, and should not be enabled unless needed.
Default value: False
Since 2.10
printOperationUnit :: PrintOperationClass self => Attr self UnitSource
The transformation for the cairo context obtained from PrintContext
is set up in such a way that
distances are measured in units of unit.
Default value: ''UnitPixel''
Since 2.10
printOperationShowProgress :: PrintOperationClass self => Attr self BoolSource
Determines whether to show a progress dialog during the print operation.
Default value: False
Since 2.10
printOperationAllowAsync :: PrintOperationClass self => Attr self BoolSource
Determines whether the print operation may run asynchronously or not.
Some systems don't support asynchronous printing, but those that do will return ''PrintOperationResultInProgress'' as the status, and emit the done signal when the operation is actually done.
The Windows port does not support asynchronous operation at all (this is unlikely to change). On other platforms, all actions except for ''PrintOperationActionExport'' support asynchronous operation.
Default value: False
Since 2.10
printOperationExportFilename :: PrintOperationClass self => Attr self StringSource
The name of a file to generate instead of showing the print dialog. Currently, PDF is the only supported format.
The intended use of this property is for implementing Export to PDF actions.
Print to PDF support is independent of this and is done by letting the user pick the Print to PDF item from the list of printers in the print dialog.
Default value: Nothing
Since 2.10
printOperationStatus :: PrintOperationClass self => ReadAttr self PrintStatusSource
The status of the print operation.
Default value: ''PrintStatusInitial''
Since 2.10
printOperationStatusString :: PrintOperationClass self => ReadAttr self StringSource
A string representation of the status of the print operation. The string is translated and suitable
for displaying the print status e.g. in a Statusbar
.
See the printOperationStatus
property for a status value that is suitable for programmatic use.
Default value: ""
Since 2.10
printOperationCustomTabLabel :: PrintOperationClass self => Attr self StringSource
printOperationSupportSelection :: PrintOperationClass self => Attr self BoolSource
printOperationHasSelection :: PrintOperationClass self => Attr self BoolSource
printOperationEmbedPageSetup :: PrintOperationClass self => Attr self BoolSource
printOperationNPagesToPrint :: PrintOperationClass self => ReadAttr self IntSource
The number of pages that will be printed.
Note that this value is set during print preparation phase (''PrintStatusPreparing''), so this
value should never be get before the data generation phase (''PrintStatusGeneratingData''). You
can connect to the statusChanged
signal and call printOperationGetNPagesToPrint
when
print status is ''PrintStatusGeneratingData''. This is typically used to track the progress of
print operation.
Allowed values: >= GMaxulong
Default value: -1
Since 2.18
Signals
printOptDone :: PrintOperationClass self => Signal self (PrintOperationResult -> IO ())Source
Emitted when the print operation run has finished doing everything required for printing.
result
gives you information about what happened during the run. If
result
is PrintOperationResultError
then you can call
printOperationGetError
for more information.
If you enabled print status tracking then printOperationIsFinished
may
still return False
after done
was
emitted.
printOptBeginPrint :: PrintOperationClass self => Signal self (PrintContext -> IO ())Source
Emitted after the user has finished changing print settings in the dialog, before the actual rendering starts.
A typical use for 'begin-print' is to use the parameters from the
PrintContext
and paginate the document accordingly, and then set the
number of pages with printOperationSetNPages
.
printOptPaginate :: PrintOperationClass self => Signal self (PrintContext -> IO Bool)Source
Emitted after the beginPrint
signal,
but before the actual rendering starts. It keeps getting emitted until a
connected signal handler returns True
.
The paginate
signal is intended to be used for paginating a document in
small chunks, to avoid blocking the user interface for a long time. The
signal handler should update the number of pages using
printOperationSetNPages
, and return True
if the document has been
completely paginated.
If you don't need to do pagination in chunks, you can simply do it all in the 'begin-print handler', and set the number of pages from there.
printOptRequestPageSetup :: PrintOperationClass self => Signal self (PrintContext -> Int -> PageSetup -> IO ())Source
Emitted once for every page that is printed, to give the application a
chance to modify the page setup. Any changes done to setup
will be in
force only for printing this page.
printOptDrawPage :: PrintOperationClass self => Signal self (PrintContext -> Int -> IO ())Source
Emitted for every page that is printed. The signal handler must render
the pageNr
's page onto the cairo context obtained from context
using
printContextGetCairoContext
.
Use printOperationSetUseFullPage
and printOperationSetUnit
before
starting the print operation to set up the transformation of the cairo
context according to your needs.
printOptEndPrint :: PrintOperationClass self => Signal self (PrintContext -> IO ())Source
Emitted after all pages have been rendered. A handler for this signal can
clean up any resources that have been allocated in the beginPrint
handler.
printOptStatusChanged :: PrintOperationClass self => Signal self (IO ())Source
Emitted at between the various phases of the print operation. See
PrintStatus
for the phases that are being discriminated. Use
printOperationGetStatus
to find out the current status.
printOptCreateCustomWidget :: PrintOperationClass self => Signal self (IO Widget)Source
Emitted when displaying the print dialog. If you return a widget in a handler for this signal it will be added to a custom tab in the print dialog. You typically return a container widget with multiple widgets in it.
The print dialog owns the returned widget, and its lifetime is not
controlled by the application. However, the widget is guaranteed to stay
around until the customWidgetApply
signal is emitted on the operation. Then you can read out any information
you need from the widgets.
printOptUpdateCustomWidget :: PrintOperationClass self => Signal self (Widget -> PageSetup -> PrintSettings -> IO ())Source
Emitted after change of selected printer. The actual page setup and print settings are passed to the custom widget, which can actualize itself according to this change.
- Available since Gtk+ version 2.18
printOptCustomWidgetApply :: PrintOperationClass self => Signal self (Widget -> IO ())Source
Emitted right before beginPrint
if you
added a custom widget in the createCustomWidtet
handler. When you get this signal you should read the
information from the custom widgets, as the widgets are not guaraneed to be
around at a later time.
printOptPreview :: PrintOperationClass self => Signal self (PrintOperationPreview -> PrintContext -> Window -> IO Bool)Source
Gets emitted when a preview is requested from the native dialog.
The default handler for this signal uses an external viewer application to preview.
To implement a custom print preview, an application must return True
from its handler for this signal. In order to use the provided context
for
the preview implementation, it must be given a suitable cairo context with
printContextSetCairoContext
.
The custom preview implementation can use
printOperationPreviewIsSelected
and printOperationPreviewRenderPage
to
find pages which are selected for print and render them. The preview must be
finished by calling printOperationPreviewEndPreview
(typically in response
to the user clicking a close button).
printOptReady :: PrintOperationPreviewClass self => Signal self (PrintContext -> IO ())Source
The ready
signal gets emitted once per preview operation, before the first page is rendered.
A handler for this signal can be used for setup tasks.
printOptGotPageSize :: PrintOperationPreviewClass self => Signal self (PrintContext -> PageSetup -> IO ())Source
The gotPageSize
signal is emitted once for each page that gets rendered to the preview.
A handler for this signal should update the context according to pageSetup
and set up a suitable
cairo context, using printContextSetCairoContext
.