Copyright | (c) 2011 Diagrams-cairo team (see LICENSE) |
---|---|
License | BSD-style (see LICENSE) |
Maintainer | diagrams-discuss@googlegroups.com |
Safe Haskell | None |
Language | Haskell2010 |
This module provides convenience functions for querying information
from cairo. In particular, this provides utilities for information
about fonts, and creating text primitives with bounds based on the
font being used. To render text with automatically determined
envelopes, use textLineBounded
, textLineBoundedIO
,
textVisualBounded
, or textVisualBoundedIO
.
Many of these functions take a Style
R2
parameter, determining the
style to apply to the text before rendering / querying information about
the text. These Style
R2
parameters can be created a variety of ways,
but the most direct will likely be by applying style-transforming functions
such as font
, fontSize
, fontSlant
, and fontWeight
to mempty
.
This works because there are instances of HasStyle
and Monoid
for
.Style
v
NOTE that this module has a couple significant caveats:
- There are some known bugs (https://github.com/diagrams/diagrams-cairo/issues/19) which are not easily fixable (they are probably bugs in cairo itself, but since we are using the "toy text API" they will never be fixed).
- The functions in this module will only
work with text whose font size is measured in
Local
units.
This module should thus be considered experimental/unsupported; if
it works for you, great, but if not you are probably out of luck.
See the SVGFonts
package for better-supported ways to accomplish
similar things.
- textLineBoundedIO :: Style R2 -> String -> IO (Diagram Cairo R2)
- textVisualBoundedIO :: Style R2 -> String -> IO (Diagram Cairo R2)
- kerningCorrection :: Style R2 -> Char -> Char -> Double
- textLineBounded :: Style R2 -> String -> Diagram Cairo R2
- textVisualBounded :: Style R2 -> String -> Diagram Cairo R2
- data TextExtents = TextExtents R2 R2 R2
- bearing :: Lens' TextExtents R2
- textSize :: Lens' TextExtents R2
- advance :: Lens' TextExtents R2
- data FontExtents = FontExtents Double Double Double R2
- ascent :: Lens' FontExtents Double
- descent :: Lens' FontExtents Double
- height :: Lens' FontExtents Double
- maxAdvance :: Lens' FontExtents R2
- getTextExtents :: Style R2 -> String -> Render TextExtents
- getFontExtents :: Style R2 -> Render FontExtents
- getExtents :: Style R2 -> String -> Render (FontExtents, TextExtents)
- kerningCorrectionIO :: Style R2 -> Char -> Char -> IO Double
- queryCairo :: Render a -> IO a
- unsafeCairo :: Render a -> a
- cairoWithStyle :: Render a -> Style R2 -> Render a
Primitives
These create diagrams instantiated with extent-based envelopes.
textLineBoundedIO :: Style R2 -> String -> IO (Diagram Cairo R2) Source
Creates text diagrams with their envelopes set such that using
stacks them in the way that
the font designer intended.vcat
. map (textLineBounded
style)
textVisualBoundedIO :: Style R2 -> String -> IO (Diagram Cairo R2) Source
Creates a text diagram with its envelope set to enclose the glyphs of the text, including leading (though not trailing) whitespace.
Unsafe
These are convenient unsafe variants of the above operations
using unsafePerformIO
. In practice, they should be fairly
safe as the results depend only on the parameters and the
font information (which ought to stay the same during a given
execution).
kerningCorrection :: Style R2 -> Char -> Char -> Double Source
Queries the amount of horizontal offset that needs to be applied
in order to position the second character properly, in the event
that it is hcat
-ed baselineText
. See kerningCorrectionIO
;
this variant uses unsafePerformIO
but should be fairly safe in
practice.
textLineBounded :: Style R2 -> String -> Diagram Cairo R2 Source
Creates text diagrams with their envelopes set such that using
stacks them in the way
that the font designer intended. See vcat
. map (textLineBounded
style)textLineBoundedIO
; this
variant uses unsafePerformIO
but should be fairly safe in
practice.
textVisualBounded :: Style R2 -> String -> Diagram Cairo R2 Source
Creates a text diagram with its envelope set to enclose the
glyphs of the text, including leading (though not trailing)
whitespace. See textVisualBoundedIO
; this variant uses
unsafePerformIO
but should be fairly safe in practice.
Extents
Data Structures
data TextExtents Source
A more convenient data structure for the results of a text-extents query.
data FontExtents Source
A more convenient data structure for the results of a font-extents query.
Queries
getTextExtents :: Style R2 -> String -> Render TextExtents Source
Get the extents of a string of text, given a style to render it with.
getFontExtents :: Style R2 -> Render FontExtents Source
Gets the intrinsic extents of a font.
getExtents :: Style R2 -> String -> Render (FontExtents, TextExtents) Source
Gets both the FontExtents
and TextExtents
of the string with the a
particular style applied. This is more efficient than calling both
getFontExtents
and getTextExtents
.
kerningCorrectionIO :: Style R2 -> Char -> Char -> IO Double Source
Queries the amount of horizontal offset that needs to be applied in order to
position the second character properly, in the event that it is hcat
-ed
baselineText
.
Utilities
queryCairo :: Render a -> IO a Source
Executes a cairo action on a dummy, zero-size image surface, in order to query things like font information.
unsafeCairo :: Render a -> a Source
Unsafely invokes queryCairo
using unsafePerformIO
.