Paul Davis
449aab3c46
git-svn-id: svn://localhost/ardour2/branches/3.0@3435 d708f5d6-7413-0410-9779-e7cbd77b26cf
967 lines
33 KiB
C++
967 lines
33 KiB
C++
// -*- c++ -*-
|
|
// Generated by gtkmmproc -- DO NOT MODIFY!
|
|
#ifndef _GTKMM_PRINTOPERATION_H
|
|
#define _GTKMM_PRINTOPERATION_H
|
|
|
|
|
|
#include <glibmm.h>
|
|
|
|
/* Copyright (C) 2006 The gtkmm Development Team
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Library General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Library General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Library General Public
|
|
* License along with this library; if not, write to the Free
|
|
* Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
*/
|
|
|
|
#include <glibmm/object.h>
|
|
|
|
#include <gtkmm/pagesetup.h>
|
|
#include <gtkmm/printcontext.h>
|
|
#include <gtkmm/printoperationpreview.h>
|
|
#include <gtkmm/printsettings.h>
|
|
#include <gtkmm/window.h>
|
|
|
|
|
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
|
typedef struct _GtkPrintOperation GtkPrintOperation;
|
|
typedef struct _GtkPrintOperationClass GtkPrintOperationClass;
|
|
#endif /* DOXYGEN_SHOULD_SKIP_THIS */
|
|
|
|
|
|
namespace Gtk
|
|
{ class PrintOperation_Class; } // namespace Gtk
|
|
namespace Gtk
|
|
{
|
|
|
|
/** @addtogroup gtkmmEnums Enums and Flags */
|
|
|
|
/**
|
|
* @ingroup gtkmmEnums
|
|
*/
|
|
enum PrintStatus
|
|
{
|
|
PRINT_STATUS_INITIAL,
|
|
PRINT_STATUS_PREPARING,
|
|
PRINT_STATUS_GENERATING_DATA,
|
|
PRINT_STATUS_SENDING_DATA,
|
|
PRINT_STATUS_PENDING,
|
|
PRINT_STATUS_PENDING_ISSUE,
|
|
PRINT_STATUS_PRINTING,
|
|
PRINT_STATUS_FINISHED,
|
|
PRINT_STATUS_FINISHED_ABORTED
|
|
};
|
|
|
|
} // namespace Gtk
|
|
|
|
|
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
|
namespace Glib
|
|
{
|
|
|
|
template <>
|
|
class Value<Gtk::PrintStatus> : public Glib::Value_Enum<Gtk::PrintStatus>
|
|
{
|
|
public:
|
|
static GType value_type() G_GNUC_CONST;
|
|
};
|
|
|
|
} // namespace Glib
|
|
#endif /* DOXYGEN_SHOULD_SKIP_THIS */
|
|
|
|
|
|
namespace Gtk
|
|
{
|
|
|
|
/**
|
|
* @ingroup gtkmmEnums
|
|
*/
|
|
enum PrintOperationResult
|
|
{
|
|
PRINT_OPERATION_RESULT_ERROR,
|
|
PRINT_OPERATION_RESULT_APPLY,
|
|
PRINT_OPERATION_RESULT_CANCEL,
|
|
PRINT_OPERATION_RESULT_IN_PROGRESS
|
|
};
|
|
|
|
} // namespace Gtk
|
|
|
|
|
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
|
namespace Glib
|
|
{
|
|
|
|
template <>
|
|
class Value<Gtk::PrintOperationResult> : public Glib::Value_Enum<Gtk::PrintOperationResult>
|
|
{
|
|
public:
|
|
static GType value_type() G_GNUC_CONST;
|
|
};
|
|
|
|
} // namespace Glib
|
|
#endif /* DOXYGEN_SHOULD_SKIP_THIS */
|
|
|
|
|
|
namespace Gtk
|
|
{
|
|
|
|
/**
|
|
* @ingroup gtkmmEnums
|
|
*/
|
|
enum PrintOperationAction
|
|
{
|
|
PRINT_OPERATION_ACTION_PRINT_DIALOG,
|
|
PRINT_OPERATION_ACTION_PRINT,
|
|
PRINT_OPERATION_ACTION_PREVIEW,
|
|
PRINT_OPERATION_ACTION_EXPORT
|
|
};
|
|
|
|
} // namespace Gtk
|
|
|
|
|
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
|
namespace Glib
|
|
{
|
|
|
|
template <>
|
|
class Value<Gtk::PrintOperationAction> : public Glib::Value_Enum<Gtk::PrintOperationAction>
|
|
{
|
|
public:
|
|
static GType value_type() G_GNUC_CONST;
|
|
};
|
|
|
|
} // namespace Glib
|
|
#endif /* DOXYGEN_SHOULD_SKIP_THIS */
|
|
|
|
|
|
namespace Gtk
|
|
{
|
|
|
|
class PrintError : public Glib::Error
|
|
{
|
|
public:
|
|
enum Code
|
|
{
|
|
GENERAL,
|
|
INTERNAL_ERROR,
|
|
NOMEM,
|
|
INVALID_FILE
|
|
};
|
|
|
|
PrintError(Code error_code, const Glib::ustring& error_message);
|
|
explicit PrintError(GError* gobject);
|
|
Code code() const;
|
|
|
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
|
private:
|
|
|
|
#ifdef GLIBMM_EXCEPTIONS_ENABLED
|
|
static void throw_func(GError* gobject);
|
|
#else
|
|
//When not using exceptions, we just pass the Exception object around without throwing it:
|
|
static std::auto_ptr<Glib::Error> throw_func(GError* gobject);
|
|
#endif //GLIBMM_EXCEPTIONS_ENABLED
|
|
|
|
friend void wrap_init(); // uses throw_func()
|
|
#endif
|
|
};
|
|
|
|
} // namespace Gtk
|
|
|
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
|
namespace Glib
|
|
{
|
|
|
|
template <>
|
|
class Value<Gtk::PrintError::Code> : public Glib::Value_Enum<Gtk::PrintError::Code>
|
|
{
|
|
public:
|
|
static GType value_type() G_GNUC_CONST;
|
|
};
|
|
|
|
} // namespace Glib
|
|
#endif /* DOXYGEN_SHOULD_SKIP_THIS */
|
|
|
|
|
|
namespace Gtk
|
|
{
|
|
|
|
|
|
/** @defgroup Printing Printing
|
|
*/
|
|
|
|
/** 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
|
|
* when the user chooses to print. Then you set some properties on it,such as 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 run(). It will then show a dialog to
|
|
* let the user select a printer and options. When the user finishes the dialog various signals will be
|
|
* emitted by the PrintOperation for you to handle, the main one being draw_page. You should then
|
|
* render the page on the provided PrintContext using Cairo.
|
|
*
|
|
* @newin2p10
|
|
*
|
|
* @ingroup Printing
|
|
*/
|
|
|
|
class PrintOperation :
|
|
public Glib::Object,
|
|
public PrintOperationPreview
|
|
{
|
|
|
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
|
|
|
public:
|
|
typedef PrintOperation CppObjectType;
|
|
typedef PrintOperation_Class CppClassType;
|
|
typedef GtkPrintOperation BaseObjectType;
|
|
typedef GtkPrintOperationClass BaseClassType;
|
|
|
|
private: friend class PrintOperation_Class;
|
|
static CppClassType printoperation_class_;
|
|
|
|
private:
|
|
// noncopyable
|
|
PrintOperation(const PrintOperation&);
|
|
PrintOperation& operator=(const PrintOperation&);
|
|
|
|
protected:
|
|
explicit PrintOperation(const Glib::ConstructParams& construct_params);
|
|
explicit PrintOperation(GtkPrintOperation* castitem);
|
|
|
|
#endif /* DOXYGEN_SHOULD_SKIP_THIS */
|
|
|
|
public:
|
|
virtual ~PrintOperation();
|
|
|
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
|
static GType get_type() G_GNUC_CONST;
|
|
static GType get_base_type() G_GNUC_CONST;
|
|
#endif
|
|
|
|
///Provides access to the underlying C GObject.
|
|
GtkPrintOperation* gobj() { return reinterpret_cast<GtkPrintOperation*>(gobject_); }
|
|
|
|
///Provides access to the underlying C GObject.
|
|
const GtkPrintOperation* gobj() const { return reinterpret_cast<GtkPrintOperation*>(gobject_); }
|
|
|
|
///Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs.
|
|
GtkPrintOperation* gobj_copy();
|
|
|
|
private:
|
|
|
|
|
|
protected:
|
|
PrintOperation();
|
|
|
|
public:
|
|
|
|
static Glib::RefPtr<PrintOperation> create();
|
|
|
|
|
|
/** Makes @a default_page_setup the default page setup for @a op .
|
|
*
|
|
* This page setup will be used by run(),
|
|
* but it can be overridden on a per-page basis by connecting
|
|
* to the Gtk::PrintOperation::request-page-setup signal.
|
|
*
|
|
* @newin2p10
|
|
* @param default_page_setup A Gtk::PageSetup, or <tt>0</tt>.
|
|
*/
|
|
void set_default_page_setup(const Glib::RefPtr<PageSetup>& default_page_setup);
|
|
|
|
/** Returns: the default page setup
|
|
* @return The default page setup
|
|
*
|
|
* @newin2p10.
|
|
*/
|
|
Glib::RefPtr<PageSetup> get_default_page_setup() const;
|
|
|
|
|
|
/** Sets the print settings for @a op . This is typically used to
|
|
* re-establish print settings from a previous print operation,
|
|
* see run().
|
|
*
|
|
* @newin2p10
|
|
* @param print_settings Gtk::PrintSettings, or <tt>0</tt>.
|
|
*/
|
|
void set_print_settings(const Glib::RefPtr<PrintSettings>& print_settings);
|
|
|
|
/** Return value: the current print settings of @a op .
|
|
* @return The current print settings of @a op .
|
|
*
|
|
* @newin2p10.
|
|
*/
|
|
Glib::RefPtr<PrintSettings> get_print_settings() const;
|
|
|
|
|
|
/** Sets the name of the print job. The name is 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.
|
|
*
|
|
* @newin2p10
|
|
* @param job_name A string that identifies the print job.
|
|
*/
|
|
void set_job_name(const Glib::ustring& job_name);
|
|
|
|
/** Sets the number of pages in the document.
|
|
*
|
|
* This <em>must</em> be set to a positive number
|
|
* before the rendering starts. It may be set in a
|
|
* Gtk::PrintOperation::begin-print signal hander.
|
|
*
|
|
* Note that the page numbers passed to the
|
|
* Gtk::PrintOperation::request-page-setup
|
|
* and Gtk::PrintOperation::draw-page signals are 0-based, i.e. if
|
|
* the user chooses to print all pages, the last ::draw-page signal
|
|
* will be for page @a n_pages - 1.
|
|
*
|
|
* @newin2p10
|
|
* @param n_pages The number of pages.
|
|
*/
|
|
void set_n_pages(int n_pages);
|
|
|
|
/** Sets the current page.
|
|
*
|
|
* If this is called before run(),
|
|
* the user will be able to select to print only the current page.
|
|
*
|
|
* Note that this only makes sense for pre-paginated documents.
|
|
*
|
|
* @newin2p10
|
|
* @param current_page The current page, 0-based.
|
|
*/
|
|
void set_current_page(int current_page);
|
|
|
|
/** If @a full_page is <tt>true</tt>, the transformation for the cairo context
|
|
* obtained from Gtk::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).
|
|
*
|
|
* @newin2p10
|
|
* @param full_page <tt>true</tt> to set up the Gtk::PrintContext for the full page.
|
|
*/
|
|
void set_use_full_page(bool use_full_page = true);
|
|
|
|
/** Sets up the transformation for the cairo context obtained from
|
|
* Gtk::PrintContext in such a way that distances are measured in
|
|
* units of @a unit .
|
|
*
|
|
* @newin2p10
|
|
* @param unit The unit to use.
|
|
*/
|
|
void set_unit(Unit unit);
|
|
|
|
/** Sets up the Gtk::PrintOperation to generate a file instead
|
|
* of showing the print dialog. The indended use of this function
|
|
* is for implementing "Export to PDF" actions. Currently, PDF
|
|
* is the only supported format.
|
|
*
|
|
* "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.
|
|
*
|
|
* @newin2p10
|
|
* @param filename The filename for the exported file.
|
|
*/
|
|
void set_export_filename(const std::string& filename);
|
|
|
|
/** If track_status is <tt>true</tt>, 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.
|
|
*
|
|
* This function is often implemented using some form of polling, so it should
|
|
* not be enabled unless needed.
|
|
*
|
|
* @newin2p10
|
|
* @param track_status <tt>true</tt> to track status after printing.
|
|
*/
|
|
void set_track_print_status(bool track_status = true);
|
|
|
|
/** If @a show_progress is <tt>true</tt>, the print operation will show a
|
|
* progress dialog during the print operation.
|
|
*
|
|
* @newin2p10
|
|
* @param show_progress <tt>true</tt> to show a progress dialog.
|
|
*/
|
|
void set_show_progress (bool show_progress = true);
|
|
|
|
/** Sets whether the run() may return
|
|
* before the print operation is completed. Note that
|
|
* some platforms may not allow asynchronous operation.
|
|
*
|
|
* @newin2p10
|
|
* @param allow_async <tt>true</tt> to allow asynchronous operation.
|
|
*/
|
|
void set_allow_async(bool allow_async = true);
|
|
|
|
/** Sets the label for the tab holding custom widgets.
|
|
*
|
|
* @newin2p10
|
|
* @param label The label to use, or <tt>0</tt> to use the default label.
|
|
*/
|
|
void set_custom_tab_label(const Glib::ustring& label);
|
|
|
|
|
|
#ifdef GLIBMM_EXCEPTIONS_ENABLED
|
|
PrintOperationResult run(PrintOperationAction action = PRINT_OPERATION_ACTION_PRINT_DIALOG);
|
|
#else
|
|
PrintOperationResult run(PrintOperationAction action, std::auto_ptr<Glib::Error>& error);
|
|
#endif //GLIBMM_EXCEPTIONS_ENABLED
|
|
|
|
|
|
/** 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
|
|
* Gtk::PrintOperation::status-changed signal on @a 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 set_allow_async() or set the allow-async
|
|
* property the operation will run asyncronously if this is supported on the
|
|
* platform. The Gtk::PrintOperation::done signal will be emitted with the
|
|
* operation results when the operation is done (i.e. when the dialog is
|
|
* canceled, or when the print succeeds or fails).
|
|
*
|
|
* @code
|
|
* if (settings != <tt>0</tt>)
|
|
* gtk_print_operation_set_print_settings (print, settings);
|
|
*
|
|
* if (page_setup != <tt>0</tt>)
|
|
* gtk_print_operation_set_default_page_setup (print, page_setup);
|
|
*
|
|
* g_signal_connect (print, "begin-print",
|
|
* G_CALLBACK (begin_print), &data);
|
|
* g_signal_connect (print, "draw-page",
|
|
* G_CALLBACK (draw_page), &data);
|
|
*
|
|
* res = gtk_print_operation_run (print, GTK_PRINT_OPERATION_ACTION_PRINT_DIALOG, parent, &error);
|
|
*
|
|
* if (res == GTK_PRINT_OPERATION_RESULT_ERROR)
|
|
* {
|
|
* error_dialog = gtk_message_dialog_new (GTK_WINDOW (parent),
|
|
* GTK_DIALOG_DESTROY_WITH_PARENT,
|
|
* GTK_MESSAGE_ERROR,
|
|
* GTK_BUTTONS_CLOSE,
|
|
* "Error printing file:<tt>\\n</tt>%s",
|
|
* error->message);
|
|
* g_signal_connect (error_dialog, "response",
|
|
* G_CALLBACK (gtk_widget_destroy), <tt>0</tt>);
|
|
* gtk_widget_show (error_dialog);
|
|
* g_error_free (error);
|
|
* }
|
|
* else if (res == GTK_PRINT_OPERATION_RESULT_APPLY)
|
|
* {
|
|
* if (settings != <tt>0</tt>)
|
|
* g_object_unref (settings);
|
|
* settings = g_object_ref (gtk_print_operation_get_print_settings (print));
|
|
* }
|
|
* @endcode
|
|
*
|
|
* Note that run() can only be called once on a
|
|
* given Gtk::PrintOperation.
|
|
* @param action The action to start.
|
|
* @param parent Transient parent of the dialog, or <tt>0</tt>.
|
|
* @param error Return location for errors, or <tt>0</tt>.
|
|
* @return The result of the print operation. A return value of
|
|
* Gtk::PRINT_OPERATION_RESULT_APPLY indicates that the printing was
|
|
* completed successfully. In this case, it is a good idea to obtain
|
|
* the used print settings with get_print_settings()
|
|
* and store them for reuse with the next print operation. A value of
|
|
* Gtk::PRINT_OPERATION_RESULT_IN_PROGRESS means the operation is running
|
|
* asynchronously, and will emit the ::done signal when done.
|
|
*
|
|
* @newin2p10.
|
|
*/
|
|
#ifdef GLIBMM_EXCEPTIONS_ENABLED
|
|
PrintOperationResult run(PrintOperationAction action, Window& parent);
|
|
#else
|
|
PrintOperationResult run(PrintOperationAction action, Window& parent, std::auto_ptr<Glib::Error>& error);
|
|
#endif //GLIBMM_EXCEPTIONS_ENABLED
|
|
|
|
|
|
/** Return value: the status of the print operation
|
|
* @return The status of the print operation
|
|
*
|
|
* @newin2p10.
|
|
*/
|
|
PrintStatus get_status() const;
|
|
|
|
/** Return value: a string representation of the status
|
|
* @return A string representation of the status
|
|
* of the print operation
|
|
*
|
|
* @newin2p10.
|
|
*/
|
|
Glib::ustring get_status_string() const;
|
|
|
|
/** Cancels a running print operation. This function may
|
|
* be called from a Gtk::PrintOperation::begin-print,
|
|
* Gtk::PrintOperation::paginate or Gtk::PrintOperation::draw-page
|
|
* signal handler to stop the currently running print
|
|
* operation.
|
|
*
|
|
* @newin2p10
|
|
*/
|
|
void cancel();
|
|
|
|
/** A convenience function to find out if the print operation
|
|
* is finished, either successfully (Gtk::PRINT_STATUS_FINISHED)
|
|
* or unsuccessfully (Gtk::PRINT_STATUS_FINISHED_ABORTED).
|
|
*
|
|
* @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.
|
|
* @return <tt>true</tt>, if the print operation is finished.
|
|
*
|
|
* @newin2p10.
|
|
*/
|
|
bool is_finished() const;
|
|
|
|
|
|
//TODO: point out in the docs that the PrintOperationResult enum may also indicate
|
|
// that an error occurred, and in that case it is up to him to handle it.
|
|
|
|
/**
|
|
* @par Prototype:
|
|
* <tt>void on_my_%done(PrintOperationResult result)</tt>
|
|
*/
|
|
|
|
Glib::SignalProxy1< void,PrintOperationResult > signal_done();
|
|
|
|
|
|
/**
|
|
* @par Prototype:
|
|
* <tt>void on_my_%begin_print(const Glib::RefPtr<PrintContext>& context)</tt>
|
|
*/
|
|
|
|
Glib::SignalProxy1< void,const Glib::RefPtr<PrintContext>& > signal_begin_print();
|
|
|
|
|
|
/**
|
|
* @par Prototype:
|
|
* <tt>bool on_my_%paginate(const Glib::RefPtr<PrintContext>& context)</tt>
|
|
*/
|
|
|
|
Glib::SignalProxy1< bool,const Glib::RefPtr<PrintContext>& > signal_paginate();
|
|
|
|
|
|
/**
|
|
* @par Prototype:
|
|
* <tt>void on_my_%request_page_setup(const Glib::RefPtr<PrintContext>& context, int page_no, const Glib::RefPtr<PageSetup>& setup)</tt>
|
|
*/
|
|
|
|
Glib::SignalProxy3< void,const Glib::RefPtr<PrintContext>&,int,const Glib::RefPtr<PageSetup>& > signal_request_page_setup();
|
|
|
|
|
|
/**
|
|
* @par Prototype:
|
|
* <tt>void on_my_%draw_page(const Glib::RefPtr<PrintContext>& context, int page_nr)</tt>
|
|
*/
|
|
|
|
Glib::SignalProxy2< void,const Glib::RefPtr<PrintContext>&,int > signal_draw_page();
|
|
|
|
|
|
/**
|
|
* @par Prototype:
|
|
* <tt>void on_my_%end_print(const Glib::RefPtr<PrintContext>& context)</tt>
|
|
*/
|
|
|
|
Glib::SignalProxy1< void,const Glib::RefPtr<PrintContext>& > signal_end_print();
|
|
|
|
|
|
/**
|
|
* @par Prototype:
|
|
* <tt>void on_my_%status_changed()</tt>
|
|
*/
|
|
|
|
Glib::SignalProxy0< void > signal_status_changed();
|
|
|
|
|
|
/**
|
|
* @par Prototype:
|
|
* <tt>Widget* on_my_%create_custom_widget()</tt>
|
|
*/
|
|
|
|
Glib::SignalProxy0< Widget* > signal_create_custom_widget();
|
|
|
|
|
|
/**
|
|
* @par Prototype:
|
|
* <tt>void on_my_%custom_widget_apply(Widget* widget)</tt>
|
|
*/
|
|
|
|
Glib::SignalProxy1< void,Widget* > signal_custom_widget_apply();
|
|
|
|
|
|
//TODO: This is causing crashes. Is it still causing crashes? murrayc.
|
|
|
|
/**
|
|
* @par Prototype:
|
|
* <tt>bool on_my_%preview(const Glib::RefPtr<PrintOperationPreview>& preview, const Glib::RefPtr<PrintContext>& context, Window* parent)</tt>
|
|
*/
|
|
|
|
Glib::SignalProxy3< bool,const Glib::RefPtr<PrintOperationPreview>&,const Glib::RefPtr<PrintContext>&,Window* > signal_preview();
|
|
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** The GtkPageSetup used by default.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy< Glib::RefPtr<PageSetup> > property_default_page_setup() ;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** The GtkPageSetup used by default.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy_ReadOnly< Glib::RefPtr<PageSetup> > property_default_page_setup() const;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** The GtkPrintSettings used for initializing the dialog.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy< Glib::RefPtr<PrintSettings> > property_print_settings() ;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** The GtkPrintSettings used for initializing the dialog.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy_ReadOnly< Glib::RefPtr<PrintSettings> > property_print_settings() const;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** A string used for identifying the print job.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy<Glib::ustring> property_job_name() ;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** A string used for identifying the print job.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy_ReadOnly<Glib::ustring> property_job_name() const;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** The number of pages in the document.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy<int> property_n_pages() ;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** The number of pages in the document.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy_ReadOnly<int> property_n_pages() const;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** The current page in the document.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy<int> property_current_page() ;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** The current page in the document.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy_ReadOnly<int> property_current_page() const;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** TRUE if the origin of the context should be at the corner of the page and not the corner of the imageable area.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy<bool> property_use_full_page() ;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** TRUE if the origin of the context should be at the corner of the page and not the corner of the imageable area.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy_ReadOnly<bool> property_use_full_page() const;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** The unit in which distances can be measured in the context.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy<Unit> property_unit() ;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** The unit in which distances can be measured in the context.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy_ReadOnly<Unit> property_unit() const;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** TRUE if a progress dialog is shown while printing.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy<bool> property_show_progress() ;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** TRUE if a progress dialog is shown while printing.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy_ReadOnly<bool> property_show_progress() const;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** TRUE if print process may run asynchronous.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy<bool> property_allow_async() ;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** TRUE if print process may run asynchronous.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy_ReadOnly<bool> property_allow_async() const;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** Export filename.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy<std::string> property_export_filename() ;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** Export filename.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy_ReadOnly<std::string> property_export_filename() const;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** The status of the print operation.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy_ReadOnly<PrintStatus> property_status() const;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** A human-readable description of the status.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy_ReadOnly<Glib::ustring> property_status_string() const;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** Label for the tab containing custom widgets.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy<Glib::ustring> property_custom_tab_label() ;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
#ifdef GLIBMM_PROPERTIES_ENABLED
|
|
/** Label for the tab containing custom widgets.
|
|
*
|
|
* You rarely need to use properties because there are get_ and set_ methods for almost all of them.
|
|
* @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
|
|
* the value of the property changes.
|
|
*/
|
|
Glib::PropertyProxy_ReadOnly<Glib::ustring> property_custom_tab_label() const;
|
|
#endif //#GLIBMM_PROPERTIES_ENABLED
|
|
|
|
|
|
public:
|
|
|
|
public:
|
|
//C++ methods used to invoke GTK+ virtual functions:
|
|
#ifdef GLIBMM_VFUNCS_ENABLED
|
|
#endif //GLIBMM_VFUNCS_ENABLED
|
|
|
|
protected:
|
|
//GTK+ Virtual Functions (override these to change behaviour):
|
|
#ifdef GLIBMM_VFUNCS_ENABLED
|
|
#endif //GLIBMM_VFUNCS_ENABLED
|
|
|
|
//Default Signal Handlers::
|
|
#ifdef GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED
|
|
virtual void on_done(PrintOperationResult result);
|
|
virtual void on_begin_print(const Glib::RefPtr<PrintContext>& context);
|
|
virtual bool on_paginate(const Glib::RefPtr<PrintContext>& context);
|
|
virtual void on_request_page_setup(const Glib::RefPtr<PrintContext>& context, int page_no, const Glib::RefPtr<PageSetup>& setup);
|
|
virtual void on_draw_page(const Glib::RefPtr<PrintContext>& context, int page_nr);
|
|
virtual void on_end_print(const Glib::RefPtr<PrintContext>& context);
|
|
virtual void on_status_changed();
|
|
virtual Widget* on_create_custom_widget();
|
|
virtual void on_custom_widget_apply(Widget* widget);
|
|
virtual bool on_preview(const Glib::RefPtr<PrintOperationPreview>& preview, const Glib::RefPtr<PrintContext>& context, Window* parent);
|
|
#endif //GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED
|
|
|
|
|
|
};
|
|
|
|
//TODO: Make these static members of a class instead of non-class functions?
|
|
|
|
//Note: gtk_run_page_setup_dialog() can take a null page_setup object, but the application should always
|
|
//store and reuse a page_setup object, so I see no need to provide an overload for that. murrayc.
|
|
//TODO: The parent parameter may also be null, so maybe we should add an overload for that.
|
|
|
|
/** Runs a page setup dialog, letting the user modify the values from page_setup.
|
|
* If the user cancels the dialog, the returned PageSetup is identical to that passed in @a page_setup,
|
|
* 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 run_page_setup_dialog_async() if this is a problem.
|
|
*
|
|
* @param parent Transient parent.
|
|
* @param page_setup An existing GtkPageSetup.
|
|
* @param settings Print settings.
|
|
* @result A new PageSetup object.
|
|
*
|
|
* @since 2.10
|
|
*/
|
|
Glib::RefPtr<PageSetup> run_page_setup_dialog(Window& parent,
|
|
const Glib::RefPtr<const PageSetup>& page_setup,
|
|
const Glib::RefPtr<const PrintSettings>& print_settings);
|
|
|
|
/** For example,
|
|
* void on_setup_done(const Glib::RefPtr<PageSetup>& page_setup);
|
|
*/
|
|
typedef sigc::slot< void, const Glib::RefPtr<PageSetup>& > SlotPrintSetupDone;
|
|
|
|
/** Runs a page setup dialog, letting the user modify the values from page_setup.
|
|
*
|
|
* In contrast to run_page_setup_dialog(), this function returns after showing the
|
|
* page setup dialog on platforms that support this, and calls the @a slot from a
|
|
* signal handler for the ::response signal of the dialog.
|
|
*
|
|
* @param parent Transient parent.
|
|
* @param page_setup An existing GtkPageSetup.
|
|
* @param settings Print settings.
|
|
* @result A new PageSetup object.
|
|
* @param slot
|
|
*
|
|
* @since 2.10
|
|
*/
|
|
void run_page_setup_dialog_async(Window& parent,
|
|
const Glib::RefPtr<const PageSetup>& page_setup,
|
|
const Glib::RefPtr<const PrintSettings>& print_settings,
|
|
const SlotPrintSetupDone& slot);
|
|
|
|
} // namespace Gtk
|
|
|
|
|
|
namespace Glib
|
|
{
|
|
/** A Glib::wrap() method for this object.
|
|
*
|
|
* @param object The C instance.
|
|
* @param take_copy False if the result should take ownership of the C instance. True if it should take a new copy or ref.
|
|
* @result A C++ instance that wraps this C instance.
|
|
*
|
|
* @relates Gtk::PrintOperation
|
|
*/
|
|
Glib::RefPtr<Gtk::PrintOperation> wrap(GtkPrintOperation* object, bool take_copy = false);
|
|
}
|
|
|
|
|
|
#endif /* _GTKMM_PRINTOPERATION_H */
|
|
|