Blame gtk/gtkprintoperationpreview.c

Packit 98cdb6
/* GTK - The GIMP Toolkit
Packit 98cdb6
 * gtkprintoperationpreview.c: Abstract print preview interface
Packit 98cdb6
 * Copyright (C) 2006, Red Hat, Inc.
Packit 98cdb6
 *
Packit 98cdb6
 * This library is free software; you can redistribute it and/or
Packit 98cdb6
 * modify it under the terms of the GNU Lesser General Public
Packit 98cdb6
 * License as published by the Free Software Foundation; either
Packit 98cdb6
 * version 2 of the License, or (at your option) any later version.
Packit 98cdb6
 *
Packit 98cdb6
 * This library is distributed in the hope that it will be useful,
Packit 98cdb6
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 98cdb6
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 98cdb6
 * Lesser General Public License for more details.
Packit 98cdb6
 *
Packit 98cdb6
 * You should have received a copy of the GNU Lesser General Public
Packit 98cdb6
 * License along with this library; if not, write to the
Packit 98cdb6
 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Packit 98cdb6
 * Boston, MA 02111-1307, USA.
Packit 98cdb6
 */
Packit 98cdb6
Packit 98cdb6
#include "config.h"
Packit 98cdb6
Packit 98cdb6
#include "gtkprintoperationpreview.h"
Packit 98cdb6
#include "gtkmarshalers.h"
Packit 98cdb6
#include "gtkintl.h"
Packit 98cdb6
#include "gtkalias.h"
Packit 98cdb6
Packit 98cdb6
Packit 98cdb6
static void gtk_print_operation_preview_base_init (gpointer g_iface);
Packit 98cdb6
Packit 98cdb6
GType
Packit 98cdb6
gtk_print_operation_preview_get_type (void)
Packit 98cdb6
{
Packit 98cdb6
  static GType print_operation_preview_type = 0;
Packit 98cdb6
Packit 98cdb6
  if (!print_operation_preview_type)
Packit 98cdb6
    {
Packit 98cdb6
      const GTypeInfo print_operation_preview_info =
Packit 98cdb6
      {
Packit 98cdb6
        sizeof (GtkPrintOperationPreviewIface), /* class_size */
Packit 98cdb6
	gtk_print_operation_preview_base_init,   /* base_init */
Packit 98cdb6
	NULL,		/* base_finalize */
Packit 98cdb6
	NULL,
Packit 98cdb6
	NULL,		/* class_finalize */
Packit 98cdb6
	NULL,		/* class_data */
Packit 98cdb6
	0,
Packit 98cdb6
	0,              /* n_preallocs */
Packit 98cdb6
	NULL
Packit 98cdb6
      };
Packit 98cdb6
Packit 98cdb6
      print_operation_preview_type =
Packit 98cdb6
	g_type_register_static (G_TYPE_INTERFACE, I_("GtkPrintOperationPreview"),
Packit 98cdb6
				&print_operation_preview_info, 0);
Packit 98cdb6
Packit 98cdb6
      g_type_interface_add_prerequisite (print_operation_preview_type, G_TYPE_OBJECT);
Packit 98cdb6
    }
Packit 98cdb6
Packit 98cdb6
  return print_operation_preview_type;
Packit 98cdb6
}
Packit 98cdb6
Packit 98cdb6
static void
Packit 98cdb6
gtk_print_operation_preview_base_init (gpointer g_iface)
Packit 98cdb6
{
Packit 98cdb6
  static gboolean initialized = FALSE;
Packit 98cdb6
Packit 98cdb6
  if (!initialized)
Packit 98cdb6
    {
Packit 98cdb6
      /**
Packit 98cdb6
       * GtkPrintOperationPreview::ready:
Packit 98cdb6
       * @preview: the object on which the signal is emitted
Packit 98cdb6
       * @context: the current #GtkPrintContext
Packit 98cdb6
       *
Packit 98cdb6
       * The ::ready signal gets emitted once per preview operation,
Packit 98cdb6
       * before the first page is rendered.
Packit 98cdb6
       * 
Packit 98cdb6
       * A handler for this signal can be used for setup tasks.
Packit 98cdb6
       */
Packit 98cdb6
      g_signal_new (I_("ready"),
Packit 98cdb6
		    GTK_TYPE_PRINT_OPERATION_PREVIEW,
Packit 98cdb6
		    G_SIGNAL_RUN_LAST,
Packit 98cdb6
		    G_STRUCT_OFFSET (GtkPrintOperationPreviewIface, ready),
Packit 98cdb6
		    NULL, NULL,
Packit 98cdb6
		    g_cclosure_marshal_VOID__OBJECT,
Packit 98cdb6
		    G_TYPE_NONE, 1,
Packit 98cdb6
		    GTK_TYPE_PRINT_CONTEXT);
Packit 98cdb6
Packit 98cdb6
      /**
Packit 98cdb6
       * GtkPrintOperationPreview::got-page-size:
Packit 98cdb6
       * @preview: the object on which the signal is emitted
Packit 98cdb6
       * @context: the current #GtkPrintContext
Packit 98cdb6
       * @page_setup: the #GtkPageSetup for the current page
Packit 98cdb6
       *
Packit 98cdb6
       * The ::got-page-size signal is emitted once for each page
Packit 98cdb6
       * that gets rendered to the preview. 
Packit 98cdb6
       *
Packit 98cdb6
       * A handler for this signal should update the @context
Packit 98cdb6
       * according to @page_setup and set up a suitable cairo
Packit 98cdb6
       * context, using gtk_print_context_set_cairo_context().
Packit 98cdb6
       */
Packit 98cdb6
      g_signal_new (I_("got-page-size"),
Packit 98cdb6
		    GTK_TYPE_PRINT_OPERATION_PREVIEW,
Packit 98cdb6
		    G_SIGNAL_RUN_LAST,
Packit 98cdb6
		    G_STRUCT_OFFSET (GtkPrintOperationPreviewIface, got_page_size),
Packit 98cdb6
		    NULL, NULL,
Packit 98cdb6
		    _gtk_marshal_VOID__OBJECT_OBJECT,
Packit 98cdb6
		    G_TYPE_NONE, 2,
Packit 98cdb6
		    GTK_TYPE_PRINT_CONTEXT,
Packit 98cdb6
		    GTK_TYPE_PAGE_SETUP);
Packit 98cdb6
Packit 98cdb6
      initialized = TRUE;
Packit 98cdb6
    }
Packit 98cdb6
}
Packit 98cdb6
Packit 98cdb6
/**
Packit 98cdb6
 * gtk_print_operation_preview_render_page:
Packit 98cdb6
 * @preview: a #GtkPrintOperationPreview
Packit 98cdb6
 * @page_nr: the page to render
Packit 98cdb6
 *
Packit 98cdb6
 * Renders a page to the preview, using the print context that
Packit 98cdb6
 * was passed to the #GtkPrintOperation::preview handler together
Packit 98cdb6
 * with @preview.
Packit 98cdb6
 *
Packit 98cdb6
 * A custom iprint preview should use this function in its ::expose
Packit 98cdb6
 * handler to render the currently selected page.
Packit 98cdb6
 * 
Packit 98cdb6
 * Note that this function requires a suitable cairo context to 
Packit 98cdb6
 * be associated with the print context. 
Packit 98cdb6
 *
Packit 98cdb6
 * Since: 2.10 
Packit 98cdb6
 */
Packit 98cdb6
void    
Packit 98cdb6
gtk_print_operation_preview_render_page (GtkPrintOperationPreview *preview,
Packit 98cdb6
					 gint			   page_nr)
Packit 98cdb6
{
Packit 98cdb6
  g_return_if_fail (GTK_IS_PRINT_OPERATION_PREVIEW (preview));
Packit 98cdb6
Packit 98cdb6
  GTK_PRINT_OPERATION_PREVIEW_GET_IFACE (preview)->render_page (preview,
Packit 98cdb6
								page_nr);
Packit 98cdb6
}
Packit 98cdb6
Packit 98cdb6
/**
Packit 98cdb6
 * gtk_print_operation_preview_end_preview:
Packit 98cdb6
 * @preview: a #GtkPrintOperationPreview
Packit 98cdb6
 *
Packit 98cdb6
 * Ends a preview. 
Packit 98cdb6
 *
Packit 98cdb6
 * This function must be called to finish a custom print preview.
Packit 98cdb6
 *
Packit 98cdb6
 * Since: 2.10
Packit 98cdb6
 */
Packit 98cdb6
void
Packit 98cdb6
gtk_print_operation_preview_end_preview (GtkPrintOperationPreview *preview)
Packit 98cdb6
{
Packit 98cdb6
  g_return_if_fail (GTK_IS_PRINT_OPERATION_PREVIEW (preview));
Packit 98cdb6
Packit 98cdb6
  GTK_PRINT_OPERATION_PREVIEW_GET_IFACE (preview)->end_preview (preview);
Packit 98cdb6
}
Packit 98cdb6
Packit 98cdb6
/**
Packit 98cdb6
 * gtk_print_operation_preview_is_selected:
Packit 98cdb6
 * @preview: a #GtkPrintOperationPreview
Packit 98cdb6
 * @page_nr: a page number
Packit 98cdb6
 *
Packit 98cdb6
 * Returns whether the given page is included in the set of pages that
Packit 98cdb6
 * have been selected for printing.
Packit 98cdb6
 * 
Packit 98cdb6
 * Returns: %TRUE if the page has been selected for printing
Packit 98cdb6
 *
Packit 98cdb6
 * Since: 2.10
Packit 98cdb6
 */
Packit 98cdb6
gboolean
Packit 98cdb6
gtk_print_operation_preview_is_selected (GtkPrintOperationPreview *preview,
Packit 98cdb6
					 gint                      page_nr)
Packit 98cdb6
{
Packit 98cdb6
  g_return_val_if_fail (GTK_IS_PRINT_OPERATION_PREVIEW (preview), FALSE);
Packit 98cdb6
Packit 98cdb6
  return GTK_PRINT_OPERATION_PREVIEW_GET_IFACE (preview)->is_selected (preview, page_nr);
Packit 98cdb6
}
Packit 98cdb6
Packit 98cdb6
Packit 98cdb6
#define __GTK_PRINT_OPERATION_PREVIEW_C__
Packit 98cdb6
#include "gtkaliasdef.c"