Magick::TypeMetric

The TypeMetric class provides the means to pass data from the Image class's TypeMetric method to the user. It provides information regarding font metrics such as ascent, descent, text width, text height, and maximum horizontal advance. The units of these font metrics are in pixels, and that the metrics are dependent on the current Image font (default Ghostscript's "Helvetica"), pointsize (default 12 points), and x/y resolution (default 72 DPI) settings.

The pixel units may be converted to points (the standard resolution-independent measure used by the typesetting industry) via the following equation:

size_points = (size_pixels * 72)/resolution
where resolution is in dots-per-inch (DPI). This means that at the default image resolution, there is one pixel per point.

Note that a font's pointsize is only a first-order approximation of the font height (ascender + descender) in points. The relationship between the specified pointsize and the rendered font height is determined by the font designer.

 See FreeType Glyph Conventions for a detailed description of font metrics related issues.

The methods available in the TypeMetric class are shown in the following table:
 
TypeMetric Methods
Method
Returns
Units
Signature
Description
ascent
double Pixels void Returns the distance in pixels from the text baseline to the highest/upper grid coordinate used to place an outline point. Always a positive value.
descent
double Pixels void Returns the the distance in pixels from the baseline to the lowest grid coordinate used to place an outline point. Always a negative value.
textWidth
double Pixels void Returns text width in pixels.
textHeight
double Pixels void Returns text height in pixels.
maxHorizontalAdvance
double Pixels void Returns the maximum horizontal advance (advance from the beginning of a character to the beginning of the next character) in pixels.