cairo 1.15.13-x86-mingw32 → 1.15.14-x86-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
@@ -1,321 +0,0 @@
|
|
1
|
-
/***************************************************************************/
|
2
|
-
/* */
|
3
|
-
/* ftcffdrv.h */
|
4
|
-
/* */
|
5
|
-
/* FreeType API for controlling the CFF driver (specification only). */
|
6
|
-
/* */
|
7
|
-
/* Copyright 2013-2017 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 FTCFFDRV_H_
|
20
|
-
#define FTCFFDRV_H_
|
21
|
-
|
22
|
-
#include <ft2build.h>
|
23
|
-
#include FT_FREETYPE_H
|
24
|
-
|
25
|
-
#ifdef FREETYPE_H
|
26
|
-
#error "freetype.h of FreeType 1 has been loaded!"
|
27
|
-
#error "Please fix the directory search order for header files"
|
28
|
-
#error "so that freetype.h of FreeType 2 is found first."
|
29
|
-
#endif
|
30
|
-
|
31
|
-
|
32
|
-
FT_BEGIN_HEADER
|
33
|
-
|
34
|
-
|
35
|
-
/**************************************************************************
|
36
|
-
*
|
37
|
-
* @section:
|
38
|
-
* cff_driver
|
39
|
-
*
|
40
|
-
* @title:
|
41
|
-
* The CFF driver
|
42
|
-
*
|
43
|
-
* @abstract:
|
44
|
-
* Controlling the CFF driver module.
|
45
|
-
*
|
46
|
-
* @description:
|
47
|
-
* While FreeType's CFF driver doesn't expose API functions by itself,
|
48
|
-
* it is possible to control its behaviour with @FT_Property_Set and
|
49
|
-
* @FT_Property_Get. The list below gives the available properties
|
50
|
-
* together with the necessary macros and structures.
|
51
|
-
*
|
52
|
-
* The CFF driver's module name is `cff'.
|
53
|
-
*
|
54
|
-
* *Hinting* *and* *antialiasing* *principles* *of* *the* *new* *engine*
|
55
|
-
*
|
56
|
-
* The rasterizer is positioning horizontal features (e.g., ascender
|
57
|
-
* height & x-height, or crossbars) on the pixel grid and minimizing the
|
58
|
-
* amount of antialiasing applied to them, while placing vertical
|
59
|
-
* features (vertical stems) on the pixel grid without hinting, thus
|
60
|
-
* representing the stem position and weight accurately. Sometimes the
|
61
|
-
* vertical stems may be only partially black. In this context,
|
62
|
-
* `antialiasing' means that stems are not positioned exactly on pixel
|
63
|
-
* borders, causing a fuzzy appearance.
|
64
|
-
*
|
65
|
-
* There are two principles behind this approach.
|
66
|
-
*
|
67
|
-
* 1) No hinting in the horizontal direction: Unlike `superhinted'
|
68
|
-
* TrueType, which changes glyph widths to accommodate regular
|
69
|
-
* inter-glyph spacing, Adobe's approach is `faithful to the design' in
|
70
|
-
* representing both the glyph width and the inter-glyph spacing
|
71
|
-
* designed for the font. This makes the screen display as close as it
|
72
|
-
* can be to the result one would get with infinite resolution, while
|
73
|
-
* preserving what is considered the key characteristics of each glyph.
|
74
|
-
* Note that the distances between unhinted and grid-fitted positions at
|
75
|
-
* small sizes are comparable to kerning values and thus would be
|
76
|
-
* noticeable (and distracting) while reading if hinting were applied.
|
77
|
-
*
|
78
|
-
* One of the reasons to not hint horizontally is antialiasing for LCD
|
79
|
-
* screens: The pixel geometry of modern displays supplies three
|
80
|
-
* vertical sub-pixels as the eye moves horizontally across each visible
|
81
|
-
* pixel. On devices where we can be certain this characteristic is
|
82
|
-
* present a rasterizer can take advantage of the sub-pixels to add
|
83
|
-
* increments of weight. In Western writing systems this turns out to
|
84
|
-
* be the more critical direction anyway; the weights and spacing of
|
85
|
-
* vertical stems (see above) are central to Armenian, Cyrillic, Greek,
|
86
|
-
* and Latin type designs. Even when the rasterizer uses greyscale
|
87
|
-
* antialiasing instead of color (a necessary compromise when one
|
88
|
-
* doesn't know the screen characteristics), the unhinted vertical
|
89
|
-
* features preserve the design's weight and spacing much better than
|
90
|
-
* aliased type would.
|
91
|
-
*
|
92
|
-
* 2) Alignment in the vertical direction: Weights and spacing along the
|
93
|
-
* y~axis are less critical; what is much more important is the visual
|
94
|
-
* alignment of related features (like cap-height and x-height). The
|
95
|
-
* sense of alignment for these is enhanced by the sharpness of grid-fit
|
96
|
-
* edges, while the cruder vertical resolution (full pixels instead of
|
97
|
-
* 1/3 pixels) is less of a problem.
|
98
|
-
*
|
99
|
-
* On the technical side, horizontal alignment zones for ascender,
|
100
|
-
* x-height, and other important height values (traditionally called
|
101
|
-
* `blue zones') as defined in the font are positioned independently,
|
102
|
-
* each being rounded to the nearest pixel edge, taking care of
|
103
|
-
* overshoot suppression at small sizes, stem darkening, and scaling.
|
104
|
-
*
|
105
|
-
* Hstems (this is, hint values defined in the font to help align
|
106
|
-
* horizontal features) that fall within a blue zone are said to be
|
107
|
-
* `captured' and are aligned to that zone. Uncaptured stems are moved
|
108
|
-
* in one of four ways, top edge up or down, bottom edge up or down.
|
109
|
-
* Unless there are conflicting hstems, the smallest movement is taken
|
110
|
-
* to minimize distortion.
|
111
|
-
*
|
112
|
-
* @order:
|
113
|
-
* hinting-engine[cff]
|
114
|
-
* no-stem-darkening[cff]
|
115
|
-
* darkening-parameters[cff]
|
116
|
-
* random-seed
|
117
|
-
*
|
118
|
-
*/
|
119
|
-
|
120
|
-
|
121
|
-
/**************************************************************************
|
122
|
-
*
|
123
|
-
* @property:
|
124
|
-
* hinting-engine[cff]
|
125
|
-
*
|
126
|
-
* @description:
|
127
|
-
* Thanks to Adobe, which contributed a new hinting (and parsing)
|
128
|
-
* engine, an application can select between `freetype' and `adobe' if
|
129
|
-
* compiled with CFF_CONFIG_OPTION_OLD_ENGINE. If this configuration
|
130
|
-
* macro isn't defined, `hinting-engine' does nothing.
|
131
|
-
*
|
132
|
-
* The default engine is `freetype' if CFF_CONFIG_OPTION_OLD_ENGINE is
|
133
|
-
* defined, and `adobe' otherwise.
|
134
|
-
*
|
135
|
-
* The following example code demonstrates how to select Adobe's hinting
|
136
|
-
* engine (omitting the error handling).
|
137
|
-
*
|
138
|
-
* {
|
139
|
-
* FT_Library library;
|
140
|
-
* FT_UInt hinting_engine = FT_CFF_HINTING_ADOBE;
|
141
|
-
*
|
142
|
-
*
|
143
|
-
* FT_Init_FreeType( &library );
|
144
|
-
*
|
145
|
-
* FT_Property_Set( library, "cff",
|
146
|
-
* "hinting-engine", &hinting_engine );
|
147
|
-
* }
|
148
|
-
*
|
149
|
-
* @note:
|
150
|
-
* This property can be used with @FT_Property_Get also.
|
151
|
-
*
|
152
|
-
* This property can be set via the `FREETYPE_PROPERTIES' environment
|
153
|
-
* variable (using values `adobe' or `freetype').
|
154
|
-
*/
|
155
|
-
|
156
|
-
|
157
|
-
/**************************************************************************
|
158
|
-
*
|
159
|
-
* @enum:
|
160
|
-
* FT_CFF_HINTING_XXX
|
161
|
-
*
|
162
|
-
* @description:
|
163
|
-
* A list of constants used for the @hinting-engine[cff] property to
|
164
|
-
* select the hinting engine for CFF fonts.
|
165
|
-
*
|
166
|
-
* @values:
|
167
|
-
* FT_CFF_HINTING_FREETYPE ::
|
168
|
-
* Use the old FreeType hinting engine.
|
169
|
-
*
|
170
|
-
* FT_CFF_HINTING_ADOBE ::
|
171
|
-
* Use the hinting engine contributed by Adobe.
|
172
|
-
*
|
173
|
-
*/
|
174
|
-
#define FT_CFF_HINTING_FREETYPE 0
|
175
|
-
#define FT_CFF_HINTING_ADOBE 1
|
176
|
-
|
177
|
-
|
178
|
-
/**************************************************************************
|
179
|
-
*
|
180
|
-
* @property:
|
181
|
-
* no-stem-darkening[cff]
|
182
|
-
*
|
183
|
-
* @description:
|
184
|
-
* By default, the Adobe CFF engine darkens stems at smaller sizes,
|
185
|
-
* regardless of hinting, to enhance contrast. This feature requires
|
186
|
-
* a rendering system with proper gamma correction. Setting this
|
187
|
-
* property, stem darkening gets switched off.
|
188
|
-
*
|
189
|
-
* Note that stem darkening is never applied if @FT_LOAD_NO_SCALE is set.
|
190
|
-
*
|
191
|
-
* {
|
192
|
-
* FT_Library library;
|
193
|
-
* FT_Bool no_stem_darkening = TRUE;
|
194
|
-
*
|
195
|
-
*
|
196
|
-
* FT_Init_FreeType( &library );
|
197
|
-
*
|
198
|
-
* FT_Property_Set( library, "cff",
|
199
|
-
* "no-stem-darkening", &no_stem_darkening );
|
200
|
-
* }
|
201
|
-
*
|
202
|
-
* @note:
|
203
|
-
* This property can be used with @FT_Property_Get also.
|
204
|
-
*
|
205
|
-
* This property can be set via the `FREETYPE_PROPERTIES' environment
|
206
|
-
* variable (using values 1 and 0 for `on' and `off', respectively).
|
207
|
-
* It can also be set per face using @FT_Face_Properties with
|
208
|
-
* @FT_PARAM_TAG_STEM_DARKENING.
|
209
|
-
*
|
210
|
-
*/
|
211
|
-
|
212
|
-
|
213
|
-
/**************************************************************************
|
214
|
-
*
|
215
|
-
* @property:
|
216
|
-
* darkening-parameters[cff]
|
217
|
-
*
|
218
|
-
* @description:
|
219
|
-
* By default, the Adobe CFF engine darkens stems as follows (if the
|
220
|
-
* `no-stem-darkening' property isn't set):
|
221
|
-
*
|
222
|
-
* {
|
223
|
-
* stem width <= 0.5px: darkening amount = 0.4px
|
224
|
-
* stem width = 1px: darkening amount = 0.275px
|
225
|
-
* stem width = 1.667px: darkening amount = 0.275px
|
226
|
-
* stem width >= 2.333px: darkening amount = 0px
|
227
|
-
* }
|
228
|
-
*
|
229
|
-
* and piecewise linear in-between. At configuration time, these four
|
230
|
-
* control points can be set with the macro
|
231
|
-
* `CFF_CONFIG_OPTION_DARKENING_PARAMETERS'. At runtime, the control
|
232
|
-
* points can be changed using the `darkening-parameters' property, as
|
233
|
-
* the following example demonstrates.
|
234
|
-
*
|
235
|
-
* {
|
236
|
-
* FT_Library library;
|
237
|
-
* FT_Int darken_params[8] = { 500, 300, // x1, y1
|
238
|
-
* 1000, 200, // x2, y2
|
239
|
-
* 1500, 100, // x3, y3
|
240
|
-
* 2000, 0 }; // x4, y4
|
241
|
-
*
|
242
|
-
*
|
243
|
-
* FT_Init_FreeType( &library );
|
244
|
-
*
|
245
|
-
* FT_Property_Set( library, "cff",
|
246
|
-
* "darkening-parameters", darken_params );
|
247
|
-
* }
|
248
|
-
*
|
249
|
-
* The x~values give the stem width, and the y~values the darkening
|
250
|
-
* amount. The unit is 1000th of pixels. All coordinate values must be
|
251
|
-
* positive; the x~values must be monotonically increasing; the
|
252
|
-
* y~values must be monotonically decreasing and smaller than or
|
253
|
-
* equal to 500 (corresponding to half a pixel); the slope of each
|
254
|
-
* linear piece must be shallower than -1 (e.g., -.4).
|
255
|
-
*
|
256
|
-
* @note:
|
257
|
-
* This property can be used with @FT_Property_Get also.
|
258
|
-
*
|
259
|
-
* This property can be set via the `FREETYPE_PROPERTIES' environment
|
260
|
-
* variable, using eight comma-separated integers without spaces. Here
|
261
|
-
* the above example, using `\' to break the line for readability.
|
262
|
-
*
|
263
|
-
* {
|
264
|
-
* FREETYPE_PROPERTIES=\
|
265
|
-
* cff:darkening-parameters=500,300,1000,200,1500,100,2000,0
|
266
|
-
* }
|
267
|
-
*/
|
268
|
-
|
269
|
-
|
270
|
-
/**************************************************************************
|
271
|
-
*
|
272
|
-
* @property:
|
273
|
-
* random-seed
|
274
|
-
*
|
275
|
-
* @description:
|
276
|
-
* By default, the seed value for the CFF `random' operator is set to a
|
277
|
-
* random value. However, mainly for debugging purposes, it is often
|
278
|
-
* necessary to use a known value as a seed so that the pseudo-random
|
279
|
-
* number sequences generated by `random' are repeatable.
|
280
|
-
*
|
281
|
-
* The `random-seed' property does that. Its argument is a signed 32bit
|
282
|
-
* integer; if the value is zero or negative, the seed given by the
|
283
|
-
* `intitialRandomSeed' private DICT operator in a CFF file gets used
|
284
|
-
* (or a default value if there is no such operator). If the value is
|
285
|
-
* positive, use it instead of `initialRandomSeed', which is
|
286
|
-
* consequently ignored.
|
287
|
-
*
|
288
|
-
* @note:
|
289
|
-
* This property can be set via the `FREETYPE_PROPERTIES' environment
|
290
|
-
* variable. It can also be set per face using @FT_Face_Properties with
|
291
|
-
* @FT_PARAM_TAG_RANDOM_SEED.
|
292
|
-
*
|
293
|
-
*/
|
294
|
-
|
295
|
-
|
296
|
-
/**************************************************************************
|
297
|
-
*
|
298
|
-
* @constant:
|
299
|
-
* FT_PARAM_TAG_RANDOM_SEED
|
300
|
-
*
|
301
|
-
* @description:
|
302
|
-
* An @FT_Parameter tag to be used with @FT_Face_Properties. The
|
303
|
-
* corresponding 32bit signed integer argument overrides the CFF
|
304
|
-
* module's random seed value with a face-specific one; see
|
305
|
-
* @random-seed.
|
306
|
-
*
|
307
|
-
*/
|
308
|
-
#define FT_PARAM_TAG_RANDOM_SEED \
|
309
|
-
FT_MAKE_TAG( 's', 'e', 'e', 'd' )
|
310
|
-
|
311
|
-
|
312
|
-
/* */
|
313
|
-
|
314
|
-
|
315
|
-
FT_END_HEADER
|
316
|
-
|
317
|
-
|
318
|
-
#endif /* FTCFFDRV_H_ */
|
319
|
-
|
320
|
-
|
321
|
-
/* END */
|
@@ -1,105 +0,0 @@
|
|
1
|
-
/***************************************************************************/
|
2
|
-
/* */
|
3
|
-
/* ftpcfdrv.h */
|
4
|
-
/* */
|
5
|
-
/* FreeType API for controlling the PCF driver (specification only). */
|
6
|
-
/* */
|
7
|
-
/* Copyright 2017 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 FTPCFDRV_H_
|
20
|
-
#define FTPCFDRV_H_
|
21
|
-
|
22
|
-
#include <ft2build.h>
|
23
|
-
#include FT_FREETYPE_H
|
24
|
-
|
25
|
-
#ifdef FREETYPE_H
|
26
|
-
#error "freetype.h of FreeType 1 has been loaded!"
|
27
|
-
#error "Please fix the directory search order for header files"
|
28
|
-
#error "so that freetype.h of FreeType 2 is found first."
|
29
|
-
#endif
|
30
|
-
|
31
|
-
|
32
|
-
FT_BEGIN_HEADER
|
33
|
-
|
34
|
-
|
35
|
-
/**************************************************************************
|
36
|
-
*
|
37
|
-
* @section:
|
38
|
-
* pcf_driver
|
39
|
-
*
|
40
|
-
* @title:
|
41
|
-
* The PCF driver
|
42
|
-
*
|
43
|
-
* @abstract:
|
44
|
-
* Controlling the PCF driver module.
|
45
|
-
*
|
46
|
-
* @description:
|
47
|
-
* While FreeType's PCF driver doesn't expose API functions by itself,
|
48
|
-
* it is possible to control its behaviour with @FT_Property_Set and
|
49
|
-
* @FT_Property_Get. Right now, there is a single property
|
50
|
-
* `no-long-family-names' available if FreeType is compiled with
|
51
|
-
* PCF_CONFIG_OPTION_LONG_FAMILY_NAMES.
|
52
|
-
*
|
53
|
-
* The PCF driver's module name is `pcf'.
|
54
|
-
*
|
55
|
-
*/
|
56
|
-
|
57
|
-
|
58
|
-
/**************************************************************************
|
59
|
-
*
|
60
|
-
* @property:
|
61
|
-
* no-long-family-names
|
62
|
-
*
|
63
|
-
* @description:
|
64
|
-
* If PCF_CONFIG_OPTION_LONG_FAMILY_NAMES is active while compiling
|
65
|
-
* FreeType, the PCF driver constructs long family names.
|
66
|
-
*
|
67
|
-
* There are many PCF fonts just called `Fixed' which look completely
|
68
|
-
* different, and which have nothing to do with each other. When
|
69
|
-
* selecting `Fixed' in KDE or Gnome one gets results that appear rather
|
70
|
-
* random, the style changes often if one changes the size and one
|
71
|
-
* cannot select some fonts at all. The improve this situation, the PCF
|
72
|
-
* module prepends the foundry name (plus a space) to the family name.
|
73
|
-
* It also checks whether there are `wide' characters; all put together,
|
74
|
-
* family names like `Sony Fixed' or `Misc Fixed Wide' are constructed.
|
75
|
-
*
|
76
|
-
* If `no-long-family-names' is set, this feature gets switched off.
|
77
|
-
*
|
78
|
-
* {
|
79
|
-
* FT_Library library;
|
80
|
-
* FT_Bool no_long_family_names = TRUE;
|
81
|
-
*
|
82
|
-
*
|
83
|
-
* FT_Init_FreeType( &library );
|
84
|
-
*
|
85
|
-
* FT_Property_Set( library, "pcf",
|
86
|
-
* "no-long-family-names",
|
87
|
-
* &no_long_family_names );
|
88
|
-
* }
|
89
|
-
*
|
90
|
-
* @note:
|
91
|
-
* This property can be used with @FT_Property_Get also.
|
92
|
-
*
|
93
|
-
* This property can be set via the `FREETYPE_PROPERTIES' environment
|
94
|
-
* variable (using values 1 and 0 for `on' and `off', respectively).
|
95
|
-
*
|
96
|
-
*/
|
97
|
-
|
98
|
-
|
99
|
-
FT_END_HEADER
|
100
|
-
|
101
|
-
|
102
|
-
#endif /* FTPCFDRV_H_ */
|
103
|
-
|
104
|
-
|
105
|
-
/* END */
|
@@ -1,328 +0,0 @@
|
|
1
|
-
/***************************************************************************/
|
2
|
-
/* */
|
3
|
-
/* ftttdrv.h */
|
4
|
-
/* */
|
5
|
-
/* FreeType API for controlling the TrueType driver */
|
6
|
-
/* (specification only). */
|
7
|
-
/* */
|
8
|
-
/* Copyright 2013-2017 by */
|
9
|
-
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
10
|
-
/* */
|
11
|
-
/* This file is part of the FreeType project, and may only be used, */
|
12
|
-
/* modified, and distributed under the terms of the FreeType project */
|
13
|
-
/* license, LICENSE.TXT. By continuing to use, modify, or distribute */
|
14
|
-
/* this file you indicate that you have read the license and */
|
15
|
-
/* understand and accept it fully. */
|
16
|
-
/* */
|
17
|
-
/***************************************************************************/
|
18
|
-
|
19
|
-
|
20
|
-
#ifndef FTTTDRV_H_
|
21
|
-
#define FTTTDRV_H_
|
22
|
-
|
23
|
-
#include <ft2build.h>
|
24
|
-
#include FT_FREETYPE_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
|
-
* tt_driver
|
40
|
-
*
|
41
|
-
* @title:
|
42
|
-
* The TrueType driver
|
43
|
-
*
|
44
|
-
* @abstract:
|
45
|
-
* Controlling the TrueType driver module.
|
46
|
-
*
|
47
|
-
* @description:
|
48
|
-
* While FreeType's TrueType driver doesn't expose API functions by
|
49
|
-
* itself, it is possible to control its behaviour with @FT_Property_Set
|
50
|
-
* and @FT_Property_Get. The following lists the available properties
|
51
|
-
* together with the necessary macros and structures.
|
52
|
-
*
|
53
|
-
* The TrueType driver's module name is `truetype'.
|
54
|
-
*
|
55
|
-
* We start with a list of definitions, kindly provided by Greg
|
56
|
-
* Hitchcock.
|
57
|
-
*
|
58
|
-
* _Bi-Level_ _Rendering_
|
59
|
-
*
|
60
|
-
* Monochromatic rendering, exclusively used in the early days of
|
61
|
-
* TrueType by both Apple and Microsoft. Microsoft's GDI interface
|
62
|
-
* supported hinting of the right-side bearing point, such that the
|
63
|
-
* advance width could be non-linear. Most often this was done to
|
64
|
-
* achieve some level of glyph symmetry. To enable reasonable
|
65
|
-
* performance (e.g., not having to run hinting on all glyphs just to
|
66
|
-
* get the widths) there was a bit in the head table indicating if the
|
67
|
-
* side bearing was hinted, and additional tables, `hdmx' and `LTSH', to
|
68
|
-
* cache hinting widths across multiple sizes and device aspect ratios.
|
69
|
-
*
|
70
|
-
* _Font_ _Smoothing_
|
71
|
-
*
|
72
|
-
* Microsoft's GDI implementation of anti-aliasing. Not traditional
|
73
|
-
* anti-aliasing as the outlines were hinted before the sampling. The
|
74
|
-
* widths matched the bi-level rendering.
|
75
|
-
*
|
76
|
-
* _ClearType_ _Rendering_
|
77
|
-
*
|
78
|
-
* Technique that uses physical subpixels to improve rendering on LCD
|
79
|
-
* (and other) displays. Because of the higher resolution, many methods
|
80
|
-
* of improving symmetry in glyphs through hinting the right-side
|
81
|
-
* bearing were no longer necessary. This lead to what GDI calls
|
82
|
-
* `natural widths' ClearType, see
|
83
|
-
* http://www.beatstamm.com/typography/RTRCh4.htm#Sec21. Since hinting
|
84
|
-
* has extra resolution, most non-linearity went away, but it is still
|
85
|
-
* possible for hints to change the advance widths in this mode.
|
86
|
-
*
|
87
|
-
* _ClearType_ _Compatible_ _Widths_
|
88
|
-
*
|
89
|
-
* One of the earliest challenges with ClearType was allowing the
|
90
|
-
* implementation in GDI to be selected without requiring all UI and
|
91
|
-
* documents to reflow. To address this, a compatible method of
|
92
|
-
* rendering ClearType was added where the font hints are executed once
|
93
|
-
* to determine the width in bi-level rendering, and then re-run in
|
94
|
-
* ClearType, with the difference in widths being absorbed in the font
|
95
|
-
* hints for ClearType (mostly in the white space of hints); see
|
96
|
-
* http://www.beatstamm.com/typography/RTRCh4.htm#Sec20. Somewhat by
|
97
|
-
* definition, compatible width ClearType allows for non-linear widths,
|
98
|
-
* but only when the bi-level version has non-linear widths.
|
99
|
-
*
|
100
|
-
* _ClearType_ _Subpixel_ _Positioning_
|
101
|
-
*
|
102
|
-
* One of the nice benefits of ClearType is the ability to more crisply
|
103
|
-
* display fractional widths; unfortunately, the GDI model of integer
|
104
|
-
* bitmaps did not support this. However, the WPF and Direct Write
|
105
|
-
* frameworks do support fractional widths. DWrite calls this `natural
|
106
|
-
* mode', not to be confused with GDI's `natural widths'. Subpixel
|
107
|
-
* positioning, in the current implementation of Direct Write,
|
108
|
-
* unfortunately does not support hinted advance widths, see
|
109
|
-
* http://www.beatstamm.com/typography/RTRCh4.htm#Sec22. Note that the
|
110
|
-
* TrueType interpreter fully allows the advance width to be adjusted in
|
111
|
-
* this mode, just the DWrite client will ignore those changes.
|
112
|
-
*
|
113
|
-
* _ClearType_ _Backward_ _Compatibility_
|
114
|
-
*
|
115
|
-
* This is a set of exceptions made in the TrueType interpreter to
|
116
|
-
* minimize hinting techniques that were problematic with the extra
|
117
|
-
* resolution of ClearType; see
|
118
|
-
* http://www.beatstamm.com/typography/RTRCh4.htm#Sec1 and
|
119
|
-
* http://www.microsoft.com/typography/cleartype/truetypecleartype.aspx.
|
120
|
-
* This technique is not to be confused with ClearType compatible
|
121
|
-
* widths. ClearType backward compatibility has no direct impact on
|
122
|
-
* changing advance widths, but there might be an indirect impact on
|
123
|
-
* disabling some deltas. This could be worked around in backward
|
124
|
-
* compatibility mode.
|
125
|
-
*
|
126
|
-
* _Native_ _ClearType_ _Mode_
|
127
|
-
*
|
128
|
-
* (Not to be confused with `natural widths'.) This mode removes all
|
129
|
-
* the exceptions in the TrueType interpreter when running with
|
130
|
-
* ClearType. Any issues on widths would still apply, though.
|
131
|
-
*
|
132
|
-
*/
|
133
|
-
|
134
|
-
|
135
|
-
/**************************************************************************
|
136
|
-
*
|
137
|
-
* @property:
|
138
|
-
* interpreter-version
|
139
|
-
*
|
140
|
-
* @description:
|
141
|
-
* Currently, three versions are available, two representing the
|
142
|
-
* bytecode interpreter with subpixel hinting support (old `Infinality'
|
143
|
-
* code and new stripped-down and higher performance `minimal' code) and
|
144
|
-
* one without, respectively. The default is subpixel support if
|
145
|
-
* TT_CONFIG_OPTION_SUBPIXEL_HINTING is defined, and no subpixel support
|
146
|
-
* otherwise (since it isn't available then).
|
147
|
-
*
|
148
|
-
* If subpixel hinting is on, many TrueType bytecode instructions behave
|
149
|
-
* differently compared to B/W or grayscale rendering (except if `native
|
150
|
-
* ClearType' is selected by the font). Microsoft's main idea is to
|
151
|
-
* render at a much increased horizontal resolution, then sampling down
|
152
|
-
* the created output to subpixel precision. However, many older fonts
|
153
|
-
* are not suited to this and must be specially taken care of by
|
154
|
-
* applying (hardcoded) tweaks in Microsoft's interpreter.
|
155
|
-
*
|
156
|
-
* Details on subpixel hinting and some of the necessary tweaks can be
|
157
|
-
* found in Greg Hitchcock's whitepaper at
|
158
|
-
* `http://www.microsoft.com/typography/cleartype/truetypecleartype.aspx'.
|
159
|
-
* Note that FreeType currently doesn't really `subpixel hint' (6x1, 6x2,
|
160
|
-
* or 6x5 supersampling) like discussed in the paper. Depending on the
|
161
|
-
* chosen interpreter, it simply ignores instructions on vertical stems
|
162
|
-
* to arrive at very similar results.
|
163
|
-
*
|
164
|
-
* The following example code demonstrates how to deactivate subpixel
|
165
|
-
* hinting (omitting the error handling).
|
166
|
-
*
|
167
|
-
* {
|
168
|
-
* FT_Library library;
|
169
|
-
* FT_Face face;
|
170
|
-
* FT_UInt interpreter_version = TT_INTERPRETER_VERSION_35;
|
171
|
-
*
|
172
|
-
*
|
173
|
-
* FT_Init_FreeType( &library );
|
174
|
-
*
|
175
|
-
* FT_Property_Set( library, "truetype",
|
176
|
-
* "interpreter-version",
|
177
|
-
* &interpreter_version );
|
178
|
-
* }
|
179
|
-
*
|
180
|
-
* @note:
|
181
|
-
* This property can be used with @FT_Property_Get also.
|
182
|
-
*
|
183
|
-
* This property can be set via the `FREETYPE_PROPERTIES' environment
|
184
|
-
* variable (using values `35', `38', or `40').
|
185
|
-
*/
|
186
|
-
|
187
|
-
|
188
|
-
/**************************************************************************
|
189
|
-
*
|
190
|
-
* @enum:
|
191
|
-
* TT_INTERPRETER_VERSION_XXX
|
192
|
-
*
|
193
|
-
* @description:
|
194
|
-
* A list of constants used for the @interpreter-version property to
|
195
|
-
* select the hinting engine for Truetype fonts.
|
196
|
-
*
|
197
|
-
* The numeric value in the constant names represents the version
|
198
|
-
* number as returned by the `GETINFO' bytecode instruction.
|
199
|
-
*
|
200
|
-
* @values:
|
201
|
-
* TT_INTERPRETER_VERSION_35 ::
|
202
|
-
* Version~35 corresponds to MS rasterizer v.1.7 as used e.g. in
|
203
|
-
* Windows~98; only grayscale and B/W rasterizing is supported.
|
204
|
-
*
|
205
|
-
* TT_INTERPRETER_VERSION_38 ::
|
206
|
-
* Version~38 corresponds to MS rasterizer v.1.9; it is roughly
|
207
|
-
* equivalent to the hinting provided by DirectWrite ClearType (as can
|
208
|
-
* be found, for example, in the Internet Explorer~9 running on
|
209
|
-
* Windows~7). It is used in FreeType to select the `Infinality'
|
210
|
-
* subpixel hinting code. The code may be removed in a future
|
211
|
-
* version.
|
212
|
-
*
|
213
|
-
* TT_INTERPRETER_VERSION_40 ::
|
214
|
-
* Version~40 corresponds to MS rasterizer v.2.1; it is roughly
|
215
|
-
* equivalent to the hinting provided by DirectWrite ClearType (as can
|
216
|
-
* be found, for example, in Microsoft's Edge Browser on Windows~10).
|
217
|
-
* It is used in FreeType to select the `minimal' subpixel hinting
|
218
|
-
* code, a stripped-down and higher performance version of the
|
219
|
-
* `Infinality' code.
|
220
|
-
*
|
221
|
-
* @note:
|
222
|
-
* This property controls the behaviour of the bytecode interpreter
|
223
|
-
* and thus how outlines get hinted. It does *not* control how glyph
|
224
|
-
* get rasterized! In particular, it does not control subpixel color
|
225
|
-
* filtering.
|
226
|
-
*
|
227
|
-
* If FreeType has not been compiled with the configuration option
|
228
|
-
* TT_CONFIG_OPTION_SUBPIXEL_HINTING, selecting version~38 or~40 causes
|
229
|
-
* an `FT_Err_Unimplemented_Feature' error.
|
230
|
-
*
|
231
|
-
* Depending on the graphics framework, Microsoft uses different
|
232
|
-
* bytecode and rendering engines. As a consequence, the version
|
233
|
-
* numbers returned by a call to the `GETINFO' bytecode instruction are
|
234
|
-
* more convoluted than desired.
|
235
|
-
*
|
236
|
-
* Here are two tables that try to shed some light on the possible
|
237
|
-
* values for the MS rasterizer engine, together with the additional
|
238
|
-
* features introduced by it.
|
239
|
-
*
|
240
|
-
* {
|
241
|
-
* GETINFO framework version feature
|
242
|
-
* -------------------------------------------------------------------
|
243
|
-
* 3 GDI (Win 3.1), v1.0 16-bit, first version
|
244
|
-
* TrueImage
|
245
|
-
* 33 GDI (Win NT 3.1), v1.5 32-bit
|
246
|
-
* HP Laserjet
|
247
|
-
* 34 GDI (Win 95) v1.6 font smoothing,
|
248
|
-
* new SCANTYPE opcode
|
249
|
-
* 35 GDI (Win 98/2000) v1.7 (UN)SCALED_COMPONENT_OFFSET
|
250
|
-
* bits in composite glyphs
|
251
|
-
* 36 MGDI (Win CE 2) v1.6+ classic ClearType
|
252
|
-
* 37 GDI (XP and later), v1.8 ClearType
|
253
|
-
* GDI+ old (before Vista)
|
254
|
-
* 38 GDI+ old (Vista, Win 7), v1.9 subpixel ClearType,
|
255
|
-
* WPF Y-direction ClearType,
|
256
|
-
* additional error checking
|
257
|
-
* 39 DWrite (before Win 8) v2.0 subpixel ClearType flags
|
258
|
-
* in GETINFO opcode,
|
259
|
-
* bug fixes
|
260
|
-
* 40 GDI+ (after Win 7), v2.1 Y-direction ClearType flag
|
261
|
-
* DWrite (Win 8) in GETINFO opcode,
|
262
|
-
* Gray ClearType
|
263
|
-
* }
|
264
|
-
*
|
265
|
-
* The `version' field gives a rough orientation only, since some
|
266
|
-
* applications provided certain features much earlier (as an example,
|
267
|
-
* Microsoft Reader used subpixel and Y-direction ClearType already in
|
268
|
-
* Windows 2000). Similarly, updates to a given framework might include
|
269
|
-
* improved hinting support.
|
270
|
-
*
|
271
|
-
* {
|
272
|
-
* version sampling rendering comment
|
273
|
-
* x y x y
|
274
|
-
* --------------------------------------------------------------
|
275
|
-
* v1.0 normal normal B/W B/W bi-level
|
276
|
-
* v1.6 high high gray gray grayscale
|
277
|
-
* v1.8 high normal color-filter B/W (GDI) ClearType
|
278
|
-
* v1.9 high high color-filter gray Color ClearType
|
279
|
-
* v2.1 high normal gray B/W Gray ClearType
|
280
|
-
* v2.1 high high gray gray Gray ClearType
|
281
|
-
* }
|
282
|
-
*
|
283
|
-
* Color and Gray ClearType are the two available variants of
|
284
|
-
* `Y-direction ClearType', meaning grayscale rasterization along the
|
285
|
-
* Y-direction; the name used in the TrueType specification for this
|
286
|
-
* feature is `symmetric smoothing'. `Classic ClearType' is the
|
287
|
-
* original algorithm used before introducing a modified version in
|
288
|
-
* Win~XP. Another name for v1.6's grayscale rendering is `font
|
289
|
-
* smoothing', and `Color ClearType' is sometimes also called `DWrite
|
290
|
-
* ClearType'. To differentiate between today's Color ClearType and the
|
291
|
-
* earlier ClearType variant with B/W rendering along the vertical axis,
|
292
|
-
* the latter is sometimes called `GDI ClearType'.
|
293
|
-
*
|
294
|
-
* `Normal' and `high' sampling describe the (virtual) resolution to
|
295
|
-
* access the rasterized outline after the hinting process. `Normal'
|
296
|
-
* means 1 sample per grid line (i.e., B/W). In the current Microsoft
|
297
|
-
* implementation, `high' means an extra virtual resolution of 16x16 (or
|
298
|
-
* 16x1) grid lines per pixel for bytecode instructions like `MIRP'.
|
299
|
-
* After hinting, these 16 grid lines are mapped to 6x5 (or 6x1) grid
|
300
|
-
* lines for color filtering if Color ClearType is activated.
|
301
|
-
*
|
302
|
-
* Note that `Gray ClearType' is essentially the same as v1.6's
|
303
|
-
* grayscale rendering. However, the GETINFO instruction handles it
|
304
|
-
* differently: v1.6 returns bit~12 (hinting for grayscale), while v2.1
|
305
|
-
* returns bits~13 (hinting for ClearType), 18 (symmetrical smoothing),
|
306
|
-
* and~19 (Gray ClearType). Also, this mode respects bits 2 and~3 for
|
307
|
-
* the version~1 gasp table exclusively (like Color ClearType), while
|
308
|
-
* v1.6 only respects the values of version~0 (bits 0 and~1).
|
309
|
-
*
|
310
|
-
* Keep in mind that the features of the above interpreter versions
|
311
|
-
* might not map exactly to FreeType features or behavior because it is
|
312
|
-
* a fundamentally different library with different internals.
|
313
|
-
*
|
314
|
-
*/
|
315
|
-
#define TT_INTERPRETER_VERSION_35 35
|
316
|
-
#define TT_INTERPRETER_VERSION_38 38
|
317
|
-
#define TT_INTERPRETER_VERSION_40 40
|
318
|
-
|
319
|
-
/* */
|
320
|
-
|
321
|
-
|
322
|
-
FT_END_HEADER
|
323
|
-
|
324
|
-
|
325
|
-
#endif /* FTTTDRV_H_ */
|
326
|
-
|
327
|
-
|
328
|
-
/* END */
|