LayoutLineProtocol
public protocol LayoutLineProtocol
A PangoLayoutLine represents one of the lines resulting from laying
out a paragraph via PangoLayout.
PangoLayoutLine structures are obtained by calling
[methodPango.Layout.get_line] and are only valid until the text,
attributes, or settings of the parent PangoLayout are modified.
The LayoutLineProtocol protocol exposes the methods and properties of an underlying PangoLayoutLine instance.
The default implementation of these can be found in the protocol extension below.
For a concrete class that implements these methods and properties, see LayoutLine.
Alternatively, use LayoutLineRef as a lighweight, unowned reference if you already have an instance you just want to use.
-
Untyped pointer to the underlying
PangoLayoutLineinstance.Declaration
Swift
var ptr: UnsafeMutableRawPointer! { get } -
layout_line_ptrDefault implementationTyped pointer to the underlying
PangoLayoutLineinstance.Default Implementation
Return the stored, untyped pointer as a typed pointer to the
PangoLayoutLineinstance.Declaration
Swift
var layout_line_ptr: UnsafeMutablePointer<PangoLayoutLine>! { get } -
Required Initialiser for types conforming to
LayoutLineProtocolDeclaration
Swift
init(raw: UnsafeMutableRawPointer)
-
getExtents(inkRect:Extension methodlogicalRect: ) Computes the logical and ink extents of a layout line.
See [method
Pango.Font.get_glyph_extents] for details about the interpretation of the rectangles.Declaration
Swift
@inlinable func getExtents(inkRect: RectangleRef? = nil, logicalRect: RectangleRef? = nil) -
getExtents(inkRect:Extension methodlogicalRect: ) Computes the logical and ink extents of a layout line.
See [method
Pango.Font.get_glyph_extents] for details about the interpretation of the rectangles.Declaration
Swift
@inlinable func getExtents<RectangleT>(inkRect: RectangleT?, logicalRect: RectangleT?) where RectangleT : RectangleProtocol -
get(height:Extension method) Computes the height of the line, as the maximum of the heights of fonts used in this line.
Note that the actual baseline-to-baseline distance between lines of text is influenced by other factors, such as [method
Pango.Layout.set_spacing] and [methodPango.Layout.set_line_spacing].Declaration
Swift
@inlinable func get(height: UnsafeMutablePointer<gint>! = nil) -
getLength()Extension methodReturns the length of the line, in bytes.
Declaration
Swift
@inlinable func getLength() -> Int -
getPixelExtents(inkRect:Extension methodlogicalRect: ) Computes the logical and ink extents of
layout_linein device units.This function just calls [method
Pango.LayoutLine.get_extents] followed by two [funcextents_to_pixels] calls, roundingink_rectandlogical_rectsuch that the rounded rectangles fully contain the unrounded one (that is, passes them as first argument to [funcextents_to_pixels]).Declaration
Swift
@inlinable func getPixelExtents(inkRect: RectangleRef? = nil, logicalRect: RectangleRef? = nil) -
getPixelExtents(inkRect:Extension methodlogicalRect: ) Computes the logical and ink extents of
layout_linein device units.This function just calls [method
Pango.LayoutLine.get_extents] followed by two [funcextents_to_pixels] calls, roundingink_rectandlogical_rectsuch that the rounded rectangles fully contain the unrounded one (that is, passes them as first argument to [funcextents_to_pixels]).Declaration
Swift
@inlinable func getPixelExtents<RectangleT>(inkRect: RectangleT?, logicalRect: RectangleT?) where RectangleT : RectangleProtocol -
getResolvedDirection()Extension methodReturns the resolved direction of the line.
Declaration
Swift
@inlinable func getResolvedDirection() -> PangoDirection -
getStartIndex()Extension methodReturns the start index of the line, as byte index into the text of the layout.
Declaration
Swift
@inlinable func getStartIndex() -> Int -
getXRanges(startIndex:Extension methodendIndex: ranges: nRanges: ) Gets 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.
Declaration
Swift
@inlinable func getXRanges(startIndex: Int, endIndex: Int, ranges: UnsafeMutablePointer<UnsafeMutablePointer<CInt>?>!, nRanges: UnsafeMutablePointer<gint>!) -
indexToX(index:Extension methodtrailing: xPos: ) Converts an index within a line to a X position.
Declaration
Swift
@inlinable func indexToX(index: Int, trailing: Bool, xPos: UnsafeMutablePointer<gint>!) -
ref()Extension methodIncrease the reference count of a
PangoLayoutLineby one.Declaration
Swift
@discardableResult @inlinable func ref() -> Pango.LayoutLineRef! -
unref()Extension methodDecrease the reference count of a
PangoLayoutLineby one.If the result is zero, the line and all associated memory will be freed.
Declaration
Swift
@inlinable func unref() -
xToIndex(xPos:Extension methodindex: trailing: ) Converts from x offset to the byte index of the corresponding character within the text of the layout.
If
x_posis outside the line,index_andtrailingwill 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 inindex_andtrailing. An X position to the left of the line results inindex_pointing to the (logical) last grapheme in the line andtrailingbeing set to the number of characters in that grapheme. The reverse is true for a left-to-right line.Declaration
Swift
@inlinable func xToIndex(xPos: Int, index: UnsafeMutablePointer<gint>!, trailing: UnsafeMutablePointer<gint>!) -> Bool -
isParagraphStartExtension methodReturns whether this is the first line of the paragraph.
Declaration
Swift
@inlinable var isParagraphStart: Bool { get } -
lengthExtension methodReturns the length of the line, in bytes.
Declaration
Swift
@inlinable var length: Int { get } -
resolvedDirectionExtension methodReturns the resolved direction of the line.
Declaration
Swift
@inlinable var resolvedDirection: PangoDirection { get } -
startIndexExtension methodReturns the start index of the line, as byte index into the text of the layout.
Declaration
Swift
@inlinable var startIndex: Int { get } -
layoutExtension methodthe layout this line belongs to, might be
nilDeclaration
Swift
@inlinable var layout: LayoutRef! { get set } -
_startIndexExtension methodstart of line as byte index into layout->text
Declaration
Swift
@inlinable var _startIndex: gint { get set } -
_lengthExtension methodlength of line in bytes
Declaration
Swift
@inlinable var _length: gint { get set } -
runsExtension methodlist of runs in the line, from left to right
Declaration
Swift
@inlinable var runs: SListRef! { get set } -
_isParagraphStartExtension methodTRUEif this is the first line of the paragraphDeclaration
Swift
@inlinable var _isParagraphStart: guint { get set } -
resolvedDirExtension methodResolvedPangoDirection of lineDeclaration
Swift
@inlinable var resolvedDir: guint { get set }
View on GitHub
Install in Dash
LayoutLineProtocol Protocol Reference