[glyf/VarComposite] Implement more
This commit is contained in:
parent
65cc3b5e2b
commit
0a939b48a6
|
@ -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 */
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue