[glyf/VarComposite] Implement more

This commit is contained in:
Behdad Esfahbod 2022-10-17 12:12:40 -06:00
parent 65cc3b5e2b
commit 0a939b48a6
2 changed files with 52 additions and 5 deletions

View File

@ -69,6 +69,11 @@ struct Glyph
if (type != COMPOSITE) return composite_iter_t (); if (type != COMPOSITE) return composite_iter_t ();
return CompositeGlyph (*header, bytes).iter (); return CompositeGlyph (*header, bytes).iter ();
} }
var_composite_iter_t get_var_composite_iterator () const
{
if (type != VAR_COMPOSITE) return var_composite_iter_t ();
return VarCompositeGlyph (*header, bytes).iter ();
}
const hb_bytes_t trim_padding () const const hb_bytes_t trim_padding () const
{ {
@ -242,6 +247,10 @@ struct Glyph
contour_point_vector_t &points = inplace ? all_points : stack_points; contour_point_vector_t &points = inplace ? all_points : stack_points;
switch (type) { switch (type) {
case SIMPLE:
if (unlikely (!SimpleGlyph (*header, bytes).get_contour_points (points, phantom_only)))
return false;
break;
case COMPOSITE: case COMPOSITE:
{ {
/* pseudo component points for each component in composite glyph */ /* pseudo component points for each component in composite glyph */
@ -249,9 +258,15 @@ struct Glyph
if (unlikely (!points.resize (num_points))) return false; if (unlikely (!points.resize (num_points))) return false;
break; break;
} }
case SIMPLE: case VAR_COMPOSITE:
if (unlikely (!SimpleGlyph (*header, bytes).get_contour_points (points, phantom_only))) {
return false; points.resize (0);
//for (auto &item : get_var_composite_iterator ())
{
/* XXX */
}
}
default:
break; break;
} }
@ -358,8 +373,36 @@ struct Glyph
all_points.extend (phantoms); all_points.extend (phantoms);
} break; } break;
case VAR_COMPOSITE:
{
contour_point_vector_t comp_points;
for (auto &item : get_var_composite_iterator ())
{
comp_points.reset ();
if (unlikely (!glyf_accelerator.glyph_for_gid (item.get_gid ())
.get_points (font, glyf_accelerator, comp_points,
deltas, shift_points_hori, use_my_metrics, phantom_only, depth + 1)))
return false;
/* Apply component transformation & translation */
item.transform_points (comp_points);
/* Apply translation from gvar */
//comp_points.translate (points[comp_index]);
/* Copy phantom points from component if USE_MY_METRICS flag set */
if (use_my_metrics && item.is_use_my_metrics ())
for (unsigned int i = 0; i < PHANTOM_COUNT; i++)
phantoms[i] = comp_points[comp_points.length - PHANTOM_COUNT + i];
all_points.extend (comp_points.sub_array (0, comp_points.length - PHANTOM_COUNT));
}
all_points.extend (phantoms);
} break;
default: default:
all_points.extend (phantoms); all_points.extend (phantoms);
break;
} }
if (depth == 0 && shift_points_hori) /* Apply at top level */ if (depth == 0 && shift_points_hori) /* Apply at top level */

View File

@ -30,7 +30,7 @@ struct VarCompositeGlyphRecord
public: public:
static constexpr unsigned NUM_TRANSFORM_POINTS = 9; static constexpr unsigned NUM_TRANSFORM_POINTS = 5;
unsigned int get_size () const unsigned int get_size () const
{ {
@ -52,7 +52,9 @@ struct VarCompositeGlyphRecord
return size; return size;
} }
bool is_use_my_metrics () const { return flags & USE_MY_METRICS; } bool has_more () const { return true; }
bool is_use_my_metrics () const { return flags & USE_MY_METRICS; }
hb_codepoint_t get_gid () const hb_codepoint_t get_gid () const
{ {
@ -74,6 +76,8 @@ struct VarCompositeGlyphRecord
float matrix[4]; float matrix[4];
contour_point_t trans; contour_point_t trans;
get_transformation (matrix, trans);
points.transform (matrix); points.transform (matrix);
points.translate (trans); points.translate (trans);
} }