Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Cache ¶
type Cache struct {
// contains filtered or unexported fields
}
Cache implements cached layout and shaping of text from a set of registered fonts.
If a font matches no registered shape, Cache falls back to the first registered face.
The LayoutString and ShapeString results are cached and re-used if possible.
func (*Cache) LayoutString ¶
LayoutString is a caching implementation of the Shaper interface.
type Face ¶
type Face interface { Layout(ppem fixed.Int26_6, maxWidth int, txt io.Reader) ([]Line, error) Shape(ppem fixed.Int26_6, str Layout) op.CallOp }
Face implements text layout and shaping for a particular font. All methods must be safe for concurrent use.
type Font ¶
type Font struct { Typeface Typeface Variant Variant Style Style // Weight is the text weight. If zero, Normal is used instead. Weight Weight }
Font specify a particular typeface variant, style and weight.
type Line ¶
type Line struct { Layout Layout // Width is the width of the line. Width fixed.Int26_6 // Ascent is the height above the baseline. Ascent fixed.Int26_6 // Descent is the height below the baseline, including // the line gap. Descent fixed.Int26_6 // Bounds is the visible bounds of the line. Bounds fixed.Rectangle26_6 }
A Line contains the measurements of a line of text.
type Shaper ¶
type Shaper interface { // Layout a text according to a set of options. Layout(font Font, size fixed.Int26_6, maxWidth int, txt io.Reader) ([]Line, error) // LayoutString is Layout for strings. LayoutString(font Font, size fixed.Int26_6, maxWidth int, str string) []Line // Shape a line of text and return a clipping operation for its outline. Shape(font Font, size fixed.Int26_6, layout Layout) op.CallOp }
Shaper implements layout and shaping of text.
type Typeface ¶
type Typeface string
Typeface identifies a particular typeface design. The empty string denotes the default typeface.