1 /* GTK - The GIMP Toolkit
2 * gtkprintoperationpreview.c: Abstract print preview interface
3 * Copyright (C) 2006, Red Hat, Inc.
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with this library; if not, write to the
17 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 * Boston, MA 02111-1307, USA.
23 #include "gtkprintoperationpreview.h"
24 #include "gtkmarshalers.h"
28 static void gtk_print_operation_preview_base_init (gpointer g_iface);
31 gtk_print_operation_preview_get_type (void)
33 static GType print_operation_preview_type = 0;
35 if (!print_operation_preview_type)
37 const GTypeInfo print_operation_preview_info =
39 sizeof (GtkPrintOperationPreviewIface), /* class_size */
40 gtk_print_operation_preview_base_init, /* base_init */
41 NULL, /* base_finalize */
43 NULL, /* class_finalize */
44 NULL, /* class_data */
50 print_operation_preview_type =
51 g_type_register_static (G_TYPE_INTERFACE, I_("GtkPrintOperationPreview"),
52 &print_operation_preview_info, 0);
54 g_type_interface_add_prerequisite (print_operation_preview_type, G_TYPE_OBJECT);
57 return print_operation_preview_type;
61 gtk_print_operation_preview_base_init (gpointer g_iface)
63 static gboolean initialized = FALSE;
68 * GtkPrintOperationPreview::ready:
69 * @preview: the object on which the signal is emitted
70 * @context: the current #GtkPrintContext
72 * The ::ready signal gets emitted once per preview operation,
73 * before the first page is rendered.
75 * A handler for this signal can be used for setup tasks.
77 g_signal_new (I_("ready"),
78 GTK_TYPE_PRINT_OPERATION_PREVIEW,
80 G_STRUCT_OFFSET (GtkPrintOperationPreviewIface, ready),
82 g_cclosure_marshal_VOID__OBJECT,
84 GTK_TYPE_PRINT_CONTEXT);
87 * GtkPrintOperationPreview::got-page-size:
88 * @preview: the object on which the signal is emitted
89 * @context: the current #GtkPrintContext
90 * @page_setup: the #GtkPageSetup for the current page
92 * The ::got-page-size signal is emitted once for each page
93 * that gets rendered to the preview.
95 * A handler for this signal should update the @context
96 * according to @page_setup and set up a suitable cairo
97 * context, using gtk_print_context_set_cairo_context().
99 g_signal_new (I_("got-page-size"),
100 GTK_TYPE_PRINT_OPERATION_PREVIEW,
102 G_STRUCT_OFFSET (GtkPrintOperationPreviewIface, got_page_size),
104 _gtk_marshal_VOID__OBJECT_OBJECT,
106 GTK_TYPE_PRINT_CONTEXT,
107 GTK_TYPE_PAGE_SETUP);
114 * gtk_print_operation_preview_render_page:
115 * @preview: a #GtkPrintOperationPreview
116 * @page_nr: the page to render
118 * Renders a page to the preview, using the print context that
119 * was passed to the #GtkPrintOperation::preview handler together
122 * A custom iprint preview should use this function in its ::expose
123 * handler to render the currently selected page.
125 * Note that this function requires a suitable cairo context to
126 * be associated with the print context.
131 gtk_print_operation_preview_render_page (GtkPrintOperationPreview *preview,
134 g_return_if_fail (GTK_IS_PRINT_OPERATION_PREVIEW (preview));
136 GTK_PRINT_OPERATION_PREVIEW_GET_IFACE (preview)->render_page (preview,
141 * gtk_print_operation_preview_end_preview:
142 * @preview: a #GtkPrintOperationPreview
146 * This function must be called to finish a custom print preview.
151 gtk_print_operation_preview_end_preview (GtkPrintOperationPreview *preview)
153 g_return_if_fail (GTK_IS_PRINT_OPERATION_PREVIEW (preview));
155 GTK_PRINT_OPERATION_PREVIEW_GET_IFACE (preview)->end_preview (preview);
159 * gtk_print_operation_preview_is_selected:
160 * @preview: a #GtkPrintOperationPreview
161 * @page_nr: a page number
163 * Returns whether the given page is included in the set of pages that
164 * have been selected for printing.
166 * Returns: %TRUE if the page has been selected for printing
171 gtk_print_operation_preview_is_selected (GtkPrintOperationPreview *preview,
174 g_return_val_if_fail (GTK_IS_PRINT_OPERATION_PREVIEW (preview), FALSE);
176 return GTK_PRINT_OPERATION_PREVIEW_GET_IFACE (preview)->is_selected (preview, page_nr);