[wasm-api] Add font_copy_glyph_outline

This commit is contained in:
Behdad Esfahbod 2023-02-25 08:59:03 -07:00
parent 92a57b4b4a
commit 65966e0c3d
4 changed files with 85 additions and 2 deletions

View File

@ -27,6 +27,8 @@
#include "hb-wasm-api.hh" #include "hb-wasm-api.hh"
#include "hb-outline.hh"
namespace hb { namespace hb {
namespace wasm { namespace wasm {
@ -109,6 +111,50 @@ HB_WASM_API (void, font_glyph_to_string) (HB_WASM_EXEC_ENV
hb_font_glyph_to_string (font, glyph, s, size); hb_font_glyph_to_string (font, glyph, s, size);
} }
static_assert (sizeof (glyph_outline_point_t) == sizeof (hb_outline_point_t), "");
static_assert (sizeof (uint32_t) == sizeof (hb_outline_t::contours[0]), "");
HB_WASM_API (bool_t, font_copy_glyph_outline) (HB_WASM_EXEC_ENV
ptr_d(font_t, font),
codepoint_t glyph,
ptr_d(glyph_outline_t, outline))
{
HB_REF2OBJ (font);
HB_PTR_PARAM (glyph_outline_t, outline);
if (unlikely (!outline))
return false;
hb_outline_t hb_outline;
auto *funcs = hb_outline_recording_pen_get_funcs ();
hb_font_draw_glyph (font, glyph, funcs, &hb_outline);
if (unlikely (hb_outline.points.in_error () ||
hb_outline.contours.in_error ()))
{
outline->n_points = outline->n_contours = 0;
return false;
}
outline->n_points = hb_outline.points.length;
outline->points = wasm_runtime_module_dup_data (module_inst,
(const char *) hb_outline.points.arrayZ,
hb_outline.points.get_size ());
outline->n_contours = hb_outline.contours.length;
outline->contours = wasm_runtime_module_dup_data (module_inst,
(const char *) hb_outline.contours.arrayZ,
hb_outline.contours.get_size ());
if ((outline->n_points && !outline->points) ||
(!outline->n_contours && !outline->contours))
{
outline->n_points = outline->n_contours = 0;
return false;
}
return true;
}
}} }}

View File

@ -78,6 +78,7 @@ static NativeSymbol _hb_wasm_native_symbols[] =
NATIVE_SYMBOL ("(ii)i", font_get_glyph_v_advance), NATIVE_SYMBOL ("(ii)i", font_get_glyph_v_advance),
NATIVE_SYMBOL ("(iii)i", font_get_glyph_extents), NATIVE_SYMBOL ("(iii)i", font_get_glyph_extents),
NATIVE_SYMBOL ("(ii$*)", font_glyph_to_string), NATIVE_SYMBOL ("(ii$*)", font_glyph_to_string),
NATIVE_SYMBOL ("(iii)i", font_copy_glyph_outline),
/* shape */ /* shape */
NATIVE_SYMBOL ("(iiii$)i", shape_with), NATIVE_SYMBOL ("(iiii$)i", shape_with),

View File

@ -207,7 +207,8 @@ HB_WASM_API (position_t, font_get_glyph_v_advance) (HB_WASM_EXEC_ENV
ptr_d(font_t, font), ptr_d(font_t, font),
codepoint_t glyph); codepoint_t glyph);
typedef struct { typedef struct
{
position_t x_bearing; position_t x_bearing;
position_t y_bearing; position_t y_bearing;
position_t width; position_t width;
@ -225,9 +226,40 @@ HB_WASM_API (void, font_glyph_to_string) (HB_WASM_EXEC_ENV
char *s, uint32_t size); char *s, uint32_t size);
/* outline */
enum glyph_outline_point_type_t
{
MOVE_TO,
LINE_TO,
QUADRATIC_TO,
CUBIC_TO,
};
typedef struct
{
float x;
float y;
uint32_t type;
} glyph_outline_point_t;
typedef struct
{
uint32_t n_points;
ptr_t(glyph_outline_point_t) points;
uint32_t n_contours;
ptr_t(uint32_t) contours;
} glyph_outline_t;
HB_WASM_API (bool_t, font_copy_glyph_outline) (HB_WASM_EXEC_ENV
ptr_d(font_t, font),
codepoint_t glyph,
ptr_d(glyph_outline_t, outline));
/* shape */ /* shape */
typedef struct { typedef struct
{
tag_t tag; tag_t tag;
uint32_t value; uint32_t value;
uint32_t start; uint32_t start;

View File

@ -42,6 +42,10 @@ shape (void *shape_plan,
contents.info[i].codepoint = font_get_glyph (font, contents.info[i].codepoint, 0); contents.info[i].codepoint = font_get_glyph (font, contents.info[i].codepoint, 0);
contents.pos[i].x_advance = font_get_glyph_h_advance (font, contents.info[i].codepoint); contents.pos[i].x_advance = font_get_glyph_h_advance (font, contents.info[i].codepoint);
glyph_outline_t outline;
font_copy_glyph_outline (font, contents.info[i].codepoint, &outline);
debugprint1 ("num outline contours", outline.n_contours);
} }
bool_t ret = buffer_set_contents (buffer, &contents); bool_t ret = buffer_set_contents (buffer, &contents);