1 /***************************************************************************/
5 /* Auto-fitter routines to compute global hinting values */
8 /* Copyright 2003-2015 by */
9 /* David Turner, Robert Wilhelm, and Werner Lemberg. */
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. */
17 /***************************************************************************/
20 #ifndef __AFGLOBAL_H__
21 #define __AFGLOBAL_H__
32 FT_LOCAL_ARRAY( AF_WritingSystemClass
)
33 af_writing_system_classes
[];
37 #define SCRIPT( s, S, d, h, sc1, sc2, sc3 ) \
38 AF_DECLARE_SCRIPT_CLASS( af_ ## s ## _script_class )
42 FT_LOCAL_ARRAY( AF_ScriptClass
)
47 #define STYLE( s, S, d, ws, sc, ss, c ) \
48 AF_DECLARE_STYLE_CLASS( af_ ## s ## _style_class )
52 FT_LOCAL_ARRAY( AF_StyleClass
)
56 #ifdef FT_DEBUG_LEVEL_TRACE
57 FT_LOCAL_ARRAY( char* )
63 * Default values and flags for both autofitter globals (found in
64 * AF_ModuleRec) and face globals (in AF_FaceGlobalsRec).
67 /* index of fallback style in `af_style_classes' */
68 #ifdef AF_CONFIG_OPTION_CJK
69 #define AF_STYLE_FALLBACK AF_STYLE_HANI_DFLT
71 #define AF_STYLE_FALLBACK AF_STYLE_NONE_DFLT
73 /* default script for OpenType; ignored if HarfBuzz isn't used */
74 #define AF_SCRIPT_DEFAULT AF_SCRIPT_LATN
76 /* a bit mask for AF_DIGIT and AF_NONBASE */
77 #define AF_STYLE_MASK 0x3FFF
78 /* an uncovered glyph */
79 #define AF_STYLE_UNASSIGNED AF_STYLE_MASK
81 /* if this flag is set, we have an ASCII digit */
82 #define AF_DIGIT 0x8000U
83 /* if this flag is set, we have a non-base character */
84 #define AF_NONBASE 0x4000U
86 /* `increase-x-height' property */
87 #define AF_PROP_INCREASE_X_HEIGHT_MIN 6
88 #define AF_PROP_INCREASE_X_HEIGHT_MAX 0
91 /************************************************************************/
92 /************************************************************************/
94 /***** F A C E G L O B A L S *****/
96 /************************************************************************/
97 /************************************************************************/
101 * Note that glyph_styles[] maps each glyph to an index into the
102 * `af_style_classes' array.
105 typedef struct AF_FaceGlobalsRec_
108 FT_Long glyph_count
; /* same as face->num_glyphs */
109 FT_UShort
* glyph_styles
;
111 #ifdef FT_CONFIG_OPTION_USE_HARFBUZZ
115 /* per-face auto-hinter properties */
116 FT_UInt increase_x_height
;
118 AF_StyleMetrics metrics
[AF_STYLE_MAX
];
120 /* Compute darkening amount once per size. Use this to check whether */
121 /* darken_{x,y} needs to be recomputed. */
122 FT_UShort stem_darkening_for_ppem
;
123 /* Copy from e.g. AF_LatinMetrics.axis[AF_DIMENSION_HORZ] */
124 /* to compute the darkening amount. */
125 FT_Pos standard_vertical_width
;
126 /* Copy from e.g. AF_LatinMetrics.axis[AF_DIMENSION_VERT] */
127 /* to compute the darkening amount. */
128 FT_Pos standard_horizontal_width
;
129 /* The actual amount to darken a glyph along the X axis. */
131 /* The actual amount to darken a glyph along the Y axis. */
133 /* Amount to scale down by to keep emboldened points */
134 /* on the Y-axis in pre-computed blue zones. */
135 FT_Fixed scale_down_factor
;
136 AF_Module module
; /* to access global properties */
142 * model the global hints data for a given face, decomposed into
143 * style-specific items
147 af_face_globals_new( FT_Face face
,
148 AF_FaceGlobals
*aglobals
,
152 af_face_globals_get_metrics( AF_FaceGlobals globals
,
155 AF_StyleMetrics
*ametrics
);
158 af_face_globals_free( AF_FaceGlobals globals
);
160 FT_LOCAL_DEF( FT_Bool
)
161 af_face_globals_is_digit( AF_FaceGlobals globals
,
169 #endif /* __AFGLOBAL_H__ */