xref: /aosp_15_r20/external/harfbuzz_ng/src/hb-ot-var.h (revision 2d1272b857b1f7575e6e246373e1cb218663db8a)
1*2d1272b8SAndroid Build Coastguard Worker /*
2*2d1272b8SAndroid Build Coastguard Worker  * Copyright © 2017  Google, Inc.
3*2d1272b8SAndroid Build Coastguard Worker  *
4*2d1272b8SAndroid Build Coastguard Worker  *  This is part of HarfBuzz, a text shaping library.
5*2d1272b8SAndroid Build Coastguard Worker  *
6*2d1272b8SAndroid Build Coastguard Worker  * Permission is hereby granted, without written agreement and without
7*2d1272b8SAndroid Build Coastguard Worker  * license or royalty fees, to use, copy, modify, and distribute this
8*2d1272b8SAndroid Build Coastguard Worker  * software and its documentation for any purpose, provided that the
9*2d1272b8SAndroid Build Coastguard Worker  * above copyright notice and the following two paragraphs appear in
10*2d1272b8SAndroid Build Coastguard Worker  * all copies of this software.
11*2d1272b8SAndroid Build Coastguard Worker  *
12*2d1272b8SAndroid Build Coastguard Worker  * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
13*2d1272b8SAndroid Build Coastguard Worker  * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
14*2d1272b8SAndroid Build Coastguard Worker  * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
15*2d1272b8SAndroid Build Coastguard Worker  * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
16*2d1272b8SAndroid Build Coastguard Worker  * DAMAGE.
17*2d1272b8SAndroid Build Coastguard Worker  *
18*2d1272b8SAndroid Build Coastguard Worker  * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
19*2d1272b8SAndroid Build Coastguard Worker  * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
20*2d1272b8SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE.  THE SOFTWARE PROVIDED HEREUNDER IS
21*2d1272b8SAndroid Build Coastguard Worker  * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
22*2d1272b8SAndroid Build Coastguard Worker  * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
23*2d1272b8SAndroid Build Coastguard Worker  *
24*2d1272b8SAndroid Build Coastguard Worker  * Red Hat Author(s): Behdad Esfahbod
25*2d1272b8SAndroid Build Coastguard Worker  */
26*2d1272b8SAndroid Build Coastguard Worker 
27*2d1272b8SAndroid Build Coastguard Worker #if !defined(HB_OT_H_IN) && !defined(HB_NO_SINGLE_HEADER_ERROR)
28*2d1272b8SAndroid Build Coastguard Worker #error "Include <hb-ot.h> instead."
29*2d1272b8SAndroid Build Coastguard Worker #endif
30*2d1272b8SAndroid Build Coastguard Worker 
31*2d1272b8SAndroid Build Coastguard Worker #ifndef HB_OT_VAR_H
32*2d1272b8SAndroid Build Coastguard Worker #define HB_OT_VAR_H
33*2d1272b8SAndroid Build Coastguard Worker 
34*2d1272b8SAndroid Build Coastguard Worker #include "hb.h"
35*2d1272b8SAndroid Build Coastguard Worker 
36*2d1272b8SAndroid Build Coastguard Worker HB_BEGIN_DECLS
37*2d1272b8SAndroid Build Coastguard Worker 
38*2d1272b8SAndroid Build Coastguard Worker /**
39*2d1272b8SAndroid Build Coastguard Worker  * HB_OT_TAG_VAR_AXIS_ITALIC:
40*2d1272b8SAndroid Build Coastguard Worker  *
41*2d1272b8SAndroid Build Coastguard Worker  * Registered tag for the roman/italic axis.
42*2d1272b8SAndroid Build Coastguard Worker  */
43*2d1272b8SAndroid Build Coastguard Worker #define HB_OT_TAG_VAR_AXIS_ITALIC	HB_TAG('i','t','a','l')
44*2d1272b8SAndroid Build Coastguard Worker 
45*2d1272b8SAndroid Build Coastguard Worker /**
46*2d1272b8SAndroid Build Coastguard Worker  * HB_OT_TAG_VAR_AXIS_OPTICAL_SIZE:
47*2d1272b8SAndroid Build Coastguard Worker  *
48*2d1272b8SAndroid Build Coastguard Worker  * Registered tag for the optical-size axis.
49*2d1272b8SAndroid Build Coastguard Worker  * <note>Note: The optical-size axis supersedes the OpenType `size` feature.</note>
50*2d1272b8SAndroid Build Coastguard Worker  */
51*2d1272b8SAndroid Build Coastguard Worker #define HB_OT_TAG_VAR_AXIS_OPTICAL_SIZE	HB_TAG('o','p','s','z')
52*2d1272b8SAndroid Build Coastguard Worker 
53*2d1272b8SAndroid Build Coastguard Worker /**
54*2d1272b8SAndroid Build Coastguard Worker  * HB_OT_TAG_VAR_AXIS_SLANT:
55*2d1272b8SAndroid Build Coastguard Worker  *
56*2d1272b8SAndroid Build Coastguard Worker  * Registered tag for the slant axis
57*2d1272b8SAndroid Build Coastguard Worker  */
58*2d1272b8SAndroid Build Coastguard Worker #define HB_OT_TAG_VAR_AXIS_SLANT	HB_TAG('s','l','n','t')
59*2d1272b8SAndroid Build Coastguard Worker 
60*2d1272b8SAndroid Build Coastguard Worker /**
61*2d1272b8SAndroid Build Coastguard Worker  * HB_OT_TAG_VAR_AXIS_WIDTH:
62*2d1272b8SAndroid Build Coastguard Worker  *
63*2d1272b8SAndroid Build Coastguard Worker  * Registered tag for the width axis.
64*2d1272b8SAndroid Build Coastguard Worker  */
65*2d1272b8SAndroid Build Coastguard Worker #define HB_OT_TAG_VAR_AXIS_WIDTH	HB_TAG('w','d','t','h')
66*2d1272b8SAndroid Build Coastguard Worker 
67*2d1272b8SAndroid Build Coastguard Worker /**
68*2d1272b8SAndroid Build Coastguard Worker  * HB_OT_TAG_VAR_AXIS_WEIGHT:
69*2d1272b8SAndroid Build Coastguard Worker  *
70*2d1272b8SAndroid Build Coastguard Worker  * Registered tag for the weight axis.
71*2d1272b8SAndroid Build Coastguard Worker  */
72*2d1272b8SAndroid Build Coastguard Worker #define HB_OT_TAG_VAR_AXIS_WEIGHT	HB_TAG('w','g','h','t')
73*2d1272b8SAndroid Build Coastguard Worker 
74*2d1272b8SAndroid Build Coastguard Worker 
75*2d1272b8SAndroid Build Coastguard Worker /*
76*2d1272b8SAndroid Build Coastguard Worker  * fvar / avar
77*2d1272b8SAndroid Build Coastguard Worker  */
78*2d1272b8SAndroid Build Coastguard Worker 
79*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_bool_t
80*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_has_data (hb_face_t *face);
81*2d1272b8SAndroid Build Coastguard Worker 
82*2d1272b8SAndroid Build Coastguard Worker 
83*2d1272b8SAndroid Build Coastguard Worker /*
84*2d1272b8SAndroid Build Coastguard Worker  * Variation axes.
85*2d1272b8SAndroid Build Coastguard Worker  */
86*2d1272b8SAndroid Build Coastguard Worker 
87*2d1272b8SAndroid Build Coastguard Worker 
88*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN unsigned int
89*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_get_axis_count (hb_face_t *face);
90*2d1272b8SAndroid Build Coastguard Worker 
91*2d1272b8SAndroid Build Coastguard Worker /**
92*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_axis_flags_t:
93*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_VAR_AXIS_FLAG_HIDDEN: The axis should not be exposed directly in user interfaces.
94*2d1272b8SAndroid Build Coastguard Worker  *
95*2d1272b8SAndroid Build Coastguard Worker  * Flags for #hb_ot_var_axis_info_t.
96*2d1272b8SAndroid Build Coastguard Worker  *
97*2d1272b8SAndroid Build Coastguard Worker  * Since: 2.2.0
98*2d1272b8SAndroid Build Coastguard Worker  */
99*2d1272b8SAndroid Build Coastguard Worker typedef enum { /*< flags >*/
100*2d1272b8SAndroid Build Coastguard Worker   HB_OT_VAR_AXIS_FLAG_HIDDEN	= 0x00000001u,
101*2d1272b8SAndroid Build Coastguard Worker 
102*2d1272b8SAndroid Build Coastguard Worker   /*< private >*/
103*2d1272b8SAndroid Build Coastguard Worker   _HB_OT_VAR_AXIS_FLAG_MAX_VALUE= HB_TAG_MAX_SIGNED /*< skip >*/
104*2d1272b8SAndroid Build Coastguard Worker } hb_ot_var_axis_flags_t;
105*2d1272b8SAndroid Build Coastguard Worker 
106*2d1272b8SAndroid Build Coastguard Worker /**
107*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_axis_info_t:
108*2d1272b8SAndroid Build Coastguard Worker  * @axis_index: Index of the axis in the variation-axis array
109*2d1272b8SAndroid Build Coastguard Worker  * @tag: The #hb_tag_t tag identifying the design variation of the axis
110*2d1272b8SAndroid Build Coastguard Worker  * @name_id: The `name` table Name ID that provides display names for the axis
111*2d1272b8SAndroid Build Coastguard Worker  * @flags: The #hb_ot_var_axis_flags_t flags for the axis
112*2d1272b8SAndroid Build Coastguard Worker  * @min_value: The minimum value on the variation axis that the font covers
113*2d1272b8SAndroid Build Coastguard Worker  * @default_value: The position on the variation axis corresponding to the font's defaults
114*2d1272b8SAndroid Build Coastguard Worker  * @max_value: The maximum value on the variation axis that the font covers
115*2d1272b8SAndroid Build Coastguard Worker  *
116*2d1272b8SAndroid Build Coastguard Worker  * Data type for holding variation-axis values.
117*2d1272b8SAndroid Build Coastguard Worker  *
118*2d1272b8SAndroid Build Coastguard Worker  * The minimum, default, and maximum values are in un-normalized, user scales.
119*2d1272b8SAndroid Build Coastguard Worker  *
120*2d1272b8SAndroid Build Coastguard Worker  * <note>Note: at present, the only flag defined for @flags is
121*2d1272b8SAndroid Build Coastguard Worker  * #HB_OT_VAR_AXIS_FLAG_HIDDEN.</note>
122*2d1272b8SAndroid Build Coastguard Worker  *
123*2d1272b8SAndroid Build Coastguard Worker  * Since: 2.2.0
124*2d1272b8SAndroid Build Coastguard Worker  */
125*2d1272b8SAndroid Build Coastguard Worker typedef struct hb_ot_var_axis_info_t {
126*2d1272b8SAndroid Build Coastguard Worker   unsigned int			axis_index;
127*2d1272b8SAndroid Build Coastguard Worker   hb_tag_t			tag;
128*2d1272b8SAndroid Build Coastguard Worker   hb_ot_name_id_t		name_id;
129*2d1272b8SAndroid Build Coastguard Worker   hb_ot_var_axis_flags_t	flags;
130*2d1272b8SAndroid Build Coastguard Worker   float				min_value;
131*2d1272b8SAndroid Build Coastguard Worker   float				default_value;
132*2d1272b8SAndroid Build Coastguard Worker   float				max_value;
133*2d1272b8SAndroid Build Coastguard Worker   /*< private >*/
134*2d1272b8SAndroid Build Coastguard Worker   unsigned int			reserved;
135*2d1272b8SAndroid Build Coastguard Worker } hb_ot_var_axis_info_t;
136*2d1272b8SAndroid Build Coastguard Worker 
137*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN unsigned int
138*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_get_axis_infos (hb_face_t             *face,
139*2d1272b8SAndroid Build Coastguard Worker 			  unsigned int           start_offset,
140*2d1272b8SAndroid Build Coastguard Worker 			  unsigned int          *axes_count /* IN/OUT */,
141*2d1272b8SAndroid Build Coastguard Worker 			  hb_ot_var_axis_info_t *axes_array /* OUT */);
142*2d1272b8SAndroid Build Coastguard Worker 
143*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_bool_t
144*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_find_axis_info (hb_face_t             *face,
145*2d1272b8SAndroid Build Coastguard Worker 			  hb_tag_t               axis_tag,
146*2d1272b8SAndroid Build Coastguard Worker 			  hb_ot_var_axis_info_t *axis_info);
147*2d1272b8SAndroid Build Coastguard Worker 
148*2d1272b8SAndroid Build Coastguard Worker 
149*2d1272b8SAndroid Build Coastguard Worker /*
150*2d1272b8SAndroid Build Coastguard Worker  * Named instances.
151*2d1272b8SAndroid Build Coastguard Worker  */
152*2d1272b8SAndroid Build Coastguard Worker 
153*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN unsigned int
154*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_get_named_instance_count (hb_face_t *face);
155*2d1272b8SAndroid Build Coastguard Worker 
156*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_ot_name_id_t
157*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_named_instance_get_subfamily_name_id (hb_face_t   *face,
158*2d1272b8SAndroid Build Coastguard Worker 						unsigned int instance_index);
159*2d1272b8SAndroid Build Coastguard Worker 
160*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_ot_name_id_t
161*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_named_instance_get_postscript_name_id (hb_face_t  *face,
162*2d1272b8SAndroid Build Coastguard Worker 						unsigned int instance_index);
163*2d1272b8SAndroid Build Coastguard Worker 
164*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN unsigned int
165*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_named_instance_get_design_coords (hb_face_t    *face,
166*2d1272b8SAndroid Build Coastguard Worker 					    unsigned int  instance_index,
167*2d1272b8SAndroid Build Coastguard Worker 					    unsigned int *coords_length, /* IN/OUT */
168*2d1272b8SAndroid Build Coastguard Worker 					    float        *coords         /* OUT */);
169*2d1272b8SAndroid Build Coastguard Worker 
170*2d1272b8SAndroid Build Coastguard Worker 
171*2d1272b8SAndroid Build Coastguard Worker /*
172*2d1272b8SAndroid Build Coastguard Worker  * Conversions.
173*2d1272b8SAndroid Build Coastguard Worker  */
174*2d1272b8SAndroid Build Coastguard Worker 
175*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN void
176*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_normalize_variations (hb_face_t            *face,
177*2d1272b8SAndroid Build Coastguard Worker 				const hb_variation_t *variations, /* IN */
178*2d1272b8SAndroid Build Coastguard Worker 				unsigned int          variations_length,
179*2d1272b8SAndroid Build Coastguard Worker 				int                  *coords, /* OUT */
180*2d1272b8SAndroid Build Coastguard Worker 				unsigned int          coords_length);
181*2d1272b8SAndroid Build Coastguard Worker 
182*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN void
183*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_normalize_coords (hb_face_t    *face,
184*2d1272b8SAndroid Build Coastguard Worker 			    unsigned int coords_length,
185*2d1272b8SAndroid Build Coastguard Worker 			    const float *design_coords, /* IN */
186*2d1272b8SAndroid Build Coastguard Worker 			    int *normalized_coords /* OUT */);
187*2d1272b8SAndroid Build Coastguard Worker 
188*2d1272b8SAndroid Build Coastguard Worker 
189*2d1272b8SAndroid Build Coastguard Worker HB_END_DECLS
190*2d1272b8SAndroid Build Coastguard Worker 
191*2d1272b8SAndroid Build Coastguard Worker #endif /* HB_OT_VAR_H */
192