Struct ttf_parser::FaceTables[][src]

pub struct FaceTables<'a> { /* fields omitted */ }

Parsed face tables.

This struct adds the from_table_provider() method that is not available on the Font. You can create a FaceTables struct from your own, custom font provider. This is important if your font provider does things that ttf-parser currently doesn't implement (for example zlib / brotli decoding)

Implementations

impl<'a> FaceTables<'a>[src]

pub fn from_table_provider<T>(provider: T) -> Result<Self, FaceParsingError> where
    T: Iterator<Item = Result<(Tag, Option<&'a [u8]>), FaceParsingError>>, 
[src]

Creates and parses face tables from an existing table provider.

This is useful for integrating ttf-parser with other font-parsing libraries that already do table decoding

pub fn has_table(&self, name: TableName) -> bool[src]

Checks that face has a specified table.

Will return true only for tables that were successfully parsed.

pub fn names(&self) -> Names<'_>

Notable traits for Names<'a>

impl<'a> Iterator for Names<'a> type Item = Name<'a>;
[src]

Returns an iterator over Name Records.

An iterator can be empty.

pub fn is_regular(&self) -> bool[src]

Checks that face is marked as Regular.

Returns false when OS/2 table is not present.

pub fn is_italic(&self) -> bool[src]

Checks that face is marked as Italic.

Returns false when OS/2 table is not present.

pub fn is_bold(&self) -> bool[src]

Checks that face is marked as Bold.

Returns false when OS/2 table is not present.

pub fn is_oblique(&self) -> bool[src]

Checks that face is marked as Oblique.

Returns false when OS/2 table is not present or when its version is < 4.

pub fn is_monospaced(&self) -> bool[src]

Checks that face is marked as Monospaced.

Returns false when post table is not present.

pub fn is_variable(&self) -> bool[src]

Checks that face is variable.

Simply checks the presence of a fvar table.

pub fn weight(&self) -> Weight[src]

Returns face's weight.

Returns Weight::Normal when OS/2 table is not present.

pub fn width(&self) -> Width[src]

Returns face's width.

Returns Width::Normal when OS/2 table is not present or when value is invalid.

pub fn italic_angle(&self) -> Option<f32>[src]

Returns face's italic angle.

Returns None when post table is not present.

pub fn ascender(&self) -> i16[src]

Returns a horizontal face ascender.

This method is affected by variation axes.

pub fn descender(&self) -> i16[src]

Returns a horizontal face descender.

This method is affected by variation axes.

pub fn height(&self) -> i16[src]

Returns face's height.

This method is affected by variation axes.

pub fn line_gap(&self) -> i16[src]

Returns a horizontal face line gap.

This method is affected by variation axes.

pub fn typographic_ascender(&self) -> Option<i16>[src]

Returns a horizontal typographic face ascender.

Prefer Face::ascender unless you explicitly want this. This is a more low-level alternative.

This method is affected by variation axes.

Returns None when OS/2 table is not present.

pub fn typographic_descender(&self) -> Option<i16>[src]

Returns a horizontal typographic face descender.

Prefer Face::descender unless you explicitly want this. This is a more low-level alternative.

This method is affected by variation axes.

Returns None when OS/2 table is not present.

pub fn typographic_line_gap(&self) -> Option<i16>[src]

Returns a horizontal typographic face line gap.

Prefer Face::line_gap unless you explicitly want this. This is a more low-level alternative.

This method is affected by variation axes.

Returns None when OS/2 table is not present.

pub fn vertical_ascender(&self) -> Option<i16>[src]

Returns a vertical face ascender.

This method is affected by variation axes.

pub fn vertical_descender(&self) -> Option<i16>[src]

Returns a vertical face descender.

This method is affected by variation axes.

pub fn vertical_height(&self) -> Option<i16>[src]

Returns a vertical face height.

This method is affected by variation axes.

pub fn vertical_line_gap(&self) -> Option<i16>[src]

Returns a vertical face line gap.

This method is affected by variation axes.

pub fn units_per_em(&self) -> Option<u16>[src]

Returns face's units per EM.

Returns None when value is not in a 16..=16384 range.

pub fn x_height(&self) -> Option<i16>[src]

Returns face's x height.

This method is affected by variation axes.

Returns None when OS/2 table is not present or when its version is < 2.

pub fn capital_height(&self) -> Option<i16>[src]

Returns face's capital height.

This method is affected by variation axes.

Returns None when OS/2 table is not present or when its version is < 2.

pub fn underline_metrics(&self) -> Option<LineMetrics>[src]

Returns face's underline metrics.

This method is affected by variation axes.

Returns None when post table is not present.

pub fn strikeout_metrics(&self) -> Option<LineMetrics>[src]

Returns face's strikeout metrics.

This method is affected by variation axes.

Returns None when OS/2 table is not present.

pub fn subscript_metrics(&self) -> Option<ScriptMetrics>[src]

Returns face's subscript metrics.

This method is affected by variation axes.

Returns None when OS/2 table is not present.

pub fn superscript_metrics(&self) -> Option<ScriptMetrics>[src]

Returns face's superscript metrics.

This method is affected by variation axes.

Returns None when OS/2 table is not present.

pub fn number_of_glyphs(&self) -> u16[src]

Returns a total number of glyphs in the face.

Never zero.

The value was already parsed, so this function doesn't involve any parsing.

pub fn character_mapping_subtables(&self) -> Subtables<'_>

Notable traits for Subtables<'a>

impl<'a> Iterator for Subtables<'a> type Item = Subtable<'a>;
[src]

Returns an iterator over character to glyph index mapping.

This is a more low-level alternative to Face::glyph_index.

An iterator can be empty.

pub fn glyph_index(&self, c: char) -> Option<GlyphId>[src]

Resolves a Glyph ID for a code point.

Returns None instead of 0 when glyph is not found.

All subtable formats except Mixed Coverage (8) are supported.

If you need a more low-level control, prefer Face::character_mapping_subtables.

pub fn glyph_variation_index(&self, c: char, variation: char) -> Option<GlyphId>[src]

Resolves a variation of a Glyph ID from two code points.

Implemented according to Unicode Variation Sequences.

Returns None instead of 0 when glyph is not found.

pub fn glyph_hor_advance(&self, glyph_id: GlyphId) -> Option<u16>[src]

Returns glyph's horizontal advance.

This method is affected by variation axes.

pub fn glyph_ver_advance(&self, glyph_id: GlyphId) -> Option<u16>[src]

Returns glyph's vertical advance.

This method is affected by variation axes.

pub fn glyph_hor_side_bearing(&self, glyph_id: GlyphId) -> Option<i16>[src]

Returns glyph's horizontal side bearing.

This method is affected by variation axes.

pub fn glyph_ver_side_bearing(&self, glyph_id: GlyphId) -> Option<i16>[src]

Returns glyph's vertical side bearing.

This method is affected by variation axes.

pub fn glyph_y_origin(&self, glyph_id: GlyphId) -> Option<i16>[src]

Returns glyph's vertical origin according to Vertical Origin Table.

pub fn glyph_name(&self, glyph_id: GlyphId) -> Option<&str>[src]

Returns glyph's name.

Uses the post and CFF tables as sources.

Returns None when no name is associated with a glyph.

pub fn has_glyph_classes(&self) -> bool[src]

Checks that face has Glyph Class Definition Table.

pub fn glyph_class(&self, glyph_id: GlyphId) -> Option<GlyphClass>[src]

Returns glyph's class according to Glyph Class Definition Table.

Returns None when Glyph Class Definition Table is not set or glyph class is not set or invalid.

pub fn glyph_mark_attachment_class(&self, glyph_id: GlyphId) -> Class[src]

Returns glyph's mark attachment class according to Mark Attachment Class Definition Table.

All glyphs not assigned to a class fall into Class 0.

pub fn is_mark_glyph(&self, glyph_id: GlyphId, set_index: Option<u16>) -> bool[src]

Checks that glyph is a mark according to Mark Glyph Sets Table.

set_index allows checking a specific glyph coverage set. Otherwise all sets will be checked.

pub fn glyph_variation_delta(
    &self,
    outer_index: u16,
    inner_index: u16
) -> Option<f32>
[src]

Returns glyph's variation delta at a specified index according to Item Variation Store Table.

pub fn kerning_subtables(&self) -> Subtables<'_>

Notable traits for Subtables<'a>

impl<'a> Iterator for Subtables<'a> type Item = Subtable<'a>;
[src]

Returns a iterator over kerning subtables.

Supports both OpenType and Apple Advanced Typography variants.

pub fn outline_glyph(
    &self,
    glyph_id: GlyphId,
    builder: &mut dyn OutlineBuilder
) -> Option<Rect>
[src]

Outlines a glyph and returns its tight bounding box.

Warning: since ttf-parser is a pull parser, OutlineBuilder will emit segments even when outline is partially malformed. You must check outline_glyph() result before using OutlineBuilder's output.

gvar, glyf, CFF and CFF2 tables are supported. And they will be accesses in this specific order.

This method is affected by variation axes.

Returns None when glyph has no outline or on error.

Example

use std::fmt::Write;
use ttf_parser;

struct Builder(String);

impl ttf_parser::OutlineBuilder for Builder {
    fn move_to(&mut self, x: f32, y: f32) {
        write!(&mut self.0, "M {} {} ", x, y).unwrap();
    }

    fn line_to(&mut self, x: f32, y: f32) {
        write!(&mut self.0, "L {} {} ", x, y).unwrap();
    }

    fn quad_to(&mut self, x1: f32, y1: f32, x: f32, y: f32) {
        write!(&mut self.0, "Q {} {} {} {} ", x1, y1, x, y).unwrap();
    }

    fn curve_to(&mut self, x1: f32, y1: f32, x2: f32, y2: f32, x: f32, y: f32) {
        write!(&mut self.0, "C {} {} {} {} {} {} ", x1, y1, x2, y2, x, y).unwrap();
    }

    fn close(&mut self) {
        write!(&mut self.0, "Z ").unwrap();
    }
}

let data = std::fs::read("tests/fonts/demo.ttf").unwrap();
let face = ttf_parser::Face::from_slice(&data, 0).unwrap();
let mut builder = Builder(String::new());
let bbox = face.outline_glyph(ttf_parser::GlyphId(1), &mut builder).unwrap();
assert_eq!(builder.0, "M 173 267 L 369 267 L 270 587 L 173 267 Z M 6 0 L 224 656 \
                       L 320 656 L 541 0 L 452 0 L 390 200 L 151 200 L 85 0 L 6 0 Z ");
assert_eq!(bbox, ttf_parser::Rect { x_min: 6, y_min: 0, x_max: 541, y_max: 656 });

pub fn glyph_bounding_box(&self, glyph_id: GlyphId) -> Option<Rect>[src]

Returns a tight glyph bounding box.

Unless the current face has a glyf table, this is just a shorthand for outline_glyph() since only the glyf table stores a bounding box. In case of CFF and variable fonts we have to actually outline a glyph to find it's bounding box.

When a glyph is defined by a raster or a vector image, that can be obtained via glyph_image(), the bounding box must be calculated manually and this method will return None.

This method is affected by variation axes.

pub fn global_bounding_box(&self) -> Rect[src]

Returns a bounding box that large enough to enclose any glyph from the face.

pub fn glyph_raster_image(
    &self,
    glyph_id: GlyphId,
    pixels_per_em: u16
) -> Option<RasterGlyphImage<'_>>
[src]

Returns a reference to a glyph's raster image.

A font can define a glyph using a raster or a vector image instead of a simple outline. Which is primarily used for emojis. This method should be used to access raster images.

pixels_per_em allows selecting a preferred image size. The chosen size will be closer to an upper one. So when font has 64px and 96px images and pixels_per_em is set to 72, 96px image will be returned. To get the largest image simply use std::u16::MAX.

Note that this method will return an encoded image. It should be decoded by the caller. We don't validate or preprocess it in any way.

Currently, only PNG images are supported.

Also, a font can contain both: images and outlines. So when this method returns None you should also try outline_glyph() afterwards.

There are multiple ways an image can be stored in a TrueType font and this method supports only sbix, CBLC+CBDT. Font's tables be accesses in this specific order.

pub fn glyph_svg_image(&self, glyph_id: GlyphId) -> Option<&'a [u8]>[src]

Returns a reference to a glyph's SVG image.

A font can define a glyph using a raster or a vector image instead of a simple outline. Which is primarily used for emojis. This method should be used to access SVG images.

Note that this method will return just an SVG data. It should be rendered or even decompressed (in case of SVGZ) by the caller. We don't validate or preprocess it in any way.

Also, a font can contain both: images and outlines. So when this method returns None you should also try outline_glyph() afterwards.

pub fn variation_axes(&self) -> VariationAxes<'_>

Notable traits for VariationAxes<'a>

impl<'a> Iterator for VariationAxes<'a> type Item = VariationAxis;
[src]

Returns an iterator over variation axes.

pub fn set_variation(&mut self, axis: Tag, value: f32) -> Option<()>[src]

Sets a variation axis coordinate.

This is the only mutable method in the library. We can simplify the API a lot by storing the variable coordinates in the face object itself.

Since coordinates are stored on the stack, we allow only 32 of them.

Returns None when face is not variable or doesn't have such axis.

pub fn variation_coordinates(&self) -> &[NormalizedCoordinate][src]

Returns the current normalized variation coordinates.

pub fn has_non_default_variation_coordinates(&self) -> bool[src]

Checks that face has non-default variation coordinates.

Trait Implementations

impl<'a> Clone for FaceTables<'a>[src]

impl Debug for FaceTables<'_>[src]

Auto Trait Implementations

impl<'a> RefUnwindSafe for FaceTables<'a>[src]

impl<'a> Send for FaceTables<'a>[src]

impl<'a> Sync for FaceTables<'a>[src]

impl<'a> Unpin for FaceTables<'a>[src]

impl<'a> UnwindSafe for FaceTables<'a>[src]

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.