mirror of
https://gitlab.freedesktop.org/cairo/cairo.git
synced 2026-05-22 00:58:08 +02:00
src/cairoint.h src/cairo_font.c src/cairo_ft_font.c src/cairo_xlib_surface.c src/cairo_pdf_surface.c src/cairo_gstate.c src/cairo.c: Switch many internal methods from handling cairo_unscaled_font_t and cairo_font_scale_t pairs to handling cairo_font_t. src/cairo-ft-private.h src/cairo_ft_fontc: Add some internal interfaces for use by the FreeType backend. Clear the gstate's current font when the transform or target surface changes. src/cairo.h src/cairo_ft_font.c: Rename cairo_ft_font_pattern to cairo_ft_font_get_pattern(). src/cairo.h src/cairo_ft_font.c: Make cairo_ft_font_create() and cairo_ft_font_create_for_ft_face() take a font scale; make the latter take load_flags for FT_Load_Glyph() as well. Change cairo_ft_font_face() to Xft-style cairo_ft_font_lock_face, cairo_ft_font_unlock_face. Remove the name/slant/weight=>unscaled font cache, it didn't work with the new cairo_font_t setup. If it turns out to be needed, it can be added back in some other form. src/cairoint.h src/cairo_font.c: Add a 'flags' field to cairo_glyph_cache_key_t, we use it for load flags with freetype backend. Switch the caching to be from resolved fontconfig pattern => file; keep only a fixed number of FT_Face objects open at once, similar to FreeType. src/cairo_gstate.c src/cairoint.h: Add public cairo_font_glyph_extents, use it to implement _cairo_gstate_glyph_extents(). Add refcounting for glyph cache elements; there was an bug where elements got ejected from the cache and freed before they could be used. src/cairoint.h src/cairo_cache.c (_cairo_cache_random_entry()) New function to return a random entry in the cache matching a predicate; reuse the internals for the previous _random_live_entry(). src/cairoint.h src/cairo_cache.c (_cairo_cache_lookup()): Add an optional created_entry return value. src/cairo_ft_font.c src/cairo_xlib_surface.c: Adapt to _cairo_cache_lookup() change. Support max_memory == 0 to indicate an unbounded cache. src/cairoint.h src/cairo_cache.c (_cairo_cache_remove()): Add a function to manually remove entries from the cache. Update for changes, document cairo_matrix_t, cairo_glyph_t, etc. src/cairo.h src/cairo-atsui.h src/cairo-ft.h src/cairo-glitz.h src/cairo-pdf.h src/cairo-png.h src/cairo-ps.h src/cairo-quartz.h src/cairo-xcb.h src/cairo-xlib.h: Add CAIRO_BEGIN/END_DECLS for extern "C", use it on all public headers. Move header guards outermost. Fix encoding.
62 lines
2.3 KiB
XML
62 lines
2.3 KiB
XML
|
|
<refentry id="cairo_glyph_t">
|
|
<refmeta>
|
|
<refentrytitle>cairo_glyph_t</refentrytitle>
|
|
<manvolnum>3</manvolnum>
|
|
</refmeta>
|
|
<refnamediv>
|
|
<refname>cairo_glyph_t</refname>
|
|
<refpurpose>struct holding information about a glyph</refpurpose>
|
|
</refnamediv>
|
|
<refsect1>
|
|
<title>Description</title>
|
|
<para><indexterm><primary>types</primary><secondary>cairo_glyph_t</secondary></indexterm><indexterm><primary/></indexterm>
|
|
<programlisting>
|
|
typedef struct {
|
|
double index;
|
|
double x;
|
|
double y;
|
|
} cairo_glyph_t;
|
|
</programlisting>
|
|
</para>
|
|
<para>
|
|
The <structname>cairo_glyph_t</structname> structure holds
|
|
information about a single glyph when drawing or measuring
|
|
text. A font is (in simple terms) a collection of shapes used to
|
|
draw text. A glyph is one of these shapes. There can be multiple
|
|
glyphs for a single character (alternates to be used in
|
|
different contexts, for example), or a glyph can be a
|
|
<firstterm>ligature</firstterm> of multiple characters. Cairo
|
|
doesn't expose any way of converting input text into glyphs, so
|
|
in order to use the Cairo interfaces that take arrays of glyphs,
|
|
you must directly access the appropriate underlying font system.
|
|
</para>
|
|
<variablelist role="struct">
|
|
<varlistentry>
|
|
<term><structfield>index</structfield></term>
|
|
<listitem><simpara>glyph index in the font. The exact
|
|
interpretation of the glyph index depends on the font
|
|
technology being used.
|
|
</simpara></listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term><structfield>x</structfield></term>
|
|
<listitem><simpara>the offset in the x direction between the
|
|
origin used for drawing or measuring the string and the
|
|
origin of this glyph. These offsets are not cumulative; each
|
|
glyph is indiviually positioned with respect to the
|
|
overall origin.
|
|
</simpara></listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term><structfield>y</structfield></term>
|
|
<listitem><simpara>the offset in the y direction between the
|
|
origin used for drawing or measuring the string and the
|
|
origin of this glyph. These offsets are not cumulative; each
|
|
glyph is indiviually positioned with respect to the
|
|
overall origin.
|
|
</simpara></listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
</refsect1>
|
|
</refentry>
|