cairo 1.15.13-x64-mingw32 → 1.15.14-x64-mingw32
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/NEWS +24 -0
- data/README.rdoc +11 -40
- data/Rakefile +4 -2
- data/ext/cairo/rb_cairo.h +1 -1
- data/ext/cairo/rb_cairo_context.c +35 -3
- data/ext/cairo/rb_cairo_font_options.c +5 -6
- data/ext/cairo/rb_cairo_private.h +2 -2
- data/ext/cairo/rb_cairo_scaled_font.c +11 -2
- data/ext/cairo/rb_cairo_surface.c +89 -48
- data/lib/2.2/cairo.so +0 -0
- data/lib/2.3/cairo.so +0 -0
- data/lib/2.4/cairo.so +0 -0
- data/lib/2.5/cairo.so +0 -0
- data/test/{cairo-test-utils.rb → helper.rb} +4 -5
- data/test/run-test.rb +3 -10
- data/test/test_context.rb +6 -6
- data/test/test_font_extents.rb +1 -1
- data/test/test_font_face.rb +1 -1
- data/test/test_font_options.rb +1 -1
- data/test/test_image_surface.rb +2 -2
- data/test/test_pdf_surface.rb +1 -1
- data/test/test_quartz_image_surface.rb +1 -1
- data/test/test_raster_source_pattern.rb +13 -13
- data/test/test_recording_surface.rb +2 -2
- data/test/test_region.rb +1 -1
- data/test/test_scaled_font.rb +1 -1
- data/test/test_script_device.rb +1 -1
- data/test/test_script_surface.rb +1 -1
- data/test/test_surface.rb +5 -5
- data/test/test_svg_surface.rb +1 -1
- data/test/test_tee_surface.rb +2 -2
- data/test/test_text_cluster.rb +1 -1
- data/test/test_text_extents.rb +1 -1
- data/test/test_text_to_glyphs_data.rb +1 -1
- data/test/test_xml_device.rb +1 -1
- data/test/test_xml_surface.rb +2 -2
- data/vendor/local/bin/fc-cache.exe +0 -0
- data/vendor/local/bin/fc-cat.exe +0 -0
- data/vendor/local/bin/fc-conflist.exe +0 -0
- data/vendor/local/bin/fc-list.exe +0 -0
- data/vendor/local/bin/fc-match.exe +0 -0
- data/vendor/local/bin/fc-pattern.exe +0 -0
- data/vendor/local/bin/fc-query.exe +0 -0
- data/vendor/local/bin/fc-scan.exe +0 -0
- data/vendor/local/bin/fc-validate.exe +0 -0
- data/vendor/local/bin/libcairo-2.dll +0 -0
- data/vendor/local/bin/libcairo-gobject-2.dll +0 -0
- data/vendor/local/bin/libcairo-script-interpreter-2.dll +0 -0
- data/vendor/local/bin/libfontconfig-1.dll +0 -0
- data/vendor/local/bin/libfreetype-6.dll +0 -0
- data/vendor/local/bin/libpixman-1-0.dll +0 -0
- data/vendor/local/bin/libpng-config +1 -1
- data/vendor/local/bin/libpng16-16.dll +0 -0
- data/vendor/local/bin/libpng16-config +1 -1
- data/vendor/local/bin/libxml2-2.dll +0 -0
- data/vendor/local/bin/png-fix-itxt.exe +0 -0
- data/vendor/local/bin/pngfix.exe +0 -0
- data/vendor/local/bin/xmlcatalog.exe +0 -0
- data/vendor/local/bin/xmllint.exe +0 -0
- data/vendor/local/bin/zlib1211.dll +0 -0
- data/vendor/local/include/freetype2/freetype/config/ftconfig.h +82 -3
- data/vendor/local/include/freetype2/freetype/config/ftheader.h +43 -85
- data/vendor/local/include/freetype2/freetype/config/ftoption.h +43 -56
- data/vendor/local/include/freetype2/freetype/config/ftstdlib.h +1 -1
- data/vendor/local/include/freetype2/freetype/freetype.h +185 -85
- data/vendor/local/include/freetype2/freetype/ftadvanc.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftbbox.h +2 -2
- data/vendor/local/include/freetype2/freetype/ftbdf.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftbitmap.h +2 -2
- data/vendor/local/include/freetype2/freetype/ftbzip2.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftcache.h +1 -16
- data/vendor/local/include/freetype2/freetype/ftchapters.h +3 -0
- data/vendor/local/include/freetype2/freetype/ftcid.h +2 -2
- data/vendor/local/include/freetype2/freetype/ftdriver.h +1225 -0
- data/vendor/local/include/freetype2/freetype/fterrdef.h +1 -1
- data/vendor/local/include/freetype2/freetype/fterrors.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftfntfmt.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftgasp.h +6 -1
- data/vendor/local/include/freetype2/freetype/ftglyph.h +3 -3
- data/vendor/local/include/freetype2/freetype/ftgxval.h +5 -5
- data/vendor/local/include/freetype2/freetype/ftgzip.h +4 -1
- data/vendor/local/include/freetype2/freetype/ftimage.h +18 -18
- data/vendor/local/include/freetype2/freetype/ftincrem.h +2 -13
- data/vendor/local/include/freetype2/freetype/ftlcdfil.h +5 -18
- data/vendor/local/include/freetype2/freetype/ftlist.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftlzw.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftmac.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftmm.h +99 -11
- data/vendor/local/include/freetype2/freetype/ftmodapi.h +12 -11
- data/vendor/local/include/freetype2/freetype/ftmoderr.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftotval.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftoutln.h +4 -7
- data/vendor/local/include/freetype2/freetype/ftparams.h +205 -0
- data/vendor/local/include/freetype2/freetype/ftpfr.h +4 -4
- data/vendor/local/include/freetype2/freetype/ftrender.h +2 -2
- data/vendor/local/include/freetype2/freetype/ftsizes.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftsnames.h +8 -42
- data/vendor/local/include/freetype2/freetype/ftstroke.h +6 -6
- data/vendor/local/include/freetype2/freetype/ftsynth.h +1 -1
- data/vendor/local/include/freetype2/freetype/ftsystem.h +1 -1
- data/vendor/local/include/freetype2/freetype/fttrigon.h +1 -1
- data/vendor/local/include/freetype2/freetype/fttypes.h +2 -2
- data/vendor/local/include/freetype2/freetype/ftwinfnt.h +2 -2
- data/vendor/local/include/freetype2/freetype/t1tables.h +10 -1
- data/vendor/local/include/freetype2/freetype/ttnameid.h +2 -2
- data/vendor/local/include/freetype2/freetype/tttables.h +1 -1
- data/vendor/local/include/freetype2/freetype/tttags.h +1 -1
- data/vendor/local/include/freetype2/ft2build.h +1 -1
- data/vendor/local/include/libpng16/png.h +40 -40
- data/vendor/local/include/libpng16/pngconf.h +15 -14
- data/vendor/local/include/libpng16/pnglibconf.h +1 -1
- data/vendor/local/include/png.h +40 -40
- data/vendor/local/include/pngconf.h +15 -14
- data/vendor/local/include/pnglibconf.h +1 -1
- data/vendor/local/lib/libcairo-gobject.dll.a +0 -0
- data/vendor/local/lib/libcairo-gobject.la +1 -1
- data/vendor/local/lib/libcairo-script-interpreter.a +0 -0
- data/vendor/local/lib/libcairo-script-interpreter.dll.a +0 -0
- data/vendor/local/lib/libcairo.a +0 -0
- data/vendor/local/lib/libcairo.dll.a +0 -0
- data/vendor/local/lib/libfontconfig.dll.a +0 -0
- data/vendor/local/lib/libfreetype.a +0 -0
- data/vendor/local/lib/libfreetype.dll.a +0 -0
- data/vendor/local/lib/libfreetype.la +3 -3
- data/vendor/local/lib/libpixman-1.dll.a +0 -0
- data/vendor/local/lib/libpng.a +0 -0
- data/vendor/local/lib/libpng.dll.a +0 -0
- data/vendor/local/lib/libpng.la +2 -2
- data/vendor/local/lib/libpng16.a +0 -0
- data/vendor/local/lib/libpng16.dll.a +0 -0
- data/vendor/local/lib/libpng16.la +2 -2
- data/vendor/local/lib/libxml2.dll.a +0 -0
- data/vendor/local/lib/libz.dll.a +0 -0
- data/vendor/local/lib/pkgconfig/freetype2.pc +2 -2
- data/vendor/local/lib/pkgconfig/libpng.pc +1 -1
- data/vendor/local/lib/pkgconfig/libpng16.pc +1 -1
- data/vendor/local/share/aclocal/freetype2.m4 +1 -1
- data/vendor/local/share/license/freetype/README +9 -9
- data/vendor/local/share/license/freetype/README.git +1 -1
- data/vendor/local/share/license/libpng/README +2 -2
- data/vendor/local/share/man/man3/libpng.3 +50 -54
- data/vendor/local/share/man/man3/libpngpf.3 +8 -4
- metadata +9 -14
- data/vendor/local/bin/freetype-config +0 -211
- data/vendor/local/include/freetype2/freetype/ftautoh.h +0 -533
- data/vendor/local/include/freetype2/freetype/ftcffdrv.h +0 -321
- data/vendor/local/include/freetype2/freetype/ftpcfdrv.h +0 -105
- data/vendor/local/include/freetype2/freetype/ftttdrv.h +0 -328
- data/vendor/local/include/freetype2/freetype/ttunpat.h +0 -63
- data/vendor/local/share/man/man1/freetype-config.1 +0 -146
@@ -4,7 +4,7 @@
|
|
4
4
|
/* */
|
5
5
|
/* Quick computation of advance widths (specification only). */
|
6
6
|
/* */
|
7
|
-
/* Copyright 2008-
|
7
|
+
/* Copyright 2008-2018 by */
|
8
8
|
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
9
9
|
/* */
|
10
10
|
/* This file is part of the FreeType project, and may only be used, */
|
@@ -4,7 +4,7 @@
|
|
4
4
|
/* */
|
5
5
|
/* FreeType exact bbox computation (specification). */
|
6
6
|
/* */
|
7
|
-
/* Copyright 1996-
|
7
|
+
/* Copyright 1996-2018 by */
|
8
8
|
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
9
9
|
/* */
|
10
10
|
/* This file is part of the FreeType project, and may only be used, */
|
@@ -61,7 +61,7 @@ FT_BEGIN_HEADER
|
|
61
61
|
/* Compute the exact bounding box of an outline. This is slower */
|
62
62
|
/* than computing the control box. However, it uses an advanced */
|
63
63
|
/* algorithm that returns _very_ quickly when the two boxes */
|
64
|
-
/* coincide. Otherwise, the outline
|
64
|
+
/* coincide. Otherwise, the outline Bezier arcs are traversed to */
|
65
65
|
/* extract their extrema. */
|
66
66
|
/* */
|
67
67
|
/* <Input> */
|
@@ -4,7 +4,7 @@
|
|
4
4
|
/* */
|
5
5
|
/* FreeType API for accessing BDF-specific strings (specification). */
|
6
6
|
/* */
|
7
|
-
/* Copyright 2002-
|
7
|
+
/* Copyright 2002-2018 by */
|
8
8
|
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
9
9
|
/* */
|
10
10
|
/* This file is part of the FreeType project, and may only be used, */
|
@@ -4,7 +4,7 @@
|
|
4
4
|
/* */
|
5
5
|
/* FreeType utility functions for bitmaps (specification). */
|
6
6
|
/* */
|
7
|
-
/* Copyright 2004-
|
7
|
+
/* Copyright 2004-2018 by */
|
8
8
|
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
9
9
|
/* */
|
10
10
|
/* This file is part of the FreeType project, and may only be used, */
|
@@ -97,7 +97,7 @@ FT_BEGIN_HEADER
|
|
97
97
|
FT_EXPORT( FT_Error )
|
98
98
|
FT_Bitmap_Copy( FT_Library library,
|
99
99
|
const FT_Bitmap *source,
|
100
|
-
FT_Bitmap *target);
|
100
|
+
FT_Bitmap *target );
|
101
101
|
|
102
102
|
|
103
103
|
/*************************************************************************/
|
@@ -4,7 +4,7 @@
|
|
4
4
|
/* */
|
5
5
|
/* FreeType Cache subsystem (specification). */
|
6
6
|
/* */
|
7
|
-
/* Copyright 1996-
|
7
|
+
/* Copyright 1996-2018 by */
|
8
8
|
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
9
9
|
/* */
|
10
10
|
/* This file is part of the FreeType project, and may only be used, */
|
@@ -540,13 +540,6 @@ FT_BEGIN_HEADER
|
|
540
540
|
FTC_FaceID face_id );
|
541
541
|
|
542
542
|
|
543
|
-
/*************************************************************************/
|
544
|
-
/* */
|
545
|
-
/* <Section> */
|
546
|
-
/* cache_subsystem */
|
547
|
-
/* */
|
548
|
-
/*************************************************************************/
|
549
|
-
|
550
543
|
/*************************************************************************
|
551
544
|
*
|
552
545
|
* @type:
|
@@ -623,14 +616,6 @@ FT_BEGIN_HEADER
|
|
623
616
|
FT_UInt32 char_code );
|
624
617
|
|
625
618
|
|
626
|
-
/*************************************************************************/
|
627
|
-
/* */
|
628
|
-
/* <Section> */
|
629
|
-
/* cache_subsystem */
|
630
|
-
/* */
|
631
|
-
/*************************************************************************/
|
632
|
-
|
633
|
-
|
634
619
|
/*************************************************************************/
|
635
620
|
/*************************************************************************/
|
636
621
|
/*************************************************************************/
|
@@ -76,8 +76,11 @@
|
|
76
76
|
/* <Sections> */
|
77
77
|
/* auto_hinter */
|
78
78
|
/* cff_driver */
|
79
|
+
/* t1_cid_driver */
|
79
80
|
/* tt_driver */
|
80
81
|
/* pcf_driver */
|
82
|
+
/* properties */
|
83
|
+
/* parameter_tags */
|
81
84
|
/* */
|
82
85
|
/***************************************************************************/
|
83
86
|
|
@@ -4,7 +4,7 @@
|
|
4
4
|
/* */
|
5
5
|
/* FreeType API for accessing CID font information (specification). */
|
6
6
|
/* */
|
7
|
-
/* Copyright 2007-
|
7
|
+
/* Copyright 2007-2018 by */
|
8
8
|
/* Dereg Clegg and Michael Toftdal. */
|
9
9
|
/* */
|
10
10
|
/* This file is part of the FreeType project, and may only be used, */
|
@@ -87,7 +87,7 @@ FT_BEGIN_HEADER
|
|
87
87
|
FT_Get_CID_Registry_Ordering_Supplement( FT_Face face,
|
88
88
|
const char* *registry,
|
89
89
|
const char* *ordering,
|
90
|
-
FT_Int *supplement);
|
90
|
+
FT_Int *supplement );
|
91
91
|
|
92
92
|
|
93
93
|
/**********************************************************************
|
@@ -0,0 +1,1225 @@
|
|
1
|
+
/***************************************************************************/
|
2
|
+
/* */
|
3
|
+
/* ftdriver.h */
|
4
|
+
/* */
|
5
|
+
/* FreeType API for controlling driver modules (specification only). */
|
6
|
+
/* */
|
7
|
+
/* Copyright 2017-2018 by */
|
8
|
+
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
9
|
+
/* */
|
10
|
+
/* This file is part of the FreeType project, and may only be used, */
|
11
|
+
/* modified, and distributed under the terms of the FreeType project */
|
12
|
+
/* license, LICENSE.TXT. By continuing to use, modify, or distribute */
|
13
|
+
/* this file you indicate that you have read the license and */
|
14
|
+
/* understand and accept it fully. */
|
15
|
+
/* */
|
16
|
+
/***************************************************************************/
|
17
|
+
|
18
|
+
|
19
|
+
#ifndef FTDRIVER_H_
|
20
|
+
#define FTDRIVER_H_
|
21
|
+
|
22
|
+
#include <ft2build.h>
|
23
|
+
#include FT_FREETYPE_H
|
24
|
+
#include FT_PARAMETER_TAGS_H
|
25
|
+
|
26
|
+
#ifdef FREETYPE_H
|
27
|
+
#error "freetype.h of FreeType 1 has been loaded!"
|
28
|
+
#error "Please fix the directory search order for header files"
|
29
|
+
#error "so that freetype.h of FreeType 2 is found first."
|
30
|
+
#endif
|
31
|
+
|
32
|
+
|
33
|
+
FT_BEGIN_HEADER
|
34
|
+
|
35
|
+
|
36
|
+
/**************************************************************************
|
37
|
+
*
|
38
|
+
* @section:
|
39
|
+
* auto_hinter
|
40
|
+
*
|
41
|
+
* @title:
|
42
|
+
* The auto-hinter
|
43
|
+
*
|
44
|
+
* @abstract:
|
45
|
+
* Controlling the auto-hinting module.
|
46
|
+
*
|
47
|
+
* @description:
|
48
|
+
* While FreeType's auto-hinter doesn't expose API functions by itself,
|
49
|
+
* it is possible to control its behaviour with @FT_Property_Set and
|
50
|
+
* @FT_Property_Get. The following lists the available properties
|
51
|
+
* together with the necessary macros and structures.
|
52
|
+
*
|
53
|
+
* Note that the auto-hinter's module name is `autofitter' for
|
54
|
+
* historical reasons.
|
55
|
+
*
|
56
|
+
* Available properties are @increase-x-height, @no-stem-darkening
|
57
|
+
* (experimental), @darkening-parameters (experimental), @warping
|
58
|
+
* (experimental), @glyph-to-script-map (experimental), @fallback-script
|
59
|
+
* (experimental), and @default-script (experimental), as documented in
|
60
|
+
* the @properties section.
|
61
|
+
*
|
62
|
+
*/
|
63
|
+
|
64
|
+
|
65
|
+
/**************************************************************************
|
66
|
+
*
|
67
|
+
* @section:
|
68
|
+
* cff_driver
|
69
|
+
*
|
70
|
+
* @title:
|
71
|
+
* The CFF driver
|
72
|
+
*
|
73
|
+
* @abstract:
|
74
|
+
* Controlling the CFF driver module.
|
75
|
+
*
|
76
|
+
* @description:
|
77
|
+
* While FreeType's CFF driver doesn't expose API functions by itself,
|
78
|
+
* it is possible to control its behaviour with @FT_Property_Set and
|
79
|
+
* @FT_Property_Get.
|
80
|
+
*
|
81
|
+
* The CFF driver's module name is `cff'.
|
82
|
+
*
|
83
|
+
* Available properties are @hinting-engine, @no-stem-darkening,
|
84
|
+
* @darkening-parameters, and @random-seed, as documented in the
|
85
|
+
* @properties section.
|
86
|
+
*
|
87
|
+
*
|
88
|
+
* *Hinting* *and* *antialiasing* *principles* *of* *the* *new* *engine*
|
89
|
+
*
|
90
|
+
* The rasterizer is positioning horizontal features (e.g., ascender
|
91
|
+
* height & x-height, or crossbars) on the pixel grid and minimizing the
|
92
|
+
* amount of antialiasing applied to them, while placing vertical
|
93
|
+
* features (vertical stems) on the pixel grid without hinting, thus
|
94
|
+
* representing the stem position and weight accurately. Sometimes the
|
95
|
+
* vertical stems may be only partially black. In this context,
|
96
|
+
* `antialiasing' means that stems are not positioned exactly on pixel
|
97
|
+
* borders, causing a fuzzy appearance.
|
98
|
+
*
|
99
|
+
* There are two principles behind this approach.
|
100
|
+
*
|
101
|
+
* 1) No hinting in the horizontal direction: Unlike `superhinted'
|
102
|
+
* TrueType, which changes glyph widths to accommodate regular
|
103
|
+
* inter-glyph spacing, Adobe's approach is `faithful to the design' in
|
104
|
+
* representing both the glyph width and the inter-glyph spacing
|
105
|
+
* designed for the font. This makes the screen display as close as it
|
106
|
+
* can be to the result one would get with infinite resolution, while
|
107
|
+
* preserving what is considered the key characteristics of each glyph.
|
108
|
+
* Note that the distances between unhinted and grid-fitted positions at
|
109
|
+
* small sizes are comparable to kerning values and thus would be
|
110
|
+
* noticeable (and distracting) while reading if hinting were applied.
|
111
|
+
*
|
112
|
+
* One of the reasons to not hint horizontally is antialiasing for LCD
|
113
|
+
* screens: The pixel geometry of modern displays supplies three
|
114
|
+
* vertical subpixels as the eye moves horizontally across each visible
|
115
|
+
* pixel. On devices where we can be certain this characteristic is
|
116
|
+
* present a rasterizer can take advantage of the subpixels to add
|
117
|
+
* increments of weight. In Western writing systems this turns out to
|
118
|
+
* be the more critical direction anyway; the weights and spacing of
|
119
|
+
* vertical stems (see above) are central to Armenian, Cyrillic, Greek,
|
120
|
+
* and Latin type designs. Even when the rasterizer uses greyscale
|
121
|
+
* antialiasing instead of color (a necessary compromise when one
|
122
|
+
* doesn't know the screen characteristics), the unhinted vertical
|
123
|
+
* features preserve the design's weight and spacing much better than
|
124
|
+
* aliased type would.
|
125
|
+
*
|
126
|
+
* 2) Alignment in the vertical direction: Weights and spacing along the
|
127
|
+
* y~axis are less critical; what is much more important is the visual
|
128
|
+
* alignment of related features (like cap-height and x-height). The
|
129
|
+
* sense of alignment for these is enhanced by the sharpness of grid-fit
|
130
|
+
* edges, while the cruder vertical resolution (full pixels instead of
|
131
|
+
* 1/3 pixels) is less of a problem.
|
132
|
+
*
|
133
|
+
* On the technical side, horizontal alignment zones for ascender,
|
134
|
+
* x-height, and other important height values (traditionally called
|
135
|
+
* `blue zones') as defined in the font are positioned independently,
|
136
|
+
* each being rounded to the nearest pixel edge, taking care of
|
137
|
+
* overshoot suppression at small sizes, stem darkening, and scaling.
|
138
|
+
*
|
139
|
+
* Hstems (this is, hint values defined in the font to help align
|
140
|
+
* horizontal features) that fall within a blue zone are said to be
|
141
|
+
* `captured' and are aligned to that zone. Uncaptured stems are moved
|
142
|
+
* in one of four ways, top edge up or down, bottom edge up or down.
|
143
|
+
* Unless there are conflicting hstems, the smallest movement is taken
|
144
|
+
* to minimize distortion.
|
145
|
+
*
|
146
|
+
*/
|
147
|
+
|
148
|
+
|
149
|
+
/**************************************************************************
|
150
|
+
*
|
151
|
+
* @section:
|
152
|
+
* pcf_driver
|
153
|
+
*
|
154
|
+
* @title:
|
155
|
+
* The PCF driver
|
156
|
+
*
|
157
|
+
* @abstract:
|
158
|
+
* Controlling the PCF driver module.
|
159
|
+
*
|
160
|
+
* @description:
|
161
|
+
* While FreeType's PCF driver doesn't expose API functions by itself,
|
162
|
+
* it is possible to control its behaviour with @FT_Property_Set and
|
163
|
+
* @FT_Property_Get. Right now, there is a single property
|
164
|
+
* @no-long-family-names available if FreeType is compiled with
|
165
|
+
* PCF_CONFIG_OPTION_LONG_FAMILY_NAMES.
|
166
|
+
*
|
167
|
+
* The PCF driver's module name is `pcf'.
|
168
|
+
*
|
169
|
+
*/
|
170
|
+
|
171
|
+
|
172
|
+
/**************************************************************************
|
173
|
+
*
|
174
|
+
* @section:
|
175
|
+
* t1_cid_driver
|
176
|
+
*
|
177
|
+
* @title:
|
178
|
+
* The Type 1 and CID drivers
|
179
|
+
*
|
180
|
+
* @abstract:
|
181
|
+
* Controlling the Type~1 and CID driver modules.
|
182
|
+
*
|
183
|
+
* @description:
|
184
|
+
* It is possible to control the behaviour of FreeType's Type~1 and
|
185
|
+
* Type~1 CID drivers with @FT_Property_Set and @FT_Property_Get.
|
186
|
+
*
|
187
|
+
* Behind the scenes, both drivers use the Adobe CFF engine for hinting;
|
188
|
+
* however, the used properties must be specified separately.
|
189
|
+
*
|
190
|
+
* The Type~1 driver's module name is `type1'; the CID driver's module
|
191
|
+
* name is `t1cid'.
|
192
|
+
*
|
193
|
+
* Available properties are @hinting-engine, @no-stem-darkening,
|
194
|
+
* @darkening-parameters, and @random-seed, as documented in the
|
195
|
+
* @properties section.
|
196
|
+
*
|
197
|
+
* Please see the @cff_driver section for more details on the new
|
198
|
+
* hinting engine.
|
199
|
+
*
|
200
|
+
*/
|
201
|
+
|
202
|
+
|
203
|
+
/**************************************************************************
|
204
|
+
*
|
205
|
+
* @section:
|
206
|
+
* tt_driver
|
207
|
+
*
|
208
|
+
* @title:
|
209
|
+
* The TrueType driver
|
210
|
+
*
|
211
|
+
* @abstract:
|
212
|
+
* Controlling the TrueType driver module.
|
213
|
+
*
|
214
|
+
* @description:
|
215
|
+
* While FreeType's TrueType driver doesn't expose API functions by
|
216
|
+
* itself, it is possible to control its behaviour with @FT_Property_Set
|
217
|
+
* and @FT_Property_Get. The following lists the available properties
|
218
|
+
* together with the necessary macros and structures.
|
219
|
+
*
|
220
|
+
* The TrueType driver's module name is `truetype'.
|
221
|
+
*
|
222
|
+
* A single property @interpreter-version is available, as documented in
|
223
|
+
* the @properties section.
|
224
|
+
*
|
225
|
+
* We start with a list of definitions, kindly provided by Greg
|
226
|
+
* Hitchcock.
|
227
|
+
*
|
228
|
+
* _Bi-Level_ _Rendering_
|
229
|
+
*
|
230
|
+
* Monochromatic rendering, exclusively used in the early days of
|
231
|
+
* TrueType by both Apple and Microsoft. Microsoft's GDI interface
|
232
|
+
* supported hinting of the right-side bearing point, such that the
|
233
|
+
* advance width could be non-linear. Most often this was done to
|
234
|
+
* achieve some level of glyph symmetry. To enable reasonable
|
235
|
+
* performance (e.g., not having to run hinting on all glyphs just to
|
236
|
+
* get the widths) there was a bit in the head table indicating if the
|
237
|
+
* side bearing was hinted, and additional tables, `hdmx' and `LTSH', to
|
238
|
+
* cache hinting widths across multiple sizes and device aspect ratios.
|
239
|
+
*
|
240
|
+
* _Font_ _Smoothing_
|
241
|
+
*
|
242
|
+
* Microsoft's GDI implementation of anti-aliasing. Not traditional
|
243
|
+
* anti-aliasing as the outlines were hinted before the sampling. The
|
244
|
+
* widths matched the bi-level rendering.
|
245
|
+
*
|
246
|
+
* _ClearType_ _Rendering_
|
247
|
+
*
|
248
|
+
* Technique that uses physical subpixels to improve rendering on LCD
|
249
|
+
* (and other) displays. Because of the higher resolution, many methods
|
250
|
+
* of improving symmetry in glyphs through hinting the right-side
|
251
|
+
* bearing were no longer necessary. This lead to what GDI calls
|
252
|
+
* `natural widths' ClearType, see
|
253
|
+
* http://www.beatstamm.com/typography/RTRCh4.htm#Sec21. Since hinting
|
254
|
+
* has extra resolution, most non-linearity went away, but it is still
|
255
|
+
* possible for hints to change the advance widths in this mode.
|
256
|
+
*
|
257
|
+
* _ClearType_ _Compatible_ _Widths_
|
258
|
+
*
|
259
|
+
* One of the earliest challenges with ClearType was allowing the
|
260
|
+
* implementation in GDI to be selected without requiring all UI and
|
261
|
+
* documents to reflow. To address this, a compatible method of
|
262
|
+
* rendering ClearType was added where the font hints are executed once
|
263
|
+
* to determine the width in bi-level rendering, and then re-run in
|
264
|
+
* ClearType, with the difference in widths being absorbed in the font
|
265
|
+
* hints for ClearType (mostly in the white space of hints); see
|
266
|
+
* http://www.beatstamm.com/typography/RTRCh4.htm#Sec20. Somewhat by
|
267
|
+
* definition, compatible width ClearType allows for non-linear widths,
|
268
|
+
* but only when the bi-level version has non-linear widths.
|
269
|
+
*
|
270
|
+
* _ClearType_ _Subpixel_ _Positioning_
|
271
|
+
*
|
272
|
+
* One of the nice benefits of ClearType is the ability to more crisply
|
273
|
+
* display fractional widths; unfortunately, the GDI model of integer
|
274
|
+
* bitmaps did not support this. However, the WPF and Direct Write
|
275
|
+
* frameworks do support fractional widths. DWrite calls this `natural
|
276
|
+
* mode', not to be confused with GDI's `natural widths'. Subpixel
|
277
|
+
* positioning, in the current implementation of Direct Write,
|
278
|
+
* unfortunately does not support hinted advance widths, see
|
279
|
+
* http://www.beatstamm.com/typography/RTRCh4.htm#Sec22. Note that the
|
280
|
+
* TrueType interpreter fully allows the advance width to be adjusted in
|
281
|
+
* this mode, just the DWrite client will ignore those changes.
|
282
|
+
*
|
283
|
+
* _ClearType_ _Backward_ _Compatibility_
|
284
|
+
*
|
285
|
+
* This is a set of exceptions made in the TrueType interpreter to
|
286
|
+
* minimize hinting techniques that were problematic with the extra
|
287
|
+
* resolution of ClearType; see
|
288
|
+
* http://www.beatstamm.com/typography/RTRCh4.htm#Sec1 and
|
289
|
+
* https://www.microsoft.com/typography/cleartype/truetypecleartype.aspx.
|
290
|
+
* This technique is not to be confused with ClearType compatible
|
291
|
+
* widths. ClearType backward compatibility has no direct impact on
|
292
|
+
* changing advance widths, but there might be an indirect impact on
|
293
|
+
* disabling some deltas. This could be worked around in backward
|
294
|
+
* compatibility mode.
|
295
|
+
*
|
296
|
+
* _Native_ _ClearType_ _Mode_
|
297
|
+
*
|
298
|
+
* (Not to be confused with `natural widths'.) This mode removes all
|
299
|
+
* the exceptions in the TrueType interpreter when running with
|
300
|
+
* ClearType. Any issues on widths would still apply, though.
|
301
|
+
*
|
302
|
+
*/
|
303
|
+
|
304
|
+
|
305
|
+
/**************************************************************************
|
306
|
+
*
|
307
|
+
* @section:
|
308
|
+
* properties
|
309
|
+
*
|
310
|
+
* @title:
|
311
|
+
* Driver properties
|
312
|
+
*
|
313
|
+
* @abstract:
|
314
|
+
* Controlling driver modules.
|
315
|
+
*
|
316
|
+
* @description:
|
317
|
+
* Driver modules can be controlled by setting and unsetting properties,
|
318
|
+
* using the functions @FT_Property_Set and @FT_Property_Get. This
|
319
|
+
* section documents the available properties, together with auxiliary
|
320
|
+
* macros and structures.
|
321
|
+
*
|
322
|
+
*/
|
323
|
+
|
324
|
+
|
325
|
+
/**************************************************************************
|
326
|
+
*
|
327
|
+
* @enum:
|
328
|
+
* FT_HINTING_XXX
|
329
|
+
*
|
330
|
+
* @description:
|
331
|
+
* A list of constants used for the @hinting-engine property to
|
332
|
+
* select the hinting engine for CFF, Type~1, and CID fonts.
|
333
|
+
*
|
334
|
+
* @values:
|
335
|
+
* FT_HINTING_FREETYPE ::
|
336
|
+
* Use the old FreeType hinting engine.
|
337
|
+
*
|
338
|
+
* FT_HINTING_ADOBE ::
|
339
|
+
* Use the hinting engine contributed by Adobe.
|
340
|
+
*
|
341
|
+
* @since:
|
342
|
+
* 2.9
|
343
|
+
*
|
344
|
+
*/
|
345
|
+
#define FT_HINTING_FREETYPE 0
|
346
|
+
#define FT_HINTING_ADOBE 1
|
347
|
+
|
348
|
+
/* these constants (introduced in 2.4.12) are deprecated */
|
349
|
+
#define FT_CFF_HINTING_FREETYPE FT_HINTING_FREETYPE
|
350
|
+
#define FT_CFF_HINTING_ADOBE FT_HINTING_ADOBE
|
351
|
+
|
352
|
+
|
353
|
+
/**************************************************************************
|
354
|
+
*
|
355
|
+
* @property:
|
356
|
+
* hinting-engine
|
357
|
+
*
|
358
|
+
* @description:
|
359
|
+
* Thanks to Adobe, which contributed a new hinting (and parsing)
|
360
|
+
* engine, an application can select between `freetype' and `adobe' if
|
361
|
+
* compiled with CFF_CONFIG_OPTION_OLD_ENGINE. If this configuration
|
362
|
+
* macro isn't defined, `hinting-engine' does nothing.
|
363
|
+
*
|
364
|
+
* The same holds for the Type~1 and CID modules if compiled with
|
365
|
+
* T1_CONFIG_OPTION_OLD_ENGINE.
|
366
|
+
*
|
367
|
+
* For the `cff' module, the default engine is `freetype' if
|
368
|
+
* CFF_CONFIG_OPTION_OLD_ENGINE is defined, and `adobe' otherwise.
|
369
|
+
*
|
370
|
+
* For both the `type1' and `t1cid' modules, the default engine is
|
371
|
+
* `freetype' if T1_CONFIG_OPTION_OLD_ENGINE is defined, and `adobe'
|
372
|
+
* otherwise.
|
373
|
+
*
|
374
|
+
* The following example code demonstrates how to select Adobe's hinting
|
375
|
+
* engine for the `cff' module (omitting the error handling).
|
376
|
+
*
|
377
|
+
* {
|
378
|
+
* FT_Library library;
|
379
|
+
* FT_UInt hinting_engine = FT_CFF_HINTING_ADOBE;
|
380
|
+
*
|
381
|
+
*
|
382
|
+
* FT_Init_FreeType( &library );
|
383
|
+
*
|
384
|
+
* FT_Property_Set( library, "cff",
|
385
|
+
* "hinting-engine", &hinting_engine );
|
386
|
+
* }
|
387
|
+
*
|
388
|
+
* @note:
|
389
|
+
* This property can be used with @FT_Property_Get also.
|
390
|
+
*
|
391
|
+
* This property can be set via the `FREETYPE_PROPERTIES' environment
|
392
|
+
* variable (using values `adobe' or `freetype').
|
393
|
+
*
|
394
|
+
* @since:
|
395
|
+
* 2.4.12 (for `cff' module)
|
396
|
+
*
|
397
|
+
* 2.9 (for `type1' and `t1cid' modules)
|
398
|
+
*
|
399
|
+
*/
|
400
|
+
|
401
|
+
|
402
|
+
/**************************************************************************
|
403
|
+
*
|
404
|
+
* @property:
|
405
|
+
* no-stem-darkening
|
406
|
+
*
|
407
|
+
* @description:
|
408
|
+
* All glyphs that pass through the auto-hinter will be emboldened
|
409
|
+
* unless this property is set to TRUE. The same is true for the CFF,
|
410
|
+
* Type~1, and CID font modules if the `Adobe' engine is selected (which
|
411
|
+
* is the default).
|
412
|
+
*
|
413
|
+
* Stem darkening emboldens glyphs at smaller sizes to make them more
|
414
|
+
* readable on common low-DPI screens when using linear alpha blending
|
415
|
+
* and gamma correction, see @FT_Render_Glyph. When not using linear
|
416
|
+
* alpha blending and gamma correction, glyphs will appear heavy and
|
417
|
+
* fuzzy!
|
418
|
+
*
|
419
|
+
* Gamma correction essentially lightens fonts since shades of grey are
|
420
|
+
* shifted to higher pixel values (=~higher brightness) to match the
|
421
|
+
* original intention to the reality of our screens. The side-effect is
|
422
|
+
* that glyphs `thin out'. Mac OS~X and Adobe's proprietary font
|
423
|
+
* rendering library implement a counter-measure: stem darkening at
|
424
|
+
* smaller sizes where shades of gray dominate. By emboldening a glyph
|
425
|
+
* slightly in relation to its pixel size, individual pixels get higher
|
426
|
+
* coverage of filled-in outlines and are therefore `blacker'. This
|
427
|
+
* counteracts the `thinning out' of glyphs, making text remain readable
|
428
|
+
* at smaller sizes.
|
429
|
+
*
|
430
|
+
* By default, the Adobe engines for CFF, Type~1, and CID fonts darken
|
431
|
+
* stems at smaller sizes, regardless of hinting, to enhance contrast.
|
432
|
+
* Setting this property, stem darkening gets switched off.
|
433
|
+
*
|
434
|
+
* For the auto-hinter, stem-darkening is experimental currently and
|
435
|
+
* thus switched off by default (this is, `no-stem-darkening' is set to
|
436
|
+
* TRUE by default). Total consistency with the CFF driver is not
|
437
|
+
* achieved right now because the emboldening method differs and glyphs
|
438
|
+
* must be scaled down on the Y-axis to keep outline points inside their
|
439
|
+
* precomputed blue zones. The smaller the size (especially 9ppem and
|
440
|
+
* down), the higher the loss of emboldening versus the CFF driver.
|
441
|
+
*
|
442
|
+
* Note that stem darkening is never applied if @FT_LOAD_NO_SCALE is
|
443
|
+
* set.
|
444
|
+
*
|
445
|
+
* {
|
446
|
+
* FT_Library library;
|
447
|
+
* FT_Bool no_stem_darkening = TRUE;
|
448
|
+
*
|
449
|
+
*
|
450
|
+
* FT_Init_FreeType( &library );
|
451
|
+
*
|
452
|
+
* FT_Property_Set( library, "cff",
|
453
|
+
* "no-stem-darkening", &no_stem_darkening );
|
454
|
+
* }
|
455
|
+
*
|
456
|
+
* @note:
|
457
|
+
* This property can be used with @FT_Property_Get also.
|
458
|
+
*
|
459
|
+
* This property can be set via the `FREETYPE_PROPERTIES' environment
|
460
|
+
* variable (using values 1 and 0 for `on' and `off', respectively).
|
461
|
+
* It can also be set per face using @FT_Face_Properties with
|
462
|
+
* @FT_PARAM_TAG_STEM_DARKENING.
|
463
|
+
*
|
464
|
+
* @since:
|
465
|
+
* 2.4.12 (for `cff' module)
|
466
|
+
*
|
467
|
+
* 2.6.2 (for `autofitter' module)
|
468
|
+
*
|
469
|
+
* 2.9 (for `type1' and `t1cid' modules)
|
470
|
+
*
|
471
|
+
*/
|
472
|
+
|
473
|
+
|
474
|
+
/**************************************************************************
|
475
|
+
*
|
476
|
+
* @property:
|
477
|
+
* darkening-parameters
|
478
|
+
*
|
479
|
+
* @description:
|
480
|
+
* By default, the Adobe hinting engine, as used by the CFF, Type~1, and
|
481
|
+
* CID font drivers, darkens stems as follows (if the
|
482
|
+
* `no-stem-darkening' property isn't set):
|
483
|
+
*
|
484
|
+
* {
|
485
|
+
* stem width <= 0.5px: darkening amount = 0.4px
|
486
|
+
* stem width = 1px: darkening amount = 0.275px
|
487
|
+
* stem width = 1.667px: darkening amount = 0.275px
|
488
|
+
* stem width >= 2.333px: darkening amount = 0px
|
489
|
+
* }
|
490
|
+
*
|
491
|
+
* and piecewise linear in-between. At configuration time, these four
|
492
|
+
* control points can be set with the macro
|
493
|
+
* `CFF_CONFIG_OPTION_DARKENING_PARAMETERS'; the CFF, Type~1, and CID
|
494
|
+
* drivers share these values. At runtime, the control points can be
|
495
|
+
* changed using the `darkening-parameters' property, as the following
|
496
|
+
* example demonstrates for the Type~1 driver.
|
497
|
+
*
|
498
|
+
* {
|
499
|
+
* FT_Library library;
|
500
|
+
* FT_Int darken_params[8] = { 500, 300, // x1, y1
|
501
|
+
* 1000, 200, // x2, y2
|
502
|
+
* 1500, 100, // x3, y3
|
503
|
+
* 2000, 0 }; // x4, y4
|
504
|
+
*
|
505
|
+
*
|
506
|
+
* FT_Init_FreeType( &library );
|
507
|
+
*
|
508
|
+
* FT_Property_Set( library, "type1",
|
509
|
+
* "darkening-parameters", darken_params );
|
510
|
+
* }
|
511
|
+
*
|
512
|
+
* The x~values give the stem width, and the y~values the darkening
|
513
|
+
* amount. The unit is 1000th of pixels. All coordinate values must be
|
514
|
+
* positive; the x~values must be monotonically increasing; the
|
515
|
+
* y~values must be monotonically decreasing and smaller than or
|
516
|
+
* equal to 500 (corresponding to half a pixel); the slope of each
|
517
|
+
* linear piece must be shallower than -1 (e.g., -.4).
|
518
|
+
*
|
519
|
+
* The auto-hinter provides this property, too, as an experimental
|
520
|
+
* feature. See @no-stem-darkening for more.
|
521
|
+
*
|
522
|
+
* @note:
|
523
|
+
* This property can be used with @FT_Property_Get also.
|
524
|
+
*
|
525
|
+
* This property can be set via the `FREETYPE_PROPERTIES' environment
|
526
|
+
* variable, using eight comma-separated integers without spaces. Here
|
527
|
+
* the above example, using `\' to break the line for readability.
|
528
|
+
*
|
529
|
+
* {
|
530
|
+
* FREETYPE_PROPERTIES=\
|
531
|
+
* type1:darkening-parameters=500,300,1000,200,1500,100,2000,0
|
532
|
+
* }
|
533
|
+
*
|
534
|
+
* @since:
|
535
|
+
* 2.5.1 (for `cff' module)
|
536
|
+
*
|
537
|
+
* 2.6.2 (for `autofitter' module)
|
538
|
+
*
|
539
|
+
* 2.9 (for `type1' and `t1cid' modules)
|
540
|
+
*
|
541
|
+
*/
|
542
|
+
|
543
|
+
|
544
|
+
/**************************************************************************
|
545
|
+
*
|
546
|
+
* @property:
|
547
|
+
* random-seed
|
548
|
+
*
|
549
|
+
* @description:
|
550
|
+
* By default, the seed value for the CFF `random' operator and the
|
551
|
+
* similar `0 28 callothersubr pop' command for the Type~1 and CID
|
552
|
+
* drivers is set to a random value. However, mainly for debugging
|
553
|
+
* purposes, it is often necessary to use a known value as a seed so
|
554
|
+
* that the pseudo-random number sequences generated by `random' are
|
555
|
+
* repeatable.
|
556
|
+
*
|
557
|
+
* The `random-seed' property does that. Its argument is a signed 32bit
|
558
|
+
* integer; if the value is zero or negative, the seed given by the
|
559
|
+
* `intitialRandomSeed' private DICT operator in a CFF file gets used
|
560
|
+
* (or a default value if there is no such operator). If the value is
|
561
|
+
* positive, use it instead of `initialRandomSeed', which is
|
562
|
+
* consequently ignored.
|
563
|
+
*
|
564
|
+
* @note:
|
565
|
+
* This property can be set via the `FREETYPE_PROPERTIES' environment
|
566
|
+
* variable. It can also be set per face using @FT_Face_Properties with
|
567
|
+
* @FT_PARAM_TAG_RANDOM_SEED.
|
568
|
+
*
|
569
|
+
* @since:
|
570
|
+
* 2.8 (for `cff' module)
|
571
|
+
*
|
572
|
+
* 2.9 (for `type1' and `t1cid' modules)
|
573
|
+
*
|
574
|
+
*/
|
575
|
+
|
576
|
+
|
577
|
+
/**************************************************************************
|
578
|
+
*
|
579
|
+
* @property:
|
580
|
+
* no-long-family-names
|
581
|
+
*
|
582
|
+
* @description:
|
583
|
+
* If PCF_CONFIG_OPTION_LONG_FAMILY_NAMES is active while compiling
|
584
|
+
* FreeType, the PCF driver constructs long family names.
|
585
|
+
*
|
586
|
+
* There are many PCF fonts just called `Fixed' which look completely
|
587
|
+
* different, and which have nothing to do with each other. When
|
588
|
+
* selecting `Fixed' in KDE or Gnome one gets results that appear rather
|
589
|
+
* random, the style changes often if one changes the size and one
|
590
|
+
* cannot select some fonts at all. The improve this situation, the PCF
|
591
|
+
* module prepends the foundry name (plus a space) to the family name.
|
592
|
+
* It also checks whether there are `wide' characters; all put together,
|
593
|
+
* family names like `Sony Fixed' or `Misc Fixed Wide' are constructed.
|
594
|
+
*
|
595
|
+
* If `no-long-family-names' is set, this feature gets switched off.
|
596
|
+
*
|
597
|
+
* {
|
598
|
+
* FT_Library library;
|
599
|
+
* FT_Bool no_long_family_names = TRUE;
|
600
|
+
*
|
601
|
+
*
|
602
|
+
* FT_Init_FreeType( &library );
|
603
|
+
*
|
604
|
+
* FT_Property_Set( library, "pcf",
|
605
|
+
* "no-long-family-names",
|
606
|
+
* &no_long_family_names );
|
607
|
+
* }
|
608
|
+
*
|
609
|
+
* @note:
|
610
|
+
* This property can be used with @FT_Property_Get also.
|
611
|
+
*
|
612
|
+
* This property can be set via the `FREETYPE_PROPERTIES' environment
|
613
|
+
* variable (using values 1 and 0 for `on' and `off', respectively).
|
614
|
+
*
|
615
|
+
* @since:
|
616
|
+
* 2.8
|
617
|
+
*/
|
618
|
+
|
619
|
+
|
620
|
+
/**************************************************************************
|
621
|
+
*
|
622
|
+
* @enum:
|
623
|
+
* TT_INTERPRETER_VERSION_XXX
|
624
|
+
*
|
625
|
+
* @description:
|
626
|
+
* A list of constants used for the @interpreter-version property to
|
627
|
+
* select the hinting engine for Truetype fonts.
|
628
|
+
*
|
629
|
+
* The numeric value in the constant names represents the version
|
630
|
+
* number as returned by the `GETINFO' bytecode instruction.
|
631
|
+
*
|
632
|
+
* @values:
|
633
|
+
* TT_INTERPRETER_VERSION_35 ::
|
634
|
+
* Version~35 corresponds to MS rasterizer v.1.7 as used e.g. in
|
635
|
+
* Windows~98; only grayscale and B/W rasterizing is supported.
|
636
|
+
*
|
637
|
+
* TT_INTERPRETER_VERSION_38 ::
|
638
|
+
* Version~38 corresponds to MS rasterizer v.1.9; it is roughly
|
639
|
+
* equivalent to the hinting provided by DirectWrite ClearType (as can
|
640
|
+
* be found, for example, in the Internet Explorer~9 running on
|
641
|
+
* Windows~7). It is used in FreeType to select the `Infinality'
|
642
|
+
* subpixel hinting code. The code may be removed in a future
|
643
|
+
* version.
|
644
|
+
*
|
645
|
+
* TT_INTERPRETER_VERSION_40 ::
|
646
|
+
* Version~40 corresponds to MS rasterizer v.2.1; it is roughly
|
647
|
+
* equivalent to the hinting provided by DirectWrite ClearType (as can
|
648
|
+
* be found, for example, in Microsoft's Edge Browser on Windows~10).
|
649
|
+
* It is used in FreeType to select the `minimal' subpixel hinting
|
650
|
+
* code, a stripped-down and higher performance version of the
|
651
|
+
* `Infinality' code.
|
652
|
+
*
|
653
|
+
* @note:
|
654
|
+
* This property controls the behaviour of the bytecode interpreter
|
655
|
+
* and thus how outlines get hinted. It does *not* control how glyph
|
656
|
+
* get rasterized! In particular, it does not control subpixel color
|
657
|
+
* filtering.
|
658
|
+
*
|
659
|
+
* If FreeType has not been compiled with the configuration option
|
660
|
+
* TT_CONFIG_OPTION_SUBPIXEL_HINTING, selecting version~38 or~40 causes
|
661
|
+
* an `FT_Err_Unimplemented_Feature' error.
|
662
|
+
*
|
663
|
+
* Depending on the graphics framework, Microsoft uses different
|
664
|
+
* bytecode and rendering engines. As a consequence, the version
|
665
|
+
* numbers returned by a call to the `GETINFO' bytecode instruction are
|
666
|
+
* more convoluted than desired.
|
667
|
+
*
|
668
|
+
* Here are two tables that try to shed some light on the possible
|
669
|
+
* values for the MS rasterizer engine, together with the additional
|
670
|
+
* features introduced by it.
|
671
|
+
*
|
672
|
+
* {
|
673
|
+
* GETINFO framework version feature
|
674
|
+
* -------------------------------------------------------------------
|
675
|
+
* 3 GDI (Win 3.1), v1.0 16-bit, first version
|
676
|
+
* TrueImage
|
677
|
+
* 33 GDI (Win NT 3.1), v1.5 32-bit
|
678
|
+
* HP Laserjet
|
679
|
+
* 34 GDI (Win 95) v1.6 font smoothing,
|
680
|
+
* new SCANTYPE opcode
|
681
|
+
* 35 GDI (Win 98/2000) v1.7 (UN)SCALED_COMPONENT_OFFSET
|
682
|
+
* bits in composite glyphs
|
683
|
+
* 36 MGDI (Win CE 2) v1.6+ classic ClearType
|
684
|
+
* 37 GDI (XP and later), v1.8 ClearType
|
685
|
+
* GDI+ old (before Vista)
|
686
|
+
* 38 GDI+ old (Vista, Win 7), v1.9 subpixel ClearType,
|
687
|
+
* WPF Y-direction ClearType,
|
688
|
+
* additional error checking
|
689
|
+
* 39 DWrite (before Win 8) v2.0 subpixel ClearType flags
|
690
|
+
* in GETINFO opcode,
|
691
|
+
* bug fixes
|
692
|
+
* 40 GDI+ (after Win 7), v2.1 Y-direction ClearType flag
|
693
|
+
* DWrite (Win 8) in GETINFO opcode,
|
694
|
+
* Gray ClearType
|
695
|
+
* }
|
696
|
+
*
|
697
|
+
* The `version' field gives a rough orientation only, since some
|
698
|
+
* applications provided certain features much earlier (as an example,
|
699
|
+
* Microsoft Reader used subpixel and Y-direction ClearType already in
|
700
|
+
* Windows 2000). Similarly, updates to a given framework might include
|
701
|
+
* improved hinting support.
|
702
|
+
*
|
703
|
+
* {
|
704
|
+
* version sampling rendering comment
|
705
|
+
* x y x y
|
706
|
+
* --------------------------------------------------------------
|
707
|
+
* v1.0 normal normal B/W B/W bi-level
|
708
|
+
* v1.6 high high gray gray grayscale
|
709
|
+
* v1.8 high normal color-filter B/W (GDI) ClearType
|
710
|
+
* v1.9 high high color-filter gray Color ClearType
|
711
|
+
* v2.1 high normal gray B/W Gray ClearType
|
712
|
+
* v2.1 high high gray gray Gray ClearType
|
713
|
+
* }
|
714
|
+
*
|
715
|
+
* Color and Gray ClearType are the two available variants of
|
716
|
+
* `Y-direction ClearType', meaning grayscale rasterization along the
|
717
|
+
* Y-direction; the name used in the TrueType specification for this
|
718
|
+
* feature is `symmetric smoothing'. `Classic ClearType' is the
|
719
|
+
* original algorithm used before introducing a modified version in
|
720
|
+
* Win~XP. Another name for v1.6's grayscale rendering is `font
|
721
|
+
* smoothing', and `Color ClearType' is sometimes also called `DWrite
|
722
|
+
* ClearType'. To differentiate between today's Color ClearType and the
|
723
|
+
* earlier ClearType variant with B/W rendering along the vertical axis,
|
724
|
+
* the latter is sometimes called `GDI ClearType'.
|
725
|
+
*
|
726
|
+
* `Normal' and `high' sampling describe the (virtual) resolution to
|
727
|
+
* access the rasterized outline after the hinting process. `Normal'
|
728
|
+
* means 1 sample per grid line (i.e., B/W). In the current Microsoft
|
729
|
+
* implementation, `high' means an extra virtual resolution of 16x16 (or
|
730
|
+
* 16x1) grid lines per pixel for bytecode instructions like `MIRP'.
|
731
|
+
* After hinting, these 16 grid lines are mapped to 6x5 (or 6x1) grid
|
732
|
+
* lines for color filtering if Color ClearType is activated.
|
733
|
+
*
|
734
|
+
* Note that `Gray ClearType' is essentially the same as v1.6's
|
735
|
+
* grayscale rendering. However, the GETINFO instruction handles it
|
736
|
+
* differently: v1.6 returns bit~12 (hinting for grayscale), while v2.1
|
737
|
+
* returns bits~13 (hinting for ClearType), 18 (symmetrical smoothing),
|
738
|
+
* and~19 (Gray ClearType). Also, this mode respects bits 2 and~3 for
|
739
|
+
* the version~1 gasp table exclusively (like Color ClearType), while
|
740
|
+
* v1.6 only respects the values of version~0 (bits 0 and~1).
|
741
|
+
*
|
742
|
+
* Keep in mind that the features of the above interpreter versions
|
743
|
+
* might not map exactly to FreeType features or behavior because it is
|
744
|
+
* a fundamentally different library with different internals.
|
745
|
+
*
|
746
|
+
*/
|
747
|
+
#define TT_INTERPRETER_VERSION_35 35
|
748
|
+
#define TT_INTERPRETER_VERSION_38 38
|
749
|
+
#define TT_INTERPRETER_VERSION_40 40
|
750
|
+
|
751
|
+
|
752
|
+
/**************************************************************************
|
753
|
+
*
|
754
|
+
* @property:
|
755
|
+
* interpreter-version
|
756
|
+
*
|
757
|
+
* @description:
|
758
|
+
* Currently, three versions are available, two representing the
|
759
|
+
* bytecode interpreter with subpixel hinting support (old `Infinality'
|
760
|
+
* code and new stripped-down and higher performance `minimal' code) and
|
761
|
+
* one without, respectively. The default is subpixel support if
|
762
|
+
* TT_CONFIG_OPTION_SUBPIXEL_HINTING is defined, and no subpixel support
|
763
|
+
* otherwise (since it isn't available then).
|
764
|
+
*
|
765
|
+
* If subpixel hinting is on, many TrueType bytecode instructions behave
|
766
|
+
* differently compared to B/W or grayscale rendering (except if `native
|
767
|
+
* ClearType' is selected by the font). Microsoft's main idea is to
|
768
|
+
* render at a much increased horizontal resolution, then sampling down
|
769
|
+
* the created output to subpixel precision. However, many older fonts
|
770
|
+
* are not suited to this and must be specially taken care of by
|
771
|
+
* applying (hardcoded) tweaks in Microsoft's interpreter.
|
772
|
+
*
|
773
|
+
* Details on subpixel hinting and some of the necessary tweaks can be
|
774
|
+
* found in Greg Hitchcock's whitepaper at
|
775
|
+
* `https://www.microsoft.com/typography/cleartype/truetypecleartype.aspx'.
|
776
|
+
* Note that FreeType currently doesn't really `subpixel hint' (6x1, 6x2,
|
777
|
+
* or 6x5 supersampling) like discussed in the paper. Depending on the
|
778
|
+
* chosen interpreter, it simply ignores instructions on vertical stems
|
779
|
+
* to arrive at very similar results.
|
780
|
+
*
|
781
|
+
* The following example code demonstrates how to deactivate subpixel
|
782
|
+
* hinting (omitting the error handling).
|
783
|
+
*
|
784
|
+
* {
|
785
|
+
* FT_Library library;
|
786
|
+
* FT_Face face;
|
787
|
+
* FT_UInt interpreter_version = TT_INTERPRETER_VERSION_35;
|
788
|
+
*
|
789
|
+
*
|
790
|
+
* FT_Init_FreeType( &library );
|
791
|
+
*
|
792
|
+
* FT_Property_Set( library, "truetype",
|
793
|
+
* "interpreter-version",
|
794
|
+
* &interpreter_version );
|
795
|
+
* }
|
796
|
+
*
|
797
|
+
* @note:
|
798
|
+
* This property can be used with @FT_Property_Get also.
|
799
|
+
*
|
800
|
+
* This property can be set via the `FREETYPE_PROPERTIES' environment
|
801
|
+
* variable (using values `35', `38', or `40').
|
802
|
+
*
|
803
|
+
* @since:
|
804
|
+
* 2.5
|
805
|
+
*/
|
806
|
+
|
807
|
+
|
808
|
+
/**************************************************************************
|
809
|
+
*
|
810
|
+
* @property:
|
811
|
+
* glyph-to-script-map
|
812
|
+
*
|
813
|
+
* @description:
|
814
|
+
* *Experimental* *only*
|
815
|
+
*
|
816
|
+
* The auto-hinter provides various script modules to hint glyphs.
|
817
|
+
* Examples of supported scripts are Latin or CJK. Before a glyph is
|
818
|
+
* auto-hinted, the Unicode character map of the font gets examined, and
|
819
|
+
* the script is then determined based on Unicode character ranges, see
|
820
|
+
* below.
|
821
|
+
*
|
822
|
+
* OpenType fonts, however, often provide much more glyphs than
|
823
|
+
* character codes (small caps, superscripts, ligatures, swashes, etc.),
|
824
|
+
* to be controlled by so-called `features'. Handling OpenType features
|
825
|
+
* can be quite complicated and thus needs a separate library on top of
|
826
|
+
* FreeType.
|
827
|
+
*
|
828
|
+
* The mapping between glyph indices and scripts (in the auto-hinter
|
829
|
+
* sense, see the @FT_AUTOHINTER_SCRIPT_XXX values) is stored as an
|
830
|
+
* array with `num_glyphs' elements, as found in the font's @FT_Face
|
831
|
+
* structure. The `glyph-to-script-map' property returns a pointer to
|
832
|
+
* this array, which can be modified as needed. Note that the
|
833
|
+
* modification should happen before the first glyph gets processed by
|
834
|
+
* the auto-hinter so that the global analysis of the font shapes
|
835
|
+
* actually uses the modified mapping.
|
836
|
+
*
|
837
|
+
* The following example code demonstrates how to access it (omitting
|
838
|
+
* the error handling).
|
839
|
+
*
|
840
|
+
* {
|
841
|
+
* FT_Library library;
|
842
|
+
* FT_Face face;
|
843
|
+
* FT_Prop_GlyphToScriptMap prop;
|
844
|
+
*
|
845
|
+
*
|
846
|
+
* FT_Init_FreeType( &library );
|
847
|
+
* FT_New_Face( library, "foo.ttf", 0, &face );
|
848
|
+
*
|
849
|
+
* prop.face = face;
|
850
|
+
*
|
851
|
+
* FT_Property_Get( library, "autofitter",
|
852
|
+
* "glyph-to-script-map", &prop );
|
853
|
+
*
|
854
|
+
* // adjust `prop.map' as needed right here
|
855
|
+
*
|
856
|
+
* FT_Load_Glyph( face, ..., FT_LOAD_FORCE_AUTOHINT );
|
857
|
+
* }
|
858
|
+
*
|
859
|
+
* @since:
|
860
|
+
* 2.4.11
|
861
|
+
*
|
862
|
+
*/
|
863
|
+
|
864
|
+
|
865
|
+
/**************************************************************************
|
866
|
+
*
|
867
|
+
* @enum:
|
868
|
+
* FT_AUTOHINTER_SCRIPT_XXX
|
869
|
+
*
|
870
|
+
* @description:
|
871
|
+
* *Experimental* *only*
|
872
|
+
*
|
873
|
+
* A list of constants used for the @glyph-to-script-map property to
|
874
|
+
* specify the script submodule the auto-hinter should use for hinting a
|
875
|
+
* particular glyph.
|
876
|
+
*
|
877
|
+
* @values:
|
878
|
+
* FT_AUTOHINTER_SCRIPT_NONE ::
|
879
|
+
* Don't auto-hint this glyph.
|
880
|
+
*
|
881
|
+
* FT_AUTOHINTER_SCRIPT_LATIN ::
|
882
|
+
* Apply the latin auto-hinter. For the auto-hinter, `latin' is a
|
883
|
+
* very broad term, including Cyrillic and Greek also since characters
|
884
|
+
* from those scripts share the same design constraints.
|
885
|
+
*
|
886
|
+
* By default, characters from the following Unicode ranges are
|
887
|
+
* assigned to this submodule.
|
888
|
+
*
|
889
|
+
* {
|
890
|
+
* U+0020 - U+007F // Basic Latin (no control characters)
|
891
|
+
* U+00A0 - U+00FF // Latin-1 Supplement (no control characters)
|
892
|
+
* U+0100 - U+017F // Latin Extended-A
|
893
|
+
* U+0180 - U+024F // Latin Extended-B
|
894
|
+
* U+0250 - U+02AF // IPA Extensions
|
895
|
+
* U+02B0 - U+02FF // Spacing Modifier Letters
|
896
|
+
* U+0300 - U+036F // Combining Diacritical Marks
|
897
|
+
* U+0370 - U+03FF // Greek and Coptic
|
898
|
+
* U+0400 - U+04FF // Cyrillic
|
899
|
+
* U+0500 - U+052F // Cyrillic Supplement
|
900
|
+
* U+1D00 - U+1D7F // Phonetic Extensions
|
901
|
+
* U+1D80 - U+1DBF // Phonetic Extensions Supplement
|
902
|
+
* U+1DC0 - U+1DFF // Combining Diacritical Marks Supplement
|
903
|
+
* U+1E00 - U+1EFF // Latin Extended Additional
|
904
|
+
* U+1F00 - U+1FFF // Greek Extended
|
905
|
+
* U+2000 - U+206F // General Punctuation
|
906
|
+
* U+2070 - U+209F // Superscripts and Subscripts
|
907
|
+
* U+20A0 - U+20CF // Currency Symbols
|
908
|
+
* U+2150 - U+218F // Number Forms
|
909
|
+
* U+2460 - U+24FF // Enclosed Alphanumerics
|
910
|
+
* U+2C60 - U+2C7F // Latin Extended-C
|
911
|
+
* U+2DE0 - U+2DFF // Cyrillic Extended-A
|
912
|
+
* U+2E00 - U+2E7F // Supplemental Punctuation
|
913
|
+
* U+A640 - U+A69F // Cyrillic Extended-B
|
914
|
+
* U+A720 - U+A7FF // Latin Extended-D
|
915
|
+
* U+FB00 - U+FB06 // Alphab. Present. Forms (Latin Ligatures)
|
916
|
+
* U+1D400 - U+1D7FF // Mathematical Alphanumeric Symbols
|
917
|
+
* U+1F100 - U+1F1FF // Enclosed Alphanumeric Supplement
|
918
|
+
* }
|
919
|
+
*
|
920
|
+
* FT_AUTOHINTER_SCRIPT_CJK ::
|
921
|
+
* Apply the CJK auto-hinter, covering Chinese, Japanese, Korean, old
|
922
|
+
* Vietnamese, and some other scripts.
|
923
|
+
*
|
924
|
+
* By default, characters from the following Unicode ranges are
|
925
|
+
* assigned to this submodule.
|
926
|
+
*
|
927
|
+
* {
|
928
|
+
* U+1100 - U+11FF // Hangul Jamo
|
929
|
+
* U+2E80 - U+2EFF // CJK Radicals Supplement
|
930
|
+
* U+2F00 - U+2FDF // Kangxi Radicals
|
931
|
+
* U+2FF0 - U+2FFF // Ideographic Description Characters
|
932
|
+
* U+3000 - U+303F // CJK Symbols and Punctuation
|
933
|
+
* U+3040 - U+309F // Hiragana
|
934
|
+
* U+30A0 - U+30FF // Katakana
|
935
|
+
* U+3100 - U+312F // Bopomofo
|
936
|
+
* U+3130 - U+318F // Hangul Compatibility Jamo
|
937
|
+
* U+3190 - U+319F // Kanbun
|
938
|
+
* U+31A0 - U+31BF // Bopomofo Extended
|
939
|
+
* U+31C0 - U+31EF // CJK Strokes
|
940
|
+
* U+31F0 - U+31FF // Katakana Phonetic Extensions
|
941
|
+
* U+3200 - U+32FF // Enclosed CJK Letters and Months
|
942
|
+
* U+3300 - U+33FF // CJK Compatibility
|
943
|
+
* U+3400 - U+4DBF // CJK Unified Ideographs Extension A
|
944
|
+
* U+4DC0 - U+4DFF // Yijing Hexagram Symbols
|
945
|
+
* U+4E00 - U+9FFF // CJK Unified Ideographs
|
946
|
+
* U+A960 - U+A97F // Hangul Jamo Extended-A
|
947
|
+
* U+AC00 - U+D7AF // Hangul Syllables
|
948
|
+
* U+D7B0 - U+D7FF // Hangul Jamo Extended-B
|
949
|
+
* U+F900 - U+FAFF // CJK Compatibility Ideographs
|
950
|
+
* U+FE10 - U+FE1F // Vertical forms
|
951
|
+
* U+FE30 - U+FE4F // CJK Compatibility Forms
|
952
|
+
* U+FF00 - U+FFEF // Halfwidth and Fullwidth Forms
|
953
|
+
* U+1B000 - U+1B0FF // Kana Supplement
|
954
|
+
* U+1D300 - U+1D35F // Tai Xuan Hing Symbols
|
955
|
+
* U+1F200 - U+1F2FF // Enclosed Ideographic Supplement
|
956
|
+
* U+20000 - U+2A6DF // CJK Unified Ideographs Extension B
|
957
|
+
* U+2A700 - U+2B73F // CJK Unified Ideographs Extension C
|
958
|
+
* U+2B740 - U+2B81F // CJK Unified Ideographs Extension D
|
959
|
+
* U+2F800 - U+2FA1F // CJK Compatibility Ideographs Supplement
|
960
|
+
* }
|
961
|
+
*
|
962
|
+
* FT_AUTOHINTER_SCRIPT_INDIC ::
|
963
|
+
* Apply the indic auto-hinter, covering all major scripts from the
|
964
|
+
* Indian sub-continent and some other related scripts like Thai, Lao,
|
965
|
+
* or Tibetan.
|
966
|
+
*
|
967
|
+
* By default, characters from the following Unicode ranges are
|
968
|
+
* assigned to this submodule.
|
969
|
+
*
|
970
|
+
* {
|
971
|
+
* U+0900 - U+0DFF // Indic Range
|
972
|
+
* U+0F00 - U+0FFF // Tibetan
|
973
|
+
* U+1900 - U+194F // Limbu
|
974
|
+
* U+1B80 - U+1BBF // Sundanese
|
975
|
+
* U+A800 - U+A82F // Syloti Nagri
|
976
|
+
* U+ABC0 - U+ABFF // Meetei Mayek
|
977
|
+
* U+11800 - U+118DF // Sharada
|
978
|
+
* }
|
979
|
+
*
|
980
|
+
* Note that currently Indic support is rudimentary only, missing blue
|
981
|
+
* zone support.
|
982
|
+
*
|
983
|
+
* @since:
|
984
|
+
* 2.4.11
|
985
|
+
*
|
986
|
+
*/
|
987
|
+
#define FT_AUTOHINTER_SCRIPT_NONE 0
|
988
|
+
#define FT_AUTOHINTER_SCRIPT_LATIN 1
|
989
|
+
#define FT_AUTOHINTER_SCRIPT_CJK 2
|
990
|
+
#define FT_AUTOHINTER_SCRIPT_INDIC 3
|
991
|
+
|
992
|
+
|
993
|
+
/**************************************************************************
|
994
|
+
*
|
995
|
+
* @struct:
|
996
|
+
* FT_Prop_GlyphToScriptMap
|
997
|
+
*
|
998
|
+
* @description:
|
999
|
+
* *Experimental* *only*
|
1000
|
+
*
|
1001
|
+
* The data exchange structure for the @glyph-to-script-map property.
|
1002
|
+
*
|
1003
|
+
* @since:
|
1004
|
+
* 2.4.11
|
1005
|
+
*
|
1006
|
+
*/
|
1007
|
+
typedef struct FT_Prop_GlyphToScriptMap_
|
1008
|
+
{
|
1009
|
+
FT_Face face;
|
1010
|
+
FT_UShort* map;
|
1011
|
+
|
1012
|
+
} FT_Prop_GlyphToScriptMap;
|
1013
|
+
|
1014
|
+
|
1015
|
+
/**************************************************************************
|
1016
|
+
*
|
1017
|
+
* @property:
|
1018
|
+
* fallback-script
|
1019
|
+
*
|
1020
|
+
* @description:
|
1021
|
+
* *Experimental* *only*
|
1022
|
+
*
|
1023
|
+
* If no auto-hinter script module can be assigned to a glyph, a
|
1024
|
+
* fallback script gets assigned to it (see also the
|
1025
|
+
* @glyph-to-script-map property). By default, this is
|
1026
|
+
* @FT_AUTOHINTER_SCRIPT_CJK. Using the `fallback-script' property,
|
1027
|
+
* this fallback value can be changed.
|
1028
|
+
*
|
1029
|
+
* {
|
1030
|
+
* FT_Library library;
|
1031
|
+
* FT_UInt fallback_script = FT_AUTOHINTER_SCRIPT_NONE;
|
1032
|
+
*
|
1033
|
+
*
|
1034
|
+
* FT_Init_FreeType( &library );
|
1035
|
+
*
|
1036
|
+
* FT_Property_Set( library, "autofitter",
|
1037
|
+
* "fallback-script", &fallback_script );
|
1038
|
+
* }
|
1039
|
+
*
|
1040
|
+
* @note:
|
1041
|
+
* This property can be used with @FT_Property_Get also.
|
1042
|
+
*
|
1043
|
+
* It's important to use the right timing for changing this value: The
|
1044
|
+
* creation of the glyph-to-script map that eventually uses the
|
1045
|
+
* fallback script value gets triggered either by setting or reading a
|
1046
|
+
* face-specific property like @glyph-to-script-map, or by auto-hinting
|
1047
|
+
* any glyph from that face. In particular, if you have already created
|
1048
|
+
* an @FT_Face structure but not loaded any glyph (using the
|
1049
|
+
* auto-hinter), a change of the fallback script will affect this face.
|
1050
|
+
*
|
1051
|
+
* @since:
|
1052
|
+
* 2.4.11
|
1053
|
+
*
|
1054
|
+
*/
|
1055
|
+
|
1056
|
+
|
1057
|
+
/**************************************************************************
|
1058
|
+
*
|
1059
|
+
* @property:
|
1060
|
+
* default-script
|
1061
|
+
*
|
1062
|
+
* @description:
|
1063
|
+
* *Experimental* *only*
|
1064
|
+
*
|
1065
|
+
* If FreeType gets compiled with FT_CONFIG_OPTION_USE_HARFBUZZ to make
|
1066
|
+
* the HarfBuzz library access OpenType features for getting better
|
1067
|
+
* glyph coverages, this property sets the (auto-fitter) script to be
|
1068
|
+
* used for the default (OpenType) script data of a font's GSUB table.
|
1069
|
+
* Features for the default script are intended for all scripts not
|
1070
|
+
* explicitly handled in GSUB; an example is a `dlig' feature,
|
1071
|
+
* containing the combination of the characters `T', `E', and `L' to
|
1072
|
+
* form a `TEL' ligature.
|
1073
|
+
*
|
1074
|
+
* By default, this is @FT_AUTOHINTER_SCRIPT_LATIN. Using the
|
1075
|
+
* `default-script' property, this default value can be changed.
|
1076
|
+
*
|
1077
|
+
* {
|
1078
|
+
* FT_Library library;
|
1079
|
+
* FT_UInt default_script = FT_AUTOHINTER_SCRIPT_NONE;
|
1080
|
+
*
|
1081
|
+
*
|
1082
|
+
* FT_Init_FreeType( &library );
|
1083
|
+
*
|
1084
|
+
* FT_Property_Set( library, "autofitter",
|
1085
|
+
* "default-script", &default_script );
|
1086
|
+
* }
|
1087
|
+
*
|
1088
|
+
* @note:
|
1089
|
+
* This property can be used with @FT_Property_Get also.
|
1090
|
+
*
|
1091
|
+
* It's important to use the right timing for changing this value: The
|
1092
|
+
* creation of the glyph-to-script map that eventually uses the
|
1093
|
+
* default script value gets triggered either by setting or reading a
|
1094
|
+
* face-specific property like @glyph-to-script-map, or by auto-hinting
|
1095
|
+
* any glyph from that face. In particular, if you have already created
|
1096
|
+
* an @FT_Face structure but not loaded any glyph (using the
|
1097
|
+
* auto-hinter), a change of the default script will affect this face.
|
1098
|
+
*
|
1099
|
+
* @since:
|
1100
|
+
* 2.5.3
|
1101
|
+
*
|
1102
|
+
*/
|
1103
|
+
|
1104
|
+
|
1105
|
+
/**************************************************************************
|
1106
|
+
*
|
1107
|
+
* @property:
|
1108
|
+
* increase-x-height
|
1109
|
+
*
|
1110
|
+
* @description:
|
1111
|
+
* For ppem values in the range 6~<= ppem <= `increase-x-height', round
|
1112
|
+
* up the font's x~height much more often than normally. If the value
|
1113
|
+
* is set to~0, which is the default, this feature is switched off. Use
|
1114
|
+
* this property to improve the legibility of small font sizes if
|
1115
|
+
* necessary.
|
1116
|
+
*
|
1117
|
+
* {
|
1118
|
+
* FT_Library library;
|
1119
|
+
* FT_Face face;
|
1120
|
+
* FT_Prop_IncreaseXHeight prop;
|
1121
|
+
*
|
1122
|
+
*
|
1123
|
+
* FT_Init_FreeType( &library );
|
1124
|
+
* FT_New_Face( library, "foo.ttf", 0, &face );
|
1125
|
+
* FT_Set_Char_Size( face, 10 * 64, 0, 72, 0 );
|
1126
|
+
*
|
1127
|
+
* prop.face = face;
|
1128
|
+
* prop.limit = 14;
|
1129
|
+
*
|
1130
|
+
* FT_Property_Set( library, "autofitter",
|
1131
|
+
* "increase-x-height", &prop );
|
1132
|
+
* }
|
1133
|
+
*
|
1134
|
+
* @note:
|
1135
|
+
* This property can be used with @FT_Property_Get also.
|
1136
|
+
*
|
1137
|
+
* Set this value right after calling @FT_Set_Char_Size, but before
|
1138
|
+
* loading any glyph (using the auto-hinter).
|
1139
|
+
*
|
1140
|
+
* @since:
|
1141
|
+
* 2.4.11
|
1142
|
+
*
|
1143
|
+
*/
|
1144
|
+
|
1145
|
+
|
1146
|
+
/**************************************************************************
|
1147
|
+
*
|
1148
|
+
* @struct:
|
1149
|
+
* FT_Prop_IncreaseXHeight
|
1150
|
+
*
|
1151
|
+
* @description:
|
1152
|
+
* The data exchange structure for the @increase-x-height property.
|
1153
|
+
*
|
1154
|
+
*/
|
1155
|
+
typedef struct FT_Prop_IncreaseXHeight_
|
1156
|
+
{
|
1157
|
+
FT_Face face;
|
1158
|
+
FT_UInt limit;
|
1159
|
+
|
1160
|
+
} FT_Prop_IncreaseXHeight;
|
1161
|
+
|
1162
|
+
|
1163
|
+
/**************************************************************************
|
1164
|
+
*
|
1165
|
+
* @property:
|
1166
|
+
* warping
|
1167
|
+
*
|
1168
|
+
* @description:
|
1169
|
+
* *Experimental* *only*
|
1170
|
+
*
|
1171
|
+
* If FreeType gets compiled with option AF_CONFIG_OPTION_USE_WARPER to
|
1172
|
+
* activate the warp hinting code in the auto-hinter, this property
|
1173
|
+
* switches warping on and off.
|
1174
|
+
*
|
1175
|
+
* Warping only works in `normal' auto-hinting mode replacing it.
|
1176
|
+
* The idea of the code is to slightly scale and shift a glyph along
|
1177
|
+
* the non-hinted dimension (which is usually the horizontal axis) so
|
1178
|
+
* that as much of its segments are aligned (more or less) to the grid.
|
1179
|
+
* To find out a glyph's optimal scaling and shifting value, various
|
1180
|
+
* parameter combinations are tried and scored.
|
1181
|
+
*
|
1182
|
+
* By default, warping is off. The example below shows how to switch on
|
1183
|
+
* warping (omitting the error handling).
|
1184
|
+
*
|
1185
|
+
* {
|
1186
|
+
* FT_Library library;
|
1187
|
+
* FT_Bool warping = 1;
|
1188
|
+
*
|
1189
|
+
*
|
1190
|
+
* FT_Init_FreeType( &library );
|
1191
|
+
*
|
1192
|
+
* FT_Property_Set( library, "autofitter",
|
1193
|
+
* "warping", &warping );
|
1194
|
+
* }
|
1195
|
+
*
|
1196
|
+
* @note:
|
1197
|
+
* This property can be used with @FT_Property_Get also.
|
1198
|
+
*
|
1199
|
+
* This property can be set via the `FREETYPE_PROPERTIES' environment
|
1200
|
+
* variable (using values 1 and 0 for `on' and `off', respectively).
|
1201
|
+
*
|
1202
|
+
* The warping code can also change advance widths. Have a look at the
|
1203
|
+
* `lsb_delta' and `rsb_delta' fields in the @FT_GlyphSlotRec structure
|
1204
|
+
* for details on improving inter-glyph distances while rendering.
|
1205
|
+
*
|
1206
|
+
* Since warping is a global property of the auto-hinter it is best to
|
1207
|
+
* change its value before rendering any face. Otherwise, you should
|
1208
|
+
* reload all faces that get auto-hinted in `normal' hinting mode.
|
1209
|
+
*
|
1210
|
+
* @since:
|
1211
|
+
* 2.6
|
1212
|
+
*
|
1213
|
+
*/
|
1214
|
+
|
1215
|
+
|
1216
|
+
/* */
|
1217
|
+
|
1218
|
+
|
1219
|
+
FT_END_HEADER
|
1220
|
+
|
1221
|
+
|
1222
|
+
#endif /* FTDRIVER_H_ */
|
1223
|
+
|
1224
|
+
|
1225
|
+
/* END */
|