Gtk.PrintContext

g GObject.Object GObject.Object Gtk.PrintContext Gtk.PrintContext GObject.Object->Gtk.PrintContext

Subclasses:

None

Methods

Inherited:

GObject.Object (37)

Structs:

GObject.ObjectClass (5)

create_pango_context ()

create_pango_layout ()

get_cairo_context ()

get_dpi_x ()

get_dpi_y ()

get_hard_margins ()

get_height ()

get_page_setup ()

get_pango_fontmap ()

get_width ()

set_cairo_context (cr, dpi_x, dpi_y)

Virtual Methods

Inherited:

GObject.Object (7)

Properties

None

Signals

Inherited:

GObject.Object (1)

Fields

Inherited:

GObject.Object (1)

Class Details

class Gtk.PrintContext(**kwargs)
Bases:

GObject.Object

Abstract:

No

A GtkPrintContext encapsulates context information that is required when drawing pages for printing.

This includes the cairo context and important parameters like page size and resolution. It also lets you easily create [class`Pango`.Layout] and [class`Pango`.Context] objects that match the font metrics of the cairo surface.

GtkPrintContext objects get passed to the [signal`Gtk`.PrintOperation::begin-print], [signal`Gtk`.PrintOperation::end-print], [signal`Gtk`.PrintOperation::request-page-setup] and [signal`Gtk`.PrintOperation::draw-page] signals on the [class`Gtk`.PrintOperation] object.

Using Gtk.PrintContext in a ::draw-page callback

```c static void draw_page (Gtk.PrintOperation *operation, Gtk.PrintContext *context, int page_nr) { cairo.Context *cr; Pango.Layout *layout; Pango.FontDescription *desc;

cr = Gtk.PrintContext.get_cairo_context (context);

// Draw a red rectangle, as wide as the paper (inside the margins) cairo.Context.set_source_rgb (cr, 1.0, 0, 0); cairo.Context.rectangle (cr, 0, 0, Gtk.PrintContext.get_width (context), 50);

cairo.Context.fill (cr);

// Draw some lines cairo.Context.move_to (cr, 20, 10); cairo.Context.line_to (cr, 40, 20); cairo.Context.arc (cr, 60, 60, 20, 0, M_PI); cairo.Context.line_to (cr, 80, 20);

cairo.Context.set_source_rgb (cr, 0, 0, 0); cairo.Context.set_line_width (cr, 5); cairo.Context.set_line_cap (cr, cairo.LineCap.ROUND); cairo.Context.set_line_join (cr, cairo.LineJoin.ROUND);

cairo.Context.stroke (cr);

// Draw some text layout = Gtk.PrintContext.create_pango_layout (context); Pango.Layout.set_text (layout, “Hello World! Printing is easy”, -1); desc = Pango.FontDescription.from_string (“sans 28”); Pango.Layout.set_font_description (layout, desc); Pango.FontDescription.free (desc);

cairo.Context.move_to (cr, 30, 20); PangoCairo.layout_path (cr, layout);

// Font Outline cairo.Context.set_source_rgb (cr, 0.93, 1.0, 0.47); cairo.Context.set_line_width (cr, 0.5); cairo.Context.stroke_preserve (cr);

// Font Fill cairo.Context.set_source_rgb (cr, 0, 0.0, 1.0); cairo.Context.fill (cr);

GObject.Object.unref (layout); } ```

create_pango_context()[source]
Returns:

a new Pango context for self

Return type:

Pango.Context

Creates a new PangoContext that can be used with the GtkPrintContext.

create_pango_layout()[source]
Returns:

a new Pango layout for self

Return type:

Pango.Layout

Creates a new PangoLayout that is suitable for use with the GtkPrintContext.

get_cairo_context()[source]
Returns:

the cairo context of self

Return type:

cairo.Context

Obtains the cairo context that is associated with the GtkPrintContext.

get_dpi_x()[source]
Returns:

the horizontal resolution of self

Return type:

float

Obtains the horizontal resolution of the GtkPrintContext, in dots per inch.

get_dpi_y()[source]
Returns:

the vertical resolution of self

Return type:

float

Obtains the vertical resolution of the GtkPrintContext, in dots per inch.

get_hard_margins()[source]
Returns:

True if the hard margins were retrieved

top:

top hardware printer margin

bottom:

bottom hardware printer margin

left:

left hardware printer margin

right:

right hardware printer margin

Return type:

(bool, top: float, bottom: float, left: float, right: float)

Obtains the hardware printer margins of the GtkPrintContext, in units.

get_height()[source]
Returns:

the height of self

Return type:

float

Obtains the height of the GtkPrintContext, in pixels.

get_page_setup()[source]
Returns:

the page setup of self

Return type:

Gtk.PageSetup

Obtains the GtkPageSetup that determines the page dimensions of the GtkPrintContext.

get_pango_fontmap()[source]
Returns:

the font map of self

Return type:

Pango.FontMap

Returns a PangoFontMap that is suitable for use with the GtkPrintContext.

get_width()[source]
Returns:

the width of self

Return type:

float

Obtains the width of the GtkPrintContext, in pixels.

set_cairo_context(cr, dpi_x, dpi_y)[source]
Parameters:
  • cr (cairo.Context) – the cairo context

  • dpi_x (float) – the horizontal resolution to use with cr

  • dpi_y (float) – the vertical resolution to use with cr

Sets a new cairo context on a print context.

This function is intended to be used when implementing an internal print preview, it is not needed for printing, since GTK itself creates a suitable cairo context in that case.