pangomm: Pango::LayoutLine Class Reference

A Pango::LayoutLine represents one of the lines resulting from laying out a paragraph via Pango::Layout. More...

#include <pangomm/layoutline.h>

Public Member Functions

void reference () const
 Increment the reference count for this object. More...

 
void unreference () const
 Decrement the reference count for this object. More...

 
PangoLayoutLine* gobj ()
 Provides access to the underlying C instance. More...

 
const PangoLayoutLine* gobj () const
 Provides access to the underlying C instance. More...

 
PangoLayoutLine* gobj_copy () const
 Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs. More...

 
 LayoutLine ()=delete
 
 LayoutLine (const LayoutLine&)=delete
 
LayoutLineoperator= (const LayoutLine&)=delete
 
bool x_to_index (int x_pos, int& index, int& trailing) const
 Converts from x offset to the byte index of the corresponding character within the text of the layout. More...

 
int index_to_x (int index, bool trailing) const
 Converts an index within a line to a x position. More...

 
std::vector< std::pair< int, int > > get_x_ranges (int start_index, int end_index) const
 Get a list of visual ranges corresponding to a given logical range. More...

 
void get_extents (Rectangle& ink_rect, Rectangle& logical_rect) const
 Compute the logical and ink extents of a layout line. More...

 
Rectangle get_ink_extents () const
 Compute the ink extents of a layout line. More...

 
Rectangle get_logical_extents () const
 Compute the logical extents of a layout line. More...

 
void get_pixel_extents (Rectangle& ink_rect, Rectangle& logical_rect) const
 Compute the logical and ink extents of a layout line. More...

 
Rectangle get_pixel_ink_extents () const
 Compute the ink extents of a layout line in device units. More...

 
Rectangle get_pixel_logical_extents () const
 Compute the logical extents of a layout line in device units. More...

 
void show_in_cairo_context (const Cairo::RefPtr< Cairo::Context >& context)
 Draws this LayoutLine in the specified Cairo context. More...

 
void add_to_cairo_context (const Cairo::RefPtr< Cairo::Context >& context)
 Adds the text in this LayoutLine to the current path in the specified Cairo context. More...

 
Glib::RefPtr< Pango::Layoutget_layout ()
 
Glib::RefPtr< const Pango::Layoutget_layout () const
 
int get_length () const
 
int get_start_index () const
 

Protected Member Functions

void operator delete (void*, std::size_t)
 

Related Functions

(Note that these are not member functions.)

Glib::RefPtr< Pango::LayoutLinewrap (PangoLayoutLine* object, bool take_copy=false)
 A Glib::wrap() method for this object. More...

 

Detailed Description

A Pango::LayoutLine represents one of the lines resulting from laying out a paragraph via Pango::Layout.

Pango::LayoutLine objects are obtained by calling Pango::Layout::get_line() and are only valid until the text, attributes, or settings of the parent Pango::Layout are modified. Routines for rendering Pango::Layout objects are provided in code specific to each rendering system.

Constructor & Destructor Documentation

Pango::LayoutLine::LayoutLine ( )
delete
Pango::LayoutLine::LayoutLine ( const LayoutLine )
delete

Member Function Documentation

void Pango::LayoutLine::add_to_cairo_context ( const Cairo::RefPtr< Cairo::Context > &  context)

Adds the text in this LayoutLine to the current path in the specified Cairo context.

The origin of the glyphs (the left edge of the line) will be at the current point of the cairo context.

Parameters
contextA Cairo context.
void Pango::LayoutLine::get_extents ( Rectangle ink_rect,
Rectangle logical_rect 
) const

Compute the logical and ink extents of a layout line.

See the documentation for Pango::Font::get_glyph_extents() for details about the interpretation of the rectangles.

Parameters
ink_rectRectangle used to store the extents of the glyph string as drawn.
logical_rectRectangle used to store the logical extents of the glyph string.
Rectangle Pango::LayoutLine::get_ink_extents ( ) const

Compute the ink extents of a layout line.

Returns
The extents of the layout line as drawn.
Glib::RefPtr<Pango::Layout> Pango::LayoutLine::get_layout ( )
Glib::RefPtr<const Pango::Layout> Pango::LayoutLine::get_layout ( ) const
int Pango::LayoutLine::get_length ( ) const
Rectangle Pango::LayoutLine::get_logical_extents ( ) const

Compute the logical extents of a layout line.

Returns
The logical extents of the layout line.
void Pango::LayoutLine::get_pixel_extents ( Rectangle ink_rect,
Rectangle logical_rect 
) const

Compute the logical and ink extents of a layout line.

See the documentation for Pango::Font::get_glyph_extents() for details about the interpretation of the rectangles. The returned rectangles are in device units, as opposed to get_extents(), which returns the extents in units of device unit / PANGO_SCALE.

Parameters
ink_rectRectangle used to store the extents of the glyph string as drawn.
logical_rectRectangle used to store the logical extents of the glyph string.
Rectangle Pango::LayoutLine::get_pixel_ink_extents ( ) const

Compute the ink extents of a layout line in device units.

Returns
The extents of the layout line as drawn.
Rectangle Pango::LayoutLine::get_pixel_logical_extents ( ) const

Compute the logical extents of a layout line in device units.

Returns
The logical extents of the layout line.
int Pango::LayoutLine::get_start_index ( ) const
std::vector<std::pair<int,int> > Pango::LayoutLine::get_x_ranges ( int  start_index,
int  end_index 
) const

Get a list of visual ranges corresponding to a given logical range.

This list is not necessarily minimal - there may be consecutive ranges which are adjacent. The ranges will be sorted from left to right. The ranges are with respect to the left edge of the entire layout, not with respect to the line.

Parameters
start_indexThe start byte index of the logical range. If the value of start_index is less than the start index for the line, then the first range will extend all the way to the leading edge of the layout. Otherwise it will start at the leading edge of the first character.
end_indexThe end byte index of the logical range. If the value of end_index is greater than the end index for the line, then the last range will extend all the way to the trailing edge of the layout. Otherwise, it will end at the trailing edge of the last character.
Returns
An array of ranges represented by pairs of integers marking the start and end pixel coordinates of the ranges.
PangoLayoutLine* Pango::LayoutLine::gobj ( )

Provides access to the underlying C instance.

const PangoLayoutLine* Pango::LayoutLine::gobj ( ) const

Provides access to the underlying C instance.

PangoLayoutLine* Pango::LayoutLine::gobj_copy ( ) const

Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs.

int Pango::LayoutLine::index_to_x ( int  index,
bool  trailing 
) const

Converts an index within a line to a x position.

Parameters
indexByte offset of a grapheme within the layout.
trailingA boolean indicating the edge of the grapheme to retrieve the position of. If false, the trailing edge of the grapheme, if true the leading of the grapheme.
Returns
The x offset (in thousands of a device unit).
void Pango::LayoutLine::operator delete ( void *  ,
std::size_t   
)
protected
LayoutLine& Pango::LayoutLine::operator= ( const LayoutLine )
delete
void Pango::LayoutLine::reference ( ) const

Increment the reference count for this object.

You should never need to do this manually - use the object via a RefPtr instead.

void Pango::LayoutLine::show_in_cairo_context ( const Cairo::RefPtr< Cairo::Context > &  context)

Draws this LayoutLine in the specified Cairo context.

The origin of the glyphs (the left edge of the line) will be drawn at the current point of the cairo context.

Parameters
contextA Cairo context.
void Pango::LayoutLine::unreference ( ) const

Decrement the reference count for this object.

You should never need to do this manually - use the object via a RefPtr instead.

bool Pango::LayoutLine::x_to_index ( int  x_pos,
int &  index,
int &  trailing 
) const

Converts from x offset to the byte index of the corresponding character within the text of the layout.

If x_pos is outside the line, index and trailing will point to the very first or very last position in the line. This determination is based on the resolved direction of the paragraph; for example, if the resolved direction is right-to-left, then an X position to the right of the line (after it) results in 0 being stored in index and trailing. An X position to the left of the line results in index pointing to the (logical) last grapheme in the line and trailing being set to the number of characters in that grapheme. The reverse is true for a left-to-right line.

Parameters
x_posThe X offset (in Pango units) from the left edge of the line.
indexLocation to store calculated byte index for the grapheme in which the user clicked.
trailingLocation to store an integer indicating where in the grapheme the user clicked. It will either be zero, or the number of characters in the grapheme. 0 represents the leading edge of the grapheme.
Returns
false if x_pos was outside the line, true if inside.

Friends And Related Function Documentation

Glib::RefPtr< Pango::LayoutLine > wrap ( PangoLayoutLine *  object,
bool  take_copy = false 
)
related

A Glib::wrap() method for this object.

Parameters
objectThe C instance.
take_copyFalse if the result should take ownership of the C instance. True if it should take a new copy or ref.
Returns
A C++ instance that wraps this C instance.