pango-0.13.3.0: Binding to the Pango text rendering engine.

Maintainergtk2hs-users@lists.sourceforge.net
Stabilityprovisional
Portabilityportable (depends on GHC)
Safe HaskellNone
LanguageHaskell98

Graphics.Rendering.Pango.Enums

Description

Enumerations for describing font characteristics.

Synopsis

Documentation

data Color Source #

Color

  • Specifies a color with three integer values for red, green and blue. All values range from 0 (least intense) to 65535 (highest intensity).

Constructors

Color Word16 Word16 Word16 

Instances

Eq Color Source # 

Methods

(==) :: Color -> Color -> Bool #

(/=) :: Color -> Color -> Bool #

Show Color Source # 

Methods

showsPrec :: Int -> Color -> ShowS #

show :: Color -> String #

showList :: [Color] -> ShowS #

data Rectangle Source #

Rectangle

  • Specifies x, y, width and height

Constructors

Rectangle Int Int Int Int 

data FontMetrics Source #

The characteristic measurements of a font.

Constructors

FontMetrics 

Fields

  • ascent :: Double

    The ascent is the distance from the baseline to the logical top of a line of text. (The logical top may be above or below the top of the actual drawn ink. It is necessary to lay out the text to figure where the ink will be.)

  • descent :: Double

    The descent is the distance from the baseline to the logical bottom of a line of text. (The logical bottom may be above or below the bottom of the actual drawn ink. It is necessary to lay out the text to figure where the ink will be.)

  • approximateCharWidth :: Double

    The approximate character width. This is merely a representative value useful, for example, for determining the initial size for a window. Actual characters in text will be wider and narrower than this.

  • approximateDigitWidth :: Double

    The approximate digit width. This is merely a representative value useful, for example, for determining the initial size for a window. Actual digits in text can be wider and narrower than this, though this value is generally somewhat more accurate than approximateCharWidth.

  • underlineThickness :: Double

    The suggested thickness to draw an underline.

  • underlinePosition :: Double

    The suggested position to draw the underline. The value returned is the distance above the baseline of the top of the underline. Since most fonts have underline positions beneath the baseline, this value is typically negative.

  • strikethroughThickness :: Double

    The suggested thickness to draw for the strikethrough.

  • strikethroughPosition :: Double

    The suggested position to draw the strikethrough. The value returned is the distance above the baseline of the top of the strikethrough.

data Size Source #

Define attributes for FontSize.

Instances

data Variant Source #

The variant of a font.

  • The VariantSmallCaps is a version of a font where lower case letters are shown as physically smaller upper case letters.

data PangoDirection Source #

The PangoDirection type represents a direction in the Unicode bidirectional algorithm.

  • The "weak" values denote a left-to-right or right-to-left direction only if there is no character with a strong direction in a paragraph. An example is a sequence of special, graphical characters which are neutral with respect to their rendering direction. A fresh PangoContext is by default weakly left-to-right.
  • Not every value in this enumeration makes sense for every usage of PangoDirection; for example, the return value of unicharDirection and findBaseDir cannot be PangoDirectionWeakLtr or PangoDirectionWeakRtl, since every character is either neutral or has a strong direction; on the other hand PangoDirectionNeutral doesn't make sense to pass to log2visGetEmbeddingLevels.

data PangoAttribute Source #

Attributes for PangoItems.

  • A given attribute is applied from its start position paStart up, but not including the end position, paEnd.

Constructors

AttrLanguage

A hint as to what language this piece of text is written in.

Fields

AttrFamily

The font family, e.g. sans serif.

AttrStyle

The slant of the current font.

Fields

AttrWeight

Weight of font, e.g. WeightBold.

Fields

AttrVariant

VariantSmallCaps will display lower case letters as small upper case letters (if the font supports this).

Fields

AttrStretch

Stretch or condense the width of the letters.

Fields

AttrSize

Specify the size of the font in points.

Fields

AttrAbsSize

Specify the size of the font in device units (pixels).

  • Available in Pango 1.8.0 and higher.

Fields

AttrFontDescription

Specify several attributes of a font at once. Note that no deep copy of the description is made when this attributes is passed to or received from functions.

AttrForeground

Specify the foreground color.

Fields

AttrBackground

Specify the background color.

Fields

AttrUnderline

Specify the kind of underline, e.g. UnderlineSingle.

AttrUnderlineColor

Specify the color of an underline.

  • Available in Pango 1.8.0 and higher.

Fields

AttrStrikethrough

Specify if this piece of text should have a line through it.

AttrStrikethroughColor

Specify the color of the strike through line.

  • Available in Pango 1.8.0 and higher.

Fields

AttrRise

Displace the text vertically. Positive values move the text upwards.

Fields

AttrShape

Restrict the amount of what is drawn of the marked shapes.

  • Available in Pango 1.8.0 and higher.
AttrScale

Scale the font up (values greater than one) or shrink the font.

Fields

AttrFallback

Determine if a fall back font should be substituted if no matching font is available.

Fields

AttrLetterSpacing

Add extra space between graphemes of the text.

  • Available in Pango 1.6.0 and higher.
AttrGravity

Sets the gravity field of a font description. The gravity field specifies how the glyphs should be rotated. If gravity is GravityAuto, this actually unsets the gravity mask on the font description.

  • This function is seldom useful to the user. Gravity should normally be set on a PangoContext.
  • Available in Pango 1.16.0 and higher.
AttrGravityHint

Set the way horizontal scripts behave in a vertical context.

  • Available in Pango 1.16.0 and higher.

data EllipsizeMode Source #

The EllipsizeMode type describes what sort of (if any) ellipsization should be applied to a line of text. In the ellipsization process characters are removed from the text in order to make it fit to a given width and replaced with an ellipsis.

data PangoGravity Source #

The PangoGravity type represents the orientation of glyphs in a segment of text. The value GravitySouth, for instance, indicates that the text stands upright, i.e. that the base of the letter is directed downwards.

This is useful when rendering vertical text layouts. In those situations, the layout is rotated using a non-identity PangoMatrix, and then glyph orientation is controlled using PangoGravity. Not every value in this enumeration makes sense for every usage of Gravity; for example, PangoGravityAuto only can be passed to pangoContextSetBaseGravity and can only be returned by pangoContextGetBaseGravity.

  • See also: PangoGravityHint
  • Gravity is resolved from the context matrix.
  • Since Pango 1.16

data PangoGravityHint Source #

The PangoGravityHint defines how horizontal scripts should behave in a vertical context.

  • PangoGravityHintNatural: scripts will take their natural gravity based on the base gravity and the script. This is the default.
  • PangoGravityHintStrong: always use the base gravity set, regardless of the script.
  • PangoGravityHintLine: for scripts not in their natural direction (eg. Latin in East gravity), choose per-script gravity such that every script respects the line progression. This means, Latin and Arabic will take opposite gravities and both flow top-to-bottom for example.

data Language Source #

An RFC-3066 language designator to choose scripts.

emptyLanguage :: Language Source #

Specifying no particular language.

languageFromString :: GlibString string => string -> IO Language Source #

Take a RFC-3066 format language tag as a string and convert it to a Language type that can be efficiently passed around and compared with other language tags.

  • This function first canonicalizes the string by converting it to lowercase, mapping '_' to '-', and stripping all characters other than letters and '-'.