[font] Remember named_instance index
Specially, in hb_font_set_variations() default to the named_instance for unspecified axes. Fixes https://github.com/harfbuzz/harfbuzz/issues/1883
This commit is contained in:
parent
14a83d6cc7
commit
d195e077e9
|
@ -1776,6 +1776,7 @@ DEFINE_NULL_INSTANCE (hb_font_t) =
|
||||||
0, /* y_ppem */
|
0, /* y_ppem */
|
||||||
0, /* ptem */
|
0, /* ptem */
|
||||||
|
|
||||||
|
(unsigned) -1, /* instance_index */
|
||||||
0, /* num_coords */
|
0, /* num_coords */
|
||||||
nullptr, /* coords */
|
nullptr, /* coords */
|
||||||
nullptr, /* design_coords */
|
nullptr, /* design_coords */
|
||||||
|
@ -1805,6 +1806,7 @@ _hb_font_create (hb_face_t *face)
|
||||||
font->x_scale = font->y_scale = face->get_upem ();
|
font->x_scale = font->y_scale = face->get_upem ();
|
||||||
font->x_multf = font->y_multf = 1.f;
|
font->x_multf = font->y_multf = 1.f;
|
||||||
font->x_mult = font->y_mult = 1 << 16;
|
font->x_mult = font->y_mult = 1 << 16;
|
||||||
|
font->instance_index = (unsigned) -1;
|
||||||
|
|
||||||
return font;
|
return font;
|
||||||
}
|
}
|
||||||
|
@ -2513,7 +2515,7 @@ hb_font_set_variations (hb_font_t *font,
|
||||||
|
|
||||||
font->serial_coords = ++font->serial;
|
font->serial_coords = ++font->serial;
|
||||||
|
|
||||||
if (!variations_length)
|
if (!variations_length && font->instance_index == (unsigned) -1)
|
||||||
{
|
{
|
||||||
hb_font_set_var_coords_normalized (font, nullptr, 0);
|
hb_font_set_var_coords_normalized (font, nullptr, 0);
|
||||||
return;
|
return;
|
||||||
|
@ -2533,9 +2535,17 @@ hb_font_set_variations (hb_font_t *font,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Initialize design coords to default from fvar. */
|
/* Initialize design coords. */
|
||||||
for (unsigned int i = 0; i < coords_length; i++)
|
if (font->instance_index == (unsigned) -1)
|
||||||
design_coords[i] = axes[i].get_default ();
|
for (unsigned int i = 0; i < coords_length; i++)
|
||||||
|
design_coords[i] = axes[i].get_default ();
|
||||||
|
else
|
||||||
|
{
|
||||||
|
unsigned count = coords_length;
|
||||||
|
hb_ot_var_named_instance_get_design_coords (font->face, font->instance_index,
|
||||||
|
&count, design_coords);
|
||||||
|
assert (count == coords_length);
|
||||||
|
}
|
||||||
|
|
||||||
for (unsigned int i = 0; i < variations_length; i++)
|
for (unsigned int i = 0; i < variations_length; i++)
|
||||||
{
|
{
|
||||||
|
@ -2543,13 +2553,11 @@ hb_font_set_variations (hb_font_t *font,
|
||||||
const auto v = variations[i].value;
|
const auto v = variations[i].value;
|
||||||
for (unsigned axis_index = 0; axis_index < coords_length; axis_index++)
|
for (unsigned axis_index = 0; axis_index < coords_length; axis_index++)
|
||||||
if (axes[axis_index].axisTag == tag)
|
if (axes[axis_index].axisTag == tag)
|
||||||
{
|
|
||||||
design_coords[axis_index] = v;
|
design_coords[axis_index] = v;
|
||||||
normalized[axis_index] = fvar.normalize_axis_value (axis_index, v);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
font->face->table.avar->map_coords (normalized, coords_length);
|
font->face->table.avar->map_coords (normalized, coords_length);
|
||||||
|
|
||||||
|
hb_ot_var_normalize_coords (font->face, coords_length, design_coords, normalized);
|
||||||
_hb_font_adopt_var_coords (font, normalized, design_coords, coords_length);
|
_hb_font_adopt_var_coords (font, normalized, design_coords, coords_length);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2611,17 +2619,13 @@ hb_font_set_var_named_instance (hb_font_t *font,
|
||||||
if (hb_object_is_immutable (font))
|
if (hb_object_is_immutable (font))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
font->serial_coords = ++font->serial;
|
if (font->instance_index == instance_index)
|
||||||
|
|
||||||
unsigned int coords_length = hb_ot_var_named_instance_get_design_coords (font->face, instance_index, nullptr, nullptr);
|
|
||||||
|
|
||||||
float *coords = coords_length ? (float *) hb_calloc (coords_length, sizeof (float)) : nullptr;
|
|
||||||
if (unlikely (coords_length && !coords))
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
hb_ot_var_named_instance_get_design_coords (font->face, instance_index, &coords_length, coords);
|
font->serial_coords = ++font->serial;
|
||||||
hb_font_set_var_coords_design (font, coords, coords_length);
|
|
||||||
hb_free (coords);
|
font->instance_index = instance_index;
|
||||||
|
hb_font_set_variations (font, nullptr, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -126,6 +126,7 @@ struct hb_font_t
|
||||||
float ptem;
|
float ptem;
|
||||||
|
|
||||||
/* Font variation coordinates. */
|
/* Font variation coordinates. */
|
||||||
|
unsigned int instance_index;
|
||||||
unsigned int num_coords;
|
unsigned int num_coords;
|
||||||
int *coords;
|
int *coords;
|
||||||
float *design_coords;
|
float *design_coords;
|
||||||
|
|
Loading…
Reference in New Issue