xref: /aosp_15_r20/external/harfbuzz_ng/src/hb-ot-var.cc (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  * Google Author(s): Behdad Esfahbod
25*2d1272b8SAndroid Build Coastguard Worker  */
26*2d1272b8SAndroid Build Coastguard Worker 
27*2d1272b8SAndroid Build Coastguard Worker #include "hb.hh"
28*2d1272b8SAndroid Build Coastguard Worker 
29*2d1272b8SAndroid Build Coastguard Worker #ifndef HB_NO_VAR
30*2d1272b8SAndroid Build Coastguard Worker 
31*2d1272b8SAndroid Build Coastguard Worker #include "hb-ot-var.h"
32*2d1272b8SAndroid Build Coastguard Worker 
33*2d1272b8SAndroid Build Coastguard Worker #include "hb-ot-var-avar-table.hh"
34*2d1272b8SAndroid Build Coastguard Worker #include "hb-ot-var-fvar-table.hh"
35*2d1272b8SAndroid Build Coastguard Worker #include "hb-ot-var-mvar-table.hh"
36*2d1272b8SAndroid Build Coastguard Worker 
37*2d1272b8SAndroid Build Coastguard Worker 
38*2d1272b8SAndroid Build Coastguard Worker /**
39*2d1272b8SAndroid Build Coastguard Worker  * SECTION:hb-ot-var
40*2d1272b8SAndroid Build Coastguard Worker  * @title: hb-ot-var
41*2d1272b8SAndroid Build Coastguard Worker  * @short_description: OpenType Font Variations
42*2d1272b8SAndroid Build Coastguard Worker  * @include: hb-ot.h
43*2d1272b8SAndroid Build Coastguard Worker  *
44*2d1272b8SAndroid Build Coastguard Worker  * Functions for fetching information about OpenType Variable Fonts.
45*2d1272b8SAndroid Build Coastguard Worker  **/
46*2d1272b8SAndroid Build Coastguard Worker 
47*2d1272b8SAndroid Build Coastguard Worker 
48*2d1272b8SAndroid Build Coastguard Worker /*
49*2d1272b8SAndroid Build Coastguard Worker  * fvar/avar
50*2d1272b8SAndroid Build Coastguard Worker  */
51*2d1272b8SAndroid Build Coastguard Worker 
52*2d1272b8SAndroid Build Coastguard Worker 
53*2d1272b8SAndroid Build Coastguard Worker /**
54*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_has_data:
55*2d1272b8SAndroid Build Coastguard Worker  * @face: The #hb_face_t to work on
56*2d1272b8SAndroid Build Coastguard Worker  *
57*2d1272b8SAndroid Build Coastguard Worker  * Tests whether a face includes any OpenType variation data in the `fvar` table.
58*2d1272b8SAndroid Build Coastguard Worker  *
59*2d1272b8SAndroid Build Coastguard Worker  * Return value: `true` if data found, `false` otherwise
60*2d1272b8SAndroid Build Coastguard Worker  *
61*2d1272b8SAndroid Build Coastguard Worker  * Since: 1.4.2
62*2d1272b8SAndroid Build Coastguard Worker  **/
63*2d1272b8SAndroid Build Coastguard Worker hb_bool_t
hb_ot_var_has_data(hb_face_t * face)64*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_has_data (hb_face_t *face)
65*2d1272b8SAndroid Build Coastguard Worker {
66*2d1272b8SAndroid Build Coastguard Worker   return face->table.fvar->has_data ();
67*2d1272b8SAndroid Build Coastguard Worker }
68*2d1272b8SAndroid Build Coastguard Worker 
69*2d1272b8SAndroid Build Coastguard Worker /**
70*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_get_axis_count:
71*2d1272b8SAndroid Build Coastguard Worker  * @face: The #hb_face_t to work on
72*2d1272b8SAndroid Build Coastguard Worker  *
73*2d1272b8SAndroid Build Coastguard Worker  * Fetches the number of OpenType variation axes included in the face.
74*2d1272b8SAndroid Build Coastguard Worker  *
75*2d1272b8SAndroid Build Coastguard Worker  * Return value: the number of variation axes defined
76*2d1272b8SAndroid Build Coastguard Worker  *
77*2d1272b8SAndroid Build Coastguard Worker  * Since: 1.4.2
78*2d1272b8SAndroid Build Coastguard Worker  **/
79*2d1272b8SAndroid Build Coastguard Worker unsigned int
hb_ot_var_get_axis_count(hb_face_t * face)80*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_get_axis_count (hb_face_t *face)
81*2d1272b8SAndroid Build Coastguard Worker {
82*2d1272b8SAndroid Build Coastguard Worker   return face->table.fvar->get_axis_count ();
83*2d1272b8SAndroid Build Coastguard Worker }
84*2d1272b8SAndroid Build Coastguard Worker 
85*2d1272b8SAndroid Build Coastguard Worker #ifndef HB_DISABLE_DEPRECATED
86*2d1272b8SAndroid Build Coastguard Worker /**
87*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_get_axes:
88*2d1272b8SAndroid Build Coastguard Worker  * @face: #hb_face_t to work upon
89*2d1272b8SAndroid Build Coastguard Worker  * @start_offset: offset of the first lookup to retrieve
90*2d1272b8SAndroid Build Coastguard Worker  * @axes_count: (inout) (optional): Input = the maximum number of variation axes to return;
91*2d1272b8SAndroid Build Coastguard Worker  *                Output = the actual number of variation axes returned (may be zero)
92*2d1272b8SAndroid Build Coastguard Worker  * @axes_array: (out caller-allocates) (array length=axes_count): The array of variation axes found
93*2d1272b8SAndroid Build Coastguard Worker  *
94*2d1272b8SAndroid Build Coastguard Worker  * Fetches a list of all variation axes in the specified face. The list returned will begin
95*2d1272b8SAndroid Build Coastguard Worker  * at the offset provided.
96*2d1272b8SAndroid Build Coastguard Worker  *
97*2d1272b8SAndroid Build Coastguard Worker  * Since: 1.4.2
98*2d1272b8SAndroid Build Coastguard Worker  * Deprecated: 2.2.0: use hb_ot_var_get_axis_infos() instead
99*2d1272b8SAndroid Build Coastguard Worker  **/
100*2d1272b8SAndroid Build Coastguard Worker unsigned int
hb_ot_var_get_axes(hb_face_t * face,unsigned int start_offset,unsigned int * axes_count,hb_ot_var_axis_t * axes_array)101*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_get_axes (hb_face_t        *face,
102*2d1272b8SAndroid Build Coastguard Worker 		    unsigned int      start_offset,
103*2d1272b8SAndroid Build Coastguard Worker 		    unsigned int     *axes_count /* IN/OUT */,
104*2d1272b8SAndroid Build Coastguard Worker 		    hb_ot_var_axis_t *axes_array /* OUT */)
105*2d1272b8SAndroid Build Coastguard Worker {
106*2d1272b8SAndroid Build Coastguard Worker   return face->table.fvar->get_axes_deprecated (start_offset, axes_count, axes_array);
107*2d1272b8SAndroid Build Coastguard Worker }
108*2d1272b8SAndroid Build Coastguard Worker 
109*2d1272b8SAndroid Build Coastguard Worker /**
110*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_find_axis:
111*2d1272b8SAndroid Build Coastguard Worker  * @face: #hb_face_t to work upon
112*2d1272b8SAndroid Build Coastguard Worker  * @axis_tag: The #hb_tag_t of the variation axis to query
113*2d1272b8SAndroid Build Coastguard Worker  * @axis_index: The index of the variation axis
114*2d1272b8SAndroid Build Coastguard Worker  * @axis_info: (out): The #hb_ot_var_axis_info_t of the axis tag queried
115*2d1272b8SAndroid Build Coastguard Worker  *
116*2d1272b8SAndroid Build Coastguard Worker  * Fetches the variation-axis information corresponding to the specified axis tag
117*2d1272b8SAndroid Build Coastguard Worker  * in the specified face.
118*2d1272b8SAndroid Build Coastguard Worker  *
119*2d1272b8SAndroid Build Coastguard Worker  * Since: 1.4.2
120*2d1272b8SAndroid Build Coastguard Worker  * Deprecated: 2.2.0 - use hb_ot_var_find_axis_info() instead
121*2d1272b8SAndroid Build Coastguard Worker  **/
122*2d1272b8SAndroid Build Coastguard Worker hb_bool_t
hb_ot_var_find_axis(hb_face_t * face,hb_tag_t axis_tag,unsigned int * axis_index,hb_ot_var_axis_t * axis_info)123*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_find_axis (hb_face_t        *face,
124*2d1272b8SAndroid Build Coastguard Worker 		     hb_tag_t          axis_tag,
125*2d1272b8SAndroid Build Coastguard Worker 		     unsigned int     *axis_index,
126*2d1272b8SAndroid Build Coastguard Worker 		     hb_ot_var_axis_t *axis_info)
127*2d1272b8SAndroid Build Coastguard Worker {
128*2d1272b8SAndroid Build Coastguard Worker   return face->table.fvar->find_axis_deprecated (axis_tag, axis_index, axis_info);
129*2d1272b8SAndroid Build Coastguard Worker }
130*2d1272b8SAndroid Build Coastguard Worker #endif
131*2d1272b8SAndroid Build Coastguard Worker 
132*2d1272b8SAndroid Build Coastguard Worker /**
133*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_get_axis_infos:
134*2d1272b8SAndroid Build Coastguard Worker  * @face: #hb_face_t to work upon
135*2d1272b8SAndroid Build Coastguard Worker  * @start_offset: offset of the first lookup to retrieve
136*2d1272b8SAndroid Build Coastguard Worker  * @axes_count: (inout) (optional): Input = the maximum number of variation axes to return;
137*2d1272b8SAndroid Build Coastguard Worker  *                Output = the actual number of variation axes returned (may be zero)
138*2d1272b8SAndroid Build Coastguard Worker  * @axes_array: (out caller-allocates) (array length=axes_count): The array of variation axes found
139*2d1272b8SAndroid Build Coastguard Worker  *
140*2d1272b8SAndroid Build Coastguard Worker  * Fetches a list of all variation axes in the specified face. The list returned will begin
141*2d1272b8SAndroid Build Coastguard Worker  * at the offset provided.
142*2d1272b8SAndroid Build Coastguard Worker  *
143*2d1272b8SAndroid Build Coastguard Worker  * Return value: the number of variation axes in the face
144*2d1272b8SAndroid Build Coastguard Worker  *
145*2d1272b8SAndroid Build Coastguard Worker  * Since: 2.2.0
146*2d1272b8SAndroid Build Coastguard Worker  **/
147*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN unsigned int
hb_ot_var_get_axis_infos(hb_face_t * face,unsigned int start_offset,unsigned int * axes_count,hb_ot_var_axis_info_t * axes_array)148*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_get_axis_infos (hb_face_t             *face,
149*2d1272b8SAndroid Build Coastguard Worker 			  unsigned int           start_offset,
150*2d1272b8SAndroid Build Coastguard Worker 			  unsigned int          *axes_count /* IN/OUT */,
151*2d1272b8SAndroid Build Coastguard Worker 			  hb_ot_var_axis_info_t *axes_array /* OUT */)
152*2d1272b8SAndroid Build Coastguard Worker {
153*2d1272b8SAndroid Build Coastguard Worker   return face->table.fvar->get_axis_infos (start_offset, axes_count, axes_array);
154*2d1272b8SAndroid Build Coastguard Worker }
155*2d1272b8SAndroid Build Coastguard Worker 
156*2d1272b8SAndroid Build Coastguard Worker /**
157*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_find_axis_info:
158*2d1272b8SAndroid Build Coastguard Worker  * @face: #hb_face_t to work upon
159*2d1272b8SAndroid Build Coastguard Worker  * @axis_tag: The #hb_tag_t of the variation axis to query
160*2d1272b8SAndroid Build Coastguard Worker  * @axis_info: (out): The #hb_ot_var_axis_info_t of the axis tag queried
161*2d1272b8SAndroid Build Coastguard Worker  *
162*2d1272b8SAndroid Build Coastguard Worker  * Fetches the variation-axis information corresponding to the specified axis tag
163*2d1272b8SAndroid Build Coastguard Worker  * in the specified face.
164*2d1272b8SAndroid Build Coastguard Worker  *
165*2d1272b8SAndroid Build Coastguard Worker  * Return value: `true` if data found, `false` otherwise
166*2d1272b8SAndroid Build Coastguard Worker  *
167*2d1272b8SAndroid Build Coastguard Worker  * Since: 2.2.0
168*2d1272b8SAndroid Build Coastguard Worker  **/
169*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN hb_bool_t
hb_ot_var_find_axis_info(hb_face_t * face,hb_tag_t axis_tag,hb_ot_var_axis_info_t * axis_info)170*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_find_axis_info (hb_face_t             *face,
171*2d1272b8SAndroid Build Coastguard Worker 			  hb_tag_t               axis_tag,
172*2d1272b8SAndroid Build Coastguard Worker 			  hb_ot_var_axis_info_t *axis_info)
173*2d1272b8SAndroid Build Coastguard Worker {
174*2d1272b8SAndroid Build Coastguard Worker   return face->table.fvar->find_axis_info (axis_tag, axis_info);
175*2d1272b8SAndroid Build Coastguard Worker }
176*2d1272b8SAndroid Build Coastguard Worker 
177*2d1272b8SAndroid Build Coastguard Worker 
178*2d1272b8SAndroid Build Coastguard Worker /*
179*2d1272b8SAndroid Build Coastguard Worker  * Named instances.
180*2d1272b8SAndroid Build Coastguard Worker  */
181*2d1272b8SAndroid Build Coastguard Worker 
182*2d1272b8SAndroid Build Coastguard Worker /**
183*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_get_named_instance_count:
184*2d1272b8SAndroid Build Coastguard Worker  * @face: The #hb_face_t to work on
185*2d1272b8SAndroid Build Coastguard Worker  *
186*2d1272b8SAndroid Build Coastguard Worker  * Fetches the number of named instances included in the face.
187*2d1272b8SAndroid Build Coastguard Worker  *
188*2d1272b8SAndroid Build Coastguard Worker  * Return value: the number of named instances defined
189*2d1272b8SAndroid Build Coastguard Worker  *
190*2d1272b8SAndroid Build Coastguard Worker  * Since: 2.2.0
191*2d1272b8SAndroid Build Coastguard Worker  **/
192*2d1272b8SAndroid Build Coastguard Worker unsigned int
hb_ot_var_get_named_instance_count(hb_face_t * face)193*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_get_named_instance_count (hb_face_t *face)
194*2d1272b8SAndroid Build Coastguard Worker {
195*2d1272b8SAndroid Build Coastguard Worker   return face->table.fvar->get_instance_count ();
196*2d1272b8SAndroid Build Coastguard Worker }
197*2d1272b8SAndroid Build Coastguard Worker 
198*2d1272b8SAndroid Build Coastguard Worker /**
199*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_named_instance_get_subfamily_name_id:
200*2d1272b8SAndroid Build Coastguard Worker  * @face: The #hb_face_t to work on
201*2d1272b8SAndroid Build Coastguard Worker  * @instance_index: The index of the named instance to query
202*2d1272b8SAndroid Build Coastguard Worker  *
203*2d1272b8SAndroid Build Coastguard Worker  * Fetches the `name` table Name ID that provides display names for
204*2d1272b8SAndroid Build Coastguard Worker  * the "Subfamily name" defined for the given named instance in the face.
205*2d1272b8SAndroid Build Coastguard Worker  *
206*2d1272b8SAndroid Build Coastguard Worker  * Return value: the Name ID found for the Subfamily name
207*2d1272b8SAndroid Build Coastguard Worker  *
208*2d1272b8SAndroid Build Coastguard Worker  * Since: 2.2.0
209*2d1272b8SAndroid Build Coastguard Worker  **/
210*2d1272b8SAndroid Build Coastguard Worker hb_ot_name_id_t
hb_ot_var_named_instance_get_subfamily_name_id(hb_face_t * face,unsigned int instance_index)211*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_named_instance_get_subfamily_name_id (hb_face_t   *face,
212*2d1272b8SAndroid Build Coastguard Worker 						unsigned int instance_index)
213*2d1272b8SAndroid Build Coastguard Worker {
214*2d1272b8SAndroid Build Coastguard Worker   return face->table.fvar->get_instance_subfamily_name_id (instance_index);
215*2d1272b8SAndroid Build Coastguard Worker }
216*2d1272b8SAndroid Build Coastguard Worker 
217*2d1272b8SAndroid Build Coastguard Worker /**
218*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_named_instance_get_postscript_name_id:
219*2d1272b8SAndroid Build Coastguard Worker  * @face: The #hb_face_t to work on
220*2d1272b8SAndroid Build Coastguard Worker  * @instance_index: The index of the named instance to query
221*2d1272b8SAndroid Build Coastguard Worker  *
222*2d1272b8SAndroid Build Coastguard Worker  * Fetches the `name` table Name ID that provides display names for
223*2d1272b8SAndroid Build Coastguard Worker  * the "PostScript name" defined for the given named instance in the face.
224*2d1272b8SAndroid Build Coastguard Worker  *
225*2d1272b8SAndroid Build Coastguard Worker  * Return value: the Name ID found for the PostScript name
226*2d1272b8SAndroid Build Coastguard Worker  *
227*2d1272b8SAndroid Build Coastguard Worker  * Since: 2.2.0
228*2d1272b8SAndroid Build Coastguard Worker  **/
229*2d1272b8SAndroid Build Coastguard Worker hb_ot_name_id_t
hb_ot_var_named_instance_get_postscript_name_id(hb_face_t * face,unsigned int instance_index)230*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_named_instance_get_postscript_name_id (hb_face_t  *face,
231*2d1272b8SAndroid Build Coastguard Worker 						unsigned int instance_index)
232*2d1272b8SAndroid Build Coastguard Worker {
233*2d1272b8SAndroid Build Coastguard Worker   return face->table.fvar->get_instance_postscript_name_id (instance_index);
234*2d1272b8SAndroid Build Coastguard Worker }
235*2d1272b8SAndroid Build Coastguard Worker 
236*2d1272b8SAndroid Build Coastguard Worker /**
237*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_named_instance_get_design_coords:
238*2d1272b8SAndroid Build Coastguard Worker  * @face: The #hb_face_t to work on
239*2d1272b8SAndroid Build Coastguard Worker  * @instance_index: The index of the named instance to query
240*2d1272b8SAndroid Build Coastguard Worker  * @coords_length: (inout) (optional): Input = the maximum number of coordinates to return;
241*2d1272b8SAndroid Build Coastguard Worker  *                 Output = the actual number of coordinates returned (may be zero)
242*2d1272b8SAndroid Build Coastguard Worker  * @coords: (out) (array length=coords_length): The array of coordinates found for the query
243*2d1272b8SAndroid Build Coastguard Worker  *
244*2d1272b8SAndroid Build Coastguard Worker  * Fetches the design-space coordinates corresponding to the given
245*2d1272b8SAndroid Build Coastguard Worker  * named instance in the face.
246*2d1272b8SAndroid Build Coastguard Worker  *
247*2d1272b8SAndroid Build Coastguard Worker  * Return value: the number of variation axes in the face
248*2d1272b8SAndroid Build Coastguard Worker  *
249*2d1272b8SAndroid Build Coastguard Worker  * Since: 2.2.0
250*2d1272b8SAndroid Build Coastguard Worker  **/
251*2d1272b8SAndroid Build Coastguard Worker unsigned int
hb_ot_var_named_instance_get_design_coords(hb_face_t * face,unsigned int instance_index,unsigned int * coords_length,float * coords)252*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_named_instance_get_design_coords (hb_face_t    *face,
253*2d1272b8SAndroid Build Coastguard Worker 					    unsigned int  instance_index,
254*2d1272b8SAndroid Build Coastguard Worker 					    unsigned int *coords_length, /* IN/OUT */
255*2d1272b8SAndroid Build Coastguard Worker 					    float        *coords         /* OUT */)
256*2d1272b8SAndroid Build Coastguard Worker {
257*2d1272b8SAndroid Build Coastguard Worker   return face->table.fvar->get_instance_coords (instance_index, coords_length, coords);
258*2d1272b8SAndroid Build Coastguard Worker }
259*2d1272b8SAndroid Build Coastguard Worker 
260*2d1272b8SAndroid Build Coastguard Worker 
261*2d1272b8SAndroid Build Coastguard Worker /**
262*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_normalize_variations:
263*2d1272b8SAndroid Build Coastguard Worker  * @face: The #hb_face_t to work on
264*2d1272b8SAndroid Build Coastguard Worker  * @variations: The array of variations to normalize
265*2d1272b8SAndroid Build Coastguard Worker  * @variations_length: The number of variations to normalize
266*2d1272b8SAndroid Build Coastguard Worker  * @coords: (out) (array length=coords_length): The array of normalized coordinates
267*2d1272b8SAndroid Build Coastguard Worker  * @coords_length: The length of the coordinate array
268*2d1272b8SAndroid Build Coastguard Worker  *
269*2d1272b8SAndroid Build Coastguard Worker  * Normalizes all of the coordinates in the given list of variation axes.
270*2d1272b8SAndroid Build Coastguard Worker  *
271*2d1272b8SAndroid Build Coastguard Worker  * Since: 1.4.2
272*2d1272b8SAndroid Build Coastguard Worker  **/
273*2d1272b8SAndroid Build Coastguard Worker void
hb_ot_var_normalize_variations(hb_face_t * face,const hb_variation_t * variations,unsigned int variations_length,int * coords,unsigned int coords_length)274*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_normalize_variations (hb_face_t            *face,
275*2d1272b8SAndroid Build Coastguard Worker 				const hb_variation_t *variations, /* IN */
276*2d1272b8SAndroid Build Coastguard Worker 				unsigned int          variations_length,
277*2d1272b8SAndroid Build Coastguard Worker 				int                  *coords, /* OUT */
278*2d1272b8SAndroid Build Coastguard Worker 				unsigned int          coords_length)
279*2d1272b8SAndroid Build Coastguard Worker {
280*2d1272b8SAndroid Build Coastguard Worker   for (unsigned int i = 0; i < coords_length; i++)
281*2d1272b8SAndroid Build Coastguard Worker     coords[i] = 0;
282*2d1272b8SAndroid Build Coastguard Worker 
283*2d1272b8SAndroid Build Coastguard Worker   const OT::fvar &fvar = *face->table.fvar;
284*2d1272b8SAndroid Build Coastguard Worker   for (unsigned int i = 0; i < variations_length; i++)
285*2d1272b8SAndroid Build Coastguard Worker   {
286*2d1272b8SAndroid Build Coastguard Worker     hb_ot_var_axis_info_t info;
287*2d1272b8SAndroid Build Coastguard Worker     if (hb_ot_var_find_axis_info (face, variations[i].tag, &info) &&
288*2d1272b8SAndroid Build Coastguard Worker 	info.axis_index < coords_length)
289*2d1272b8SAndroid Build Coastguard Worker       coords[info.axis_index] = fvar.normalize_axis_value (info.axis_index, variations[i].value);
290*2d1272b8SAndroid Build Coastguard Worker   }
291*2d1272b8SAndroid Build Coastguard Worker 
292*2d1272b8SAndroid Build Coastguard Worker   face->table.avar->map_coords (coords, coords_length);
293*2d1272b8SAndroid Build Coastguard Worker }
294*2d1272b8SAndroid Build Coastguard Worker 
295*2d1272b8SAndroid Build Coastguard Worker /**
296*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_var_normalize_coords:
297*2d1272b8SAndroid Build Coastguard Worker  * @face: The #hb_face_t to work on
298*2d1272b8SAndroid Build Coastguard Worker  * @coords_length: The length of the coordinate array
299*2d1272b8SAndroid Build Coastguard Worker  * @design_coords: The design-space coordinates to normalize
300*2d1272b8SAndroid Build Coastguard Worker  * @normalized_coords: (out): The normalized coordinates
301*2d1272b8SAndroid Build Coastguard Worker  *
302*2d1272b8SAndroid Build Coastguard Worker  * Normalizes the given design-space coordinates. The minimum and maximum
303*2d1272b8SAndroid Build Coastguard Worker  * values for the axis are mapped to the interval [-1,1], with the default
304*2d1272b8SAndroid Build Coastguard Worker  * axis value mapped to 0.
305*2d1272b8SAndroid Build Coastguard Worker  *
306*2d1272b8SAndroid Build Coastguard Worker  * The normalized values have 14 bits of fixed-point sub-integer precision as per
307*2d1272b8SAndroid Build Coastguard Worker  * OpenType specification.
308*2d1272b8SAndroid Build Coastguard Worker  *
309*2d1272b8SAndroid Build Coastguard Worker  * Any additional scaling defined in the face's `avar` table is also
310*2d1272b8SAndroid Build Coastguard Worker  * applied, as described at https://docs.microsoft.com/en-us/typography/opentype/spec/avar
311*2d1272b8SAndroid Build Coastguard Worker  *
312*2d1272b8SAndroid Build Coastguard Worker  * Since: 1.4.2
313*2d1272b8SAndroid Build Coastguard Worker  **/
314*2d1272b8SAndroid Build Coastguard Worker void
hb_ot_var_normalize_coords(hb_face_t * face,unsigned int coords_length,const float * design_coords,int * normalized_coords)315*2d1272b8SAndroid Build Coastguard Worker hb_ot_var_normalize_coords (hb_face_t    *face,
316*2d1272b8SAndroid Build Coastguard Worker 			    unsigned int coords_length,
317*2d1272b8SAndroid Build Coastguard Worker 			    const float *design_coords, /* IN */
318*2d1272b8SAndroid Build Coastguard Worker 			    int *normalized_coords /* OUT */)
319*2d1272b8SAndroid Build Coastguard Worker {
320*2d1272b8SAndroid Build Coastguard Worker   const OT::fvar &fvar = *face->table.fvar;
321*2d1272b8SAndroid Build Coastguard Worker   for (unsigned int i = 0; i < coords_length; i++)
322*2d1272b8SAndroid Build Coastguard Worker     normalized_coords[i] = fvar.normalize_axis_value (i, design_coords[i]);
323*2d1272b8SAndroid Build Coastguard Worker 
324*2d1272b8SAndroid Build Coastguard Worker   face->table.avar->map_coords (normalized_coords, coords_length);
325*2d1272b8SAndroid Build Coastguard Worker }
326*2d1272b8SAndroid Build Coastguard Worker 
327*2d1272b8SAndroid Build Coastguard Worker 
328*2d1272b8SAndroid Build Coastguard Worker #endif
329