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