| Portability | portable (depends on GHC) | 
|---|---|
| Stability | provisional | 
| Maintainer | gtk2hs-users@lists.sourceforge.net | 
| Safe Haskell | None | 
Graphics.UI.Gtk.Printing.PrintOperation
Description
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
class GObjectClass o => PrintOperationClass o Source
Instances
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.
Constructors
| PrintStatusInitial | |
| PrintStatusPreparing | |
| PrintStatusGeneratingData | |
| PrintStatusSendingData | |
| PrintStatusPending | |
| PrintStatusPendingIssue | |
| PrintStatusPrinting | |
| PrintStatusFinished | |
| PrintStatusFinishedAborted | 
Instances
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.
Instances
Constructors
printOperationNew :: IO PrintOperationSource
Creates a new PrintOperation.
Methods
printOperationSetAllowAsyncSource
Arguments
| :: 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
Arguments
| :: 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
Arguments
| :: (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
Arguments
| :: PrintOperationClass self | |
| => self | |
| -> IO PrintStatus | returns the status of the print operation | 
Returns the status of the print operation. Also see
 printOperationGetStatusString.
printOperationGetStatusStringSource
Arguments
| :: 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
Arguments
| :: 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.
Arguments
| :: (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
Arguments
| :: (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
Arguments
| :: 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
Arguments
| :: 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.