[API] Vertical support, take 2
I like this API *much* better. Implementation still incomplete, but horizontal works.
This commit is contained in:
parent
744970af4d
commit
7e2c85de30
|
@ -52,11 +52,12 @@ struct _hb_font_funcs_t {
|
||||||
HB_FONT_FUNC_IMPLEMENT (glyph) \
|
HB_FONT_FUNC_IMPLEMENT (glyph) \
|
||||||
HB_FONT_FUNC_IMPLEMENT (glyph_h_advance) \
|
HB_FONT_FUNC_IMPLEMENT (glyph_h_advance) \
|
||||||
HB_FONT_FUNC_IMPLEMENT (glyph_v_advance) \
|
HB_FONT_FUNC_IMPLEMENT (glyph_v_advance) \
|
||||||
|
HB_FONT_FUNC_IMPLEMENT (glyph_h_origin) \
|
||||||
HB_FONT_FUNC_IMPLEMENT (glyph_v_origin) \
|
HB_FONT_FUNC_IMPLEMENT (glyph_v_origin) \
|
||||||
HB_FONT_FUNC_IMPLEMENT (h_kerning) \
|
HB_FONT_FUNC_IMPLEMENT (glyph_h_kerning) \
|
||||||
HB_FONT_FUNC_IMPLEMENT (v_kerning) \
|
HB_FONT_FUNC_IMPLEMENT (glyph_v_kerning) \
|
||||||
HB_FONT_FUNC_IMPLEMENT (glyph_extents) \
|
HB_FONT_FUNC_IMPLEMENT (glyph_extents) \
|
||||||
HB_FONT_FUNC_IMPLEMENT (contour_point)
|
HB_FONT_FUNC_IMPLEMENT (glyph_contour_point)
|
||||||
|
|
||||||
|
|
||||||
struct {
|
struct {
|
||||||
|
|
103
src/hb-font.cc
103
src/hb-font.cc
|
@ -96,6 +96,26 @@ hb_font_get_glyph_v_advance_nil (hb_font_t *font HB_UNUSED,
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static hb_bool_t
|
||||||
|
hb_font_get_glyph_h_origin_nil (hb_font_t *font HB_UNUSED,
|
||||||
|
void *font_data HB_UNUSED,
|
||||||
|
hb_codepoint_t glyph,
|
||||||
|
hb_position_t *x_origin,
|
||||||
|
hb_position_t *y_origin,
|
||||||
|
void *user_data HB_UNUSED)
|
||||||
|
{
|
||||||
|
if (font->parent) {
|
||||||
|
hb_bool_t ret = hb_font_get_glyph_h_origin (font->parent,
|
||||||
|
glyph,
|
||||||
|
x_origin, y_origin);
|
||||||
|
font->parent_scale_distance (x_origin, y_origin);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
*x_origin = *y_origin = 0;
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
static hb_bool_t
|
static hb_bool_t
|
||||||
hb_font_get_glyph_v_origin_nil (hb_font_t *font HB_UNUSED,
|
hb_font_get_glyph_v_origin_nil (hb_font_t *font HB_UNUSED,
|
||||||
void *font_data HB_UNUSED,
|
void *font_data HB_UNUSED,
|
||||||
|
@ -117,7 +137,7 @@ hb_font_get_glyph_v_origin_nil (hb_font_t *font HB_UNUSED,
|
||||||
}
|
}
|
||||||
|
|
||||||
static hb_bool_t
|
static hb_bool_t
|
||||||
hb_font_get_h_kerning_nil (hb_font_t *font HB_UNUSED,
|
hb_font_get_glyph_h_kerning_nil (hb_font_t *font HB_UNUSED,
|
||||||
void *font_data HB_UNUSED,
|
void *font_data HB_UNUSED,
|
||||||
hb_codepoint_t left_glyph,
|
hb_codepoint_t left_glyph,
|
||||||
hb_codepoint_t right_glyph,
|
hb_codepoint_t right_glyph,
|
||||||
|
@ -126,7 +146,7 @@ hb_font_get_h_kerning_nil (hb_font_t *font HB_UNUSED,
|
||||||
void *user_data HB_UNUSED)
|
void *user_data HB_UNUSED)
|
||||||
{
|
{
|
||||||
if (font->parent) {
|
if (font->parent) {
|
||||||
hb_bool_t ret = hb_font_get_h_kerning (font->parent,
|
hb_bool_t ret = hb_font_get_glyph_h_kerning (font->parent,
|
||||||
left_glyph, right_glyph,
|
left_glyph, right_glyph,
|
||||||
x_kern, y_kern);
|
x_kern, y_kern);
|
||||||
font->parent_scale_distance (x_kern, y_kern);
|
font->parent_scale_distance (x_kern, y_kern);
|
||||||
|
@ -138,7 +158,7 @@ hb_font_get_h_kerning_nil (hb_font_t *font HB_UNUSED,
|
||||||
}
|
}
|
||||||
|
|
||||||
static hb_bool_t
|
static hb_bool_t
|
||||||
hb_font_get_v_kerning_nil (hb_font_t *font HB_UNUSED,
|
hb_font_get_glyph_v_kerning_nil (hb_font_t *font HB_UNUSED,
|
||||||
void *font_data HB_UNUSED,
|
void *font_data HB_UNUSED,
|
||||||
hb_codepoint_t top_glyph,
|
hb_codepoint_t top_glyph,
|
||||||
hb_codepoint_t bottom_glyph,
|
hb_codepoint_t bottom_glyph,
|
||||||
|
@ -147,7 +167,7 @@ hb_font_get_v_kerning_nil (hb_font_t *font HB_UNUSED,
|
||||||
void *user_data HB_UNUSED)
|
void *user_data HB_UNUSED)
|
||||||
{
|
{
|
||||||
if (font->parent) {
|
if (font->parent) {
|
||||||
hb_bool_t ret = hb_font_get_v_kerning (font->parent,
|
hb_bool_t ret = hb_font_get_glyph_v_kerning (font->parent,
|
||||||
top_glyph, bottom_glyph,
|
top_glyph, bottom_glyph,
|
||||||
x_kern, y_kern);
|
x_kern, y_kern);
|
||||||
font->parent_scale_distance (x_kern, y_kern);
|
font->parent_scale_distance (x_kern, y_kern);
|
||||||
|
@ -162,14 +182,12 @@ static hb_bool_t
|
||||||
hb_font_get_glyph_extents_nil (hb_font_t *font HB_UNUSED,
|
hb_font_get_glyph_extents_nil (hb_font_t *font HB_UNUSED,
|
||||||
void *font_data HB_UNUSED,
|
void *font_data HB_UNUSED,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
hb_bool_t *vertical,
|
|
||||||
hb_glyph_extents_t *extents,
|
hb_glyph_extents_t *extents,
|
||||||
void *user_data HB_UNUSED)
|
void *user_data HB_UNUSED)
|
||||||
{
|
{
|
||||||
if (font->parent) {
|
if (font->parent) {
|
||||||
hb_bool_t ret = hb_font_get_glyph_extents (font->parent,
|
hb_bool_t ret = hb_font_get_glyph_extents (font->parent,
|
||||||
glyph,
|
glyph,
|
||||||
vertical,
|
|
||||||
extents);
|
extents);
|
||||||
font->parent_scale_position (&extents->x_bearing, &extents->y_bearing);
|
font->parent_scale_position (&extents->x_bearing, &extents->y_bearing);
|
||||||
font->parent_scale_distance (&extents->width, &extents->height);
|
font->parent_scale_distance (&extents->width, &extents->height);
|
||||||
|
@ -182,19 +200,17 @@ hb_font_get_glyph_extents_nil (hb_font_t *font HB_UNUSED,
|
||||||
}
|
}
|
||||||
|
|
||||||
static hb_bool_t
|
static hb_bool_t
|
||||||
hb_font_get_contour_point_nil (hb_font_t *font HB_UNUSED,
|
hb_font_get_glyph_contour_point_nil (hb_font_t *font HB_UNUSED,
|
||||||
void *font_data HB_UNUSED,
|
void *font_data HB_UNUSED,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
unsigned int point_index,
|
unsigned int point_index,
|
||||||
hb_bool_t *vertical,
|
|
||||||
hb_position_t *x,
|
hb_position_t *x,
|
||||||
hb_position_t *y,
|
hb_position_t *y,
|
||||||
void *user_data HB_UNUSED)
|
void *user_data HB_UNUSED)
|
||||||
{
|
{
|
||||||
if (font->parent) {
|
if (font->parent) {
|
||||||
hb_bool_t ret = hb_font_get_contour_point (font->parent,
|
hb_bool_t ret = hb_font_get_glyph_contour_point (font->parent,
|
||||||
glyph, point_index,
|
glyph, point_index,
|
||||||
vertical,
|
|
||||||
x, y);
|
x, y);
|
||||||
font->parent_scale_position (x, y);
|
font->parent_scale_position (x, y);
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -350,6 +366,17 @@ hb_font_get_glyph_v_advance (hb_font_t *font,
|
||||||
font->klass->user_data.glyph_v_advance);
|
font->klass->user_data.glyph_v_advance);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
hb_bool_t
|
||||||
|
hb_font_get_glyph_h_origin (hb_font_t *font,
|
||||||
|
hb_codepoint_t glyph,
|
||||||
|
hb_position_t *x_origin, hb_position_t *y_origin)
|
||||||
|
{
|
||||||
|
*x_origin = *y_origin = 0;
|
||||||
|
return font->klass->get.glyph_h_origin (font, font->user_data,
|
||||||
|
glyph, x_origin, y_origin,
|
||||||
|
font->klass->user_data.glyph_h_origin);
|
||||||
|
}
|
||||||
|
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_font_get_glyph_v_origin (hb_font_t *font,
|
hb_font_get_glyph_v_origin (hb_font_t *font,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
|
@ -362,55 +389,51 @@ hb_font_get_glyph_v_origin (hb_font_t *font,
|
||||||
}
|
}
|
||||||
|
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_font_get_h_kerning (hb_font_t *font,
|
hb_font_get_glyph_h_kerning (hb_font_t *font,
|
||||||
hb_codepoint_t left_glyph, hb_codepoint_t right_glyph,
|
hb_codepoint_t left_glyph, hb_codepoint_t right_glyph,
|
||||||
hb_position_t *x_kern, hb_position_t *y_kern)
|
hb_position_t *x_kern, hb_position_t *y_kern)
|
||||||
{
|
{
|
||||||
*x_kern = *y_kern = 0;
|
*x_kern = *y_kern = 0;
|
||||||
return font->klass->get.h_kerning (font, font->user_data,
|
return font->klass->get.glyph_h_kerning (font, font->user_data,
|
||||||
left_glyph, right_glyph,
|
left_glyph, right_glyph,
|
||||||
x_kern, y_kern,
|
x_kern, y_kern,
|
||||||
font->klass->user_data.h_kerning);
|
font->klass->user_data.glyph_h_kerning);
|
||||||
}
|
}
|
||||||
|
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_font_get_v_kerning (hb_font_t *font,
|
hb_font_get_glyph_v_kerning (hb_font_t *font,
|
||||||
hb_codepoint_t left_glyph, hb_codepoint_t right_glyph,
|
hb_codepoint_t left_glyph, hb_codepoint_t right_glyph,
|
||||||
hb_position_t *x_kern, hb_position_t *y_kern)
|
hb_position_t *x_kern, hb_position_t *y_kern)
|
||||||
{
|
{
|
||||||
*x_kern = *y_kern = 0;
|
*x_kern = *y_kern = 0;
|
||||||
return font->klass->get.v_kerning (font, font->user_data,
|
return font->klass->get.glyph_v_kerning (font, font->user_data,
|
||||||
left_glyph, right_glyph,
|
left_glyph, right_glyph,
|
||||||
x_kern, y_kern,
|
x_kern, y_kern,
|
||||||
font->klass->user_data.v_kerning);
|
font->klass->user_data.glyph_v_kerning);
|
||||||
}
|
}
|
||||||
|
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_font_get_glyph_extents (hb_font_t *font,
|
hb_font_get_glyph_extents (hb_font_t *font,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
hb_bool_t *vertical,
|
|
||||||
hb_glyph_extents_t *extents)
|
hb_glyph_extents_t *extents)
|
||||||
{
|
{
|
||||||
memset (extents, 0, sizeof (*extents));
|
memset (extents, 0, sizeof (*extents));
|
||||||
return font->klass->get.glyph_extents (font, font->user_data,
|
return font->klass->get.glyph_extents (font, font->user_data,
|
||||||
glyph,
|
glyph,
|
||||||
vertical,
|
|
||||||
extents,
|
extents,
|
||||||
font->klass->user_data.glyph_extents);
|
font->klass->user_data.glyph_extents);
|
||||||
}
|
}
|
||||||
|
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_font_get_contour_point (hb_font_t *font,
|
hb_font_get_glyph_contour_point (hb_font_t *font,
|
||||||
hb_codepoint_t glyph, unsigned int point_index,
|
hb_codepoint_t glyph, unsigned int point_index,
|
||||||
hb_bool_t *vertical,
|
|
||||||
hb_position_t *x, hb_position_t *y)
|
hb_position_t *x, hb_position_t *y)
|
||||||
{
|
{
|
||||||
*x = *y = 0;
|
*x = *y = 0;
|
||||||
return font->klass->get.contour_point (font, font->user_data,
|
return font->klass->get.glyph_contour_point (font, font->user_data,
|
||||||
glyph, point_index,
|
glyph, point_index,
|
||||||
vertical,
|
|
||||||
x, y,
|
x, y,
|
||||||
font->klass->user_data.contour_point);
|
font->klass->user_data.glyph_contour_point);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -433,7 +456,23 @@ hb_font_get_glyph_advance_for_direction (hb_font_t *font,
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
hb_font_get_kerning_for_direction (hb_font_t *font,
|
hb_font_get_glyph_origin_for_direction (hb_font_t *font,
|
||||||
|
hb_codepoint_t glyph,
|
||||||
|
hb_direction_t direction,
|
||||||
|
hb_position_t *x_origin, hb_position_t *y_origin)
|
||||||
|
{
|
||||||
|
if (HB_DIRECTION_IS_VERTICAL (direction)) {
|
||||||
|
hb_bool_t ret = hb_font_get_glyph_v_origin (font, glyph, x_origin, y_origin);
|
||||||
|
if (!ret) {
|
||||||
|
/* TODO Simulate using XXX h_origin and font_extents */
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
hb_font_get_glyph_h_origin (font, glyph, x_origin, y_origin);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
hb_font_get_glyph_kerning_for_direction (hb_font_t *font,
|
||||||
hb_codepoint_t first_glyph, hb_codepoint_t second_glyph,
|
hb_codepoint_t first_glyph, hb_codepoint_t second_glyph,
|
||||||
hb_direction_t direction,
|
hb_direction_t direction,
|
||||||
hb_position_t *x_kern, hb_position_t *y_kern)
|
hb_position_t *x_kern, hb_position_t *y_kern)
|
||||||
|
@ -441,12 +480,12 @@ hb_font_get_kerning_for_direction (hb_font_t *font,
|
||||||
switch (direction) {
|
switch (direction) {
|
||||||
case HB_DIRECTION_LTR:
|
case HB_DIRECTION_LTR:
|
||||||
case HB_DIRECTION_RTL:
|
case HB_DIRECTION_RTL:
|
||||||
hb_font_get_h_kerning (font, first_glyph, second_glyph, x_kern, y_kern);
|
hb_font_get_glyph_h_kerning (font, first_glyph, second_glyph, x_kern, y_kern);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case HB_DIRECTION_TTB:
|
case HB_DIRECTION_TTB:
|
||||||
case HB_DIRECTION_BTT:
|
case HB_DIRECTION_BTT:
|
||||||
hb_font_get_v_kerning (font, first_glyph, second_glyph, x_kern, y_kern);
|
hb_font_get_glyph_v_kerning (font, first_glyph, second_glyph, x_kern, y_kern);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case HB_DIRECTION_INVALID:
|
case HB_DIRECTION_INVALID:
|
||||||
|
@ -461,28 +500,24 @@ hb_font_get_glyph_extents_for_direction (hb_font_t *font,
|
||||||
hb_direction_t direction,
|
hb_direction_t direction,
|
||||||
hb_glyph_extents_t *extents)
|
hb_glyph_extents_t *extents)
|
||||||
{
|
{
|
||||||
hb_bool_t vertical = HB_DIRECTION_IS_VERTICAL (direction);
|
hb_bool_t ret = hb_font_get_glyph_extents (font, glyph, extents);
|
||||||
hb_bool_t ret = hb_font_get_glyph_extents (font, glyph, &vertical, extents);
|
|
||||||
|
|
||||||
if (ret) {
|
if (ret) {
|
||||||
if (vertical != HB_DIRECTION_IS_VERTICAL (direction)) {
|
|
||||||
/* XXX Adjust origin */
|
/* XXX Adjust origin */
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
/* TODO Simulate using get_h_advance and font_extents? */
|
/* TODO Simulate using get_h_advance and font_extents? */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_font_get_contour_point_for_direction (hb_font_t *font,
|
hb_font_get_glyph_contour_point_for_direction (hb_font_t *font,
|
||||||
hb_codepoint_t glyph, unsigned int point_index,
|
hb_codepoint_t glyph, unsigned int point_index,
|
||||||
hb_direction_t direction,
|
hb_direction_t direction,
|
||||||
hb_position_t *x, hb_position_t *y)
|
hb_position_t *x, hb_position_t *y)
|
||||||
{
|
{
|
||||||
hb_bool_t vertical = HB_DIRECTION_IS_VERTICAL (direction);
|
hb_bool_t ret = hb_font_get_glyph_contour_point (font, glyph, point_index, x, y);
|
||||||
hb_bool_t ret = hb_font_get_contour_point (font, glyph, point_index, &vertical, x, y);
|
|
||||||
|
|
||||||
if (ret && vertical != HB_DIRECTION_IS_VERTICAL (direction)) {
|
if (ret) {
|
||||||
/* XXX Adjust origin */
|
/* XXX Adjust origin */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -144,32 +144,32 @@ typedef hb_bool_t (*hb_font_get_glyph_func_t) (hb_font_t *font, void *font_data,
|
||||||
|
|
||||||
typedef hb_bool_t (*hb_font_get_glyph_advance_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_bool_t (*hb_font_get_glyph_advance_func_t) (hb_font_t *font, void *font_data,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
hb_position_t *x_advance, hb_position_t *y_advance,
|
hb_position_t *x, hb_position_t *y,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
typedef hb_font_get_glyph_advance_func_t hb_font_get_glyph_h_advance_func_t;
|
typedef hb_font_get_glyph_advance_func_t hb_font_get_glyph_h_advance_func_t;
|
||||||
typedef hb_font_get_glyph_advance_func_t hb_font_get_glyph_v_advance_func_t;
|
typedef hb_font_get_glyph_advance_func_t hb_font_get_glyph_v_advance_func_t;
|
||||||
|
|
||||||
typedef hb_bool_t (*hb_font_get_glyph_v_origin_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_bool_t (*hb_font_get_glyph_origin_func_t) (hb_font_t *font, void *font_data,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
hb_position_t *x_origin, hb_position_t *y_origin,
|
hb_position_t *x, hb_position_t *y,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
typedef hb_font_get_glyph_origin_func_t hb_font_get_glyph_h_origin_func_t;
|
||||||
|
typedef hb_font_get_glyph_origin_func_t hb_font_get_glyph_v_origin_func_t;
|
||||||
|
|
||||||
typedef hb_bool_t (*hb_font_get_kerning_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_bool_t (*hb_font_get_glyph_kerning_func_t) (hb_font_t *font, void *font_data,
|
||||||
hb_codepoint_t first_glyph, hb_codepoint_t second_glyph,
|
hb_codepoint_t first_glyph, hb_codepoint_t second_glyph,
|
||||||
hb_position_t *x_kern, hb_position_t *y_kern,
|
hb_position_t *x, hb_position_t *y,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
typedef hb_font_get_kerning_func_t hb_font_get_h_kerning_func_t;
|
typedef hb_font_get_glyph_kerning_func_t hb_font_get_glyph_h_kerning_func_t;
|
||||||
typedef hb_font_get_kerning_func_t hb_font_get_v_kerning_func_t;
|
typedef hb_font_get_glyph_kerning_func_t hb_font_get_glyph_v_kerning_func_t;
|
||||||
|
|
||||||
|
|
||||||
typedef hb_bool_t (*hb_font_get_glyph_extents_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_bool_t (*hb_font_get_glyph_extents_func_t) (hb_font_t *font, void *font_data,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
hb_bool_t *vertical,
|
|
||||||
hb_glyph_extents_t *extents,
|
hb_glyph_extents_t *extents,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
typedef hb_bool_t (*hb_font_get_contour_point_func_t) (hb_font_t *font, void *font_data,
|
typedef hb_bool_t (*hb_font_get_glyph_contour_point_func_t) (hb_font_t *font, void *font_data,
|
||||||
hb_codepoint_t glyph, unsigned int point_index,
|
hb_codepoint_t glyph, unsigned int point_index,
|
||||||
hb_bool_t *vertical,
|
|
||||||
hb_position_t *x, hb_position_t *y,
|
hb_position_t *x, hb_position_t *y,
|
||||||
void *user_data);
|
void *user_data);
|
||||||
|
|
||||||
|
@ -191,17 +191,21 @@ hb_font_funcs_set_glyph_v_advance_func (hb_font_funcs_t *ffuncs,
|
||||||
void *user_data, hb_destroy_func_t destroy);
|
void *user_data, hb_destroy_func_t destroy);
|
||||||
|
|
||||||
void
|
void
|
||||||
|
hb_font_funcs_set_glyph_h_origin_func (hb_font_funcs_t *ffuncs,
|
||||||
|
hb_font_get_glyph_h_origin_func_t glyph_advance_func,
|
||||||
|
void *user_data, hb_destroy_func_t destroy);
|
||||||
|
void
|
||||||
hb_font_funcs_set_glyph_v_origin_func (hb_font_funcs_t *ffuncs,
|
hb_font_funcs_set_glyph_v_origin_func (hb_font_funcs_t *ffuncs,
|
||||||
hb_font_get_glyph_v_origin_func_t glyph_advance_func,
|
hb_font_get_glyph_v_origin_func_t glyph_advance_func,
|
||||||
void *user_data, hb_destroy_func_t destroy);
|
void *user_data, hb_destroy_func_t destroy);
|
||||||
|
|
||||||
void
|
void
|
||||||
hb_font_funcs_set_h_kerning_func (hb_font_funcs_t *ffuncs,
|
hb_font_funcs_set_glyph_h_kerning_func (hb_font_funcs_t *ffuncs,
|
||||||
hb_font_get_h_kerning_func_t kerning_func,
|
hb_font_get_glyph_h_kerning_func_t kerning_func,
|
||||||
void *user_data, hb_destroy_func_t destroy);
|
void *user_data, hb_destroy_func_t destroy);
|
||||||
void
|
void
|
||||||
hb_font_funcs_set_v_kerning_func (hb_font_funcs_t *ffuncs,
|
hb_font_funcs_set_glyph_v_kerning_func (hb_font_funcs_t *ffuncs,
|
||||||
hb_font_get_v_kerning_func_t kerning_func,
|
hb_font_get_glyph_v_kerning_func_t kerning_func,
|
||||||
void *user_data, hb_destroy_func_t destroy);
|
void *user_data, hb_destroy_func_t destroy);
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -209,8 +213,8 @@ hb_font_funcs_set_glyph_extents_func (hb_font_funcs_t *ffuncs,
|
||||||
hb_font_get_glyph_extents_func_t glyph_extents_func,
|
hb_font_get_glyph_extents_func_t glyph_extents_func,
|
||||||
void *user_data, hb_destroy_func_t destroy);
|
void *user_data, hb_destroy_func_t destroy);
|
||||||
void
|
void
|
||||||
hb_font_funcs_set_contour_point_func (hb_font_funcs_t *ffuncs,
|
hb_font_funcs_set_glyph_contour_point_func (hb_font_funcs_t *ffuncs,
|
||||||
hb_font_get_contour_point_func_t contour_point_func,
|
hb_font_get_glyph_contour_point_func_t glyph_contour_point_func,
|
||||||
void *user_data, hb_destroy_func_t destroy);
|
void *user_data, hb_destroy_func_t destroy);
|
||||||
|
|
||||||
|
|
||||||
|
@ -224,36 +228,38 @@ hb_font_get_glyph (hb_font_t *font,
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_font_get_glyph_h_advance (hb_font_t *font,
|
hb_font_get_glyph_h_advance (hb_font_t *font,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
hb_position_t *x_advance, hb_position_t *y_advance);
|
hb_position_t *x, hb_position_t *y);
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_font_get_glyph_v_advance (hb_font_t *font,
|
hb_font_get_glyph_v_advance (hb_font_t *font,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
hb_position_t *x_advance, hb_position_t *y_advance);
|
hb_position_t *x, hb_position_t *y);
|
||||||
|
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
|
hb_font_get_glyph_h_origin (hb_font_t *font,
|
||||||
|
hb_codepoint_t glyph,
|
||||||
|
hb_position_t *x, hb_position_t *y);
|
||||||
|
hb_bool_t
|
||||||
hb_font_get_glyph_v_origin (hb_font_t *font,
|
hb_font_get_glyph_v_origin (hb_font_t *font,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
hb_position_t *x_kern, hb_position_t *y_kern);
|
hb_position_t *x, hb_position_t *y);
|
||||||
|
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_font_get_h_kerning (hb_font_t *font,
|
hb_font_get_glyph_h_kerning (hb_font_t *font,
|
||||||
hb_codepoint_t left_glyph, hb_codepoint_t right_glyph,
|
hb_codepoint_t left_glyph, hb_codepoint_t right_glyph,
|
||||||
hb_position_t *x_kern, hb_position_t *y_kern);
|
hb_position_t *x, hb_position_t *y);
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_font_get_v_kerning (hb_font_t *font,
|
hb_font_get_glyph_v_kerning (hb_font_t *font,
|
||||||
hb_codepoint_t top_glyph, hb_codepoint_t bottom_glyph,
|
hb_codepoint_t top_glyph, hb_codepoint_t bottom_glyph,
|
||||||
hb_position_t *x_kern, hb_position_t *y_kern);
|
hb_position_t *x, hb_position_t *y);
|
||||||
|
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_font_get_glyph_extents (hb_font_t *font,
|
hb_font_get_glyph_extents (hb_font_t *font,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
hb_bool_t *vertical,
|
|
||||||
hb_glyph_extents_t *extents);
|
hb_glyph_extents_t *extents);
|
||||||
|
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_font_get_contour_point (hb_font_t *font,
|
hb_font_get_glyph_contour_point (hb_font_t *font,
|
||||||
hb_codepoint_t glyph, unsigned int point_index,
|
hb_codepoint_t glyph, unsigned int point_index,
|
||||||
hb_bool_t *vertical,
|
|
||||||
hb_position_t *x, hb_position_t *y);
|
hb_position_t *x, hb_position_t *y);
|
||||||
|
|
||||||
|
|
||||||
|
@ -263,13 +269,18 @@ void
|
||||||
hb_font_get_glyph_advance_for_direction (hb_font_t *font,
|
hb_font_get_glyph_advance_for_direction (hb_font_t *font,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
hb_direction_t direction,
|
hb_direction_t direction,
|
||||||
hb_position_t *x_advance, hb_position_t *y_advance);
|
hb_position_t *x, hb_position_t *y);
|
||||||
|
void
|
||||||
|
hb_font_get_glyph_origin_for_direction (hb_font_t *font,
|
||||||
|
hb_codepoint_t glyph,
|
||||||
|
hb_direction_t direction,
|
||||||
|
hb_position_t *x, hb_position_t *y);
|
||||||
|
|
||||||
void
|
void
|
||||||
hb_font_get_kerning_for_direction (hb_font_t *font,
|
hb_font_get_glyph_kerning_for_direction (hb_font_t *font,
|
||||||
hb_codepoint_t first_glyph, hb_codepoint_t second_glyph,
|
hb_codepoint_t first_glyph, hb_codepoint_t second_glyph,
|
||||||
hb_direction_t direction,
|
hb_direction_t direction,
|
||||||
hb_position_t *x_kern, hb_position_t *y_kern);
|
hb_position_t *x, hb_position_t *y);
|
||||||
|
|
||||||
void
|
void
|
||||||
hb_font_get_glyph_extents_for_direction (hb_font_t *font,
|
hb_font_get_glyph_extents_for_direction (hb_font_t *font,
|
||||||
|
@ -278,7 +289,7 @@ hb_font_get_glyph_extents_for_direction (hb_font_t *font,
|
||||||
hb_glyph_extents_t *extents);
|
hb_glyph_extents_t *extents);
|
||||||
|
|
||||||
hb_bool_t
|
hb_bool_t
|
||||||
hb_font_get_contour_point_for_direction (hb_font_t *font,
|
hb_font_get_glyph_contour_point_for_direction (hb_font_t *font,
|
||||||
hb_codepoint_t glyph, unsigned int point_index,
|
hb_codepoint_t glyph, unsigned int point_index,
|
||||||
hb_direction_t direction,
|
hb_direction_t direction,
|
||||||
hb_position_t *x, hb_position_t *y);
|
hb_position_t *x, hb_position_t *y);
|
||||||
|
|
40
src/hb-ft.cc
40
src/hb-ft.cc
|
@ -114,6 +114,18 @@ hb_ft_get_glyph_v_advance (hb_font_t *font HB_UNUSED,
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static hb_bool_t
|
||||||
|
hb_ft_get_glyph_h_origin (hb_font_t *font HB_UNUSED,
|
||||||
|
void *font_data HB_UNUSED,
|
||||||
|
hb_codepoint_t glyph HB_UNUSED,
|
||||||
|
hb_position_t *x_origin HB_UNUSED,
|
||||||
|
hb_position_t *y_origin HB_UNUSED,
|
||||||
|
void *user_data HB_UNUSED)
|
||||||
|
{
|
||||||
|
/* We always work in the horizontal coordinates. */
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
static hb_bool_t
|
static hb_bool_t
|
||||||
hb_ft_get_glyph_v_origin (hb_font_t *font HB_UNUSED,
|
hb_ft_get_glyph_v_origin (hb_font_t *font HB_UNUSED,
|
||||||
void *font_data,
|
void *font_data,
|
||||||
|
@ -128,12 +140,12 @@ hb_ft_get_glyph_v_origin (hb_font_t *font HB_UNUSED,
|
||||||
if (unlikely (FT_Load_Glyph (ft_face, glyph, load_flags)))
|
if (unlikely (FT_Load_Glyph (ft_face, glyph, load_flags)))
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
*y_origin = ft_face->glyph->metrics.vertAdvance;
|
/* XXX */*y_origin = ft_face->glyph->metrics.vertAdvance;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static hb_bool_t
|
static hb_bool_t
|
||||||
hb_ft_get_h_kerning (hb_font_t *font HB_UNUSED,
|
hb_ft_get_glyph_h_kerning (hb_font_t *font HB_UNUSED,
|
||||||
void *font_data,
|
void *font_data,
|
||||||
hb_codepoint_t left_glyph,
|
hb_codepoint_t left_glyph,
|
||||||
hb_codepoint_t right_glyph,
|
hb_codepoint_t right_glyph,
|
||||||
|
@ -153,12 +165,12 @@ hb_ft_get_h_kerning (hb_font_t *font HB_UNUSED,
|
||||||
}
|
}
|
||||||
|
|
||||||
static hb_bool_t
|
static hb_bool_t
|
||||||
hb_ft_get_v_kerning (hb_font_t *font HB_UNUSED,
|
hb_ft_get_glyph_v_kerning (hb_font_t *font HB_UNUSED,
|
||||||
void *font_data,
|
void *font_data HB_UNUSED,
|
||||||
hb_codepoint_t top_glyph,
|
hb_codepoint_t top_glyph HB_UNUSED,
|
||||||
hb_codepoint_t bottom_glyph,
|
hb_codepoint_t bottom_glyph HB_UNUSED,
|
||||||
hb_position_t *x_kern,
|
hb_position_t *x_kern HB_UNUSED,
|
||||||
hb_position_t *y_kern,
|
hb_position_t *y_kern HB_UNUSED,
|
||||||
void *user_data HB_UNUSED)
|
void *user_data HB_UNUSED)
|
||||||
{
|
{
|
||||||
/* FreeType API doesn't support vertical kerning */
|
/* FreeType API doesn't support vertical kerning */
|
||||||
|
@ -169,7 +181,6 @@ static hb_bool_t
|
||||||
hb_ft_get_glyph_extents (hb_font_t *font HB_UNUSED,
|
hb_ft_get_glyph_extents (hb_font_t *font HB_UNUSED,
|
||||||
void *font_data,
|
void *font_data,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
hb_bool_t *vertical,
|
|
||||||
hb_glyph_extents_t *extents,
|
hb_glyph_extents_t *extents,
|
||||||
void *user_data HB_UNUSED)
|
void *user_data HB_UNUSED)
|
||||||
{
|
{
|
||||||
|
@ -190,11 +201,10 @@ hb_ft_get_glyph_extents (hb_font_t *font HB_UNUSED,
|
||||||
}
|
}
|
||||||
|
|
||||||
static hb_bool_t
|
static hb_bool_t
|
||||||
hb_ft_get_contour_point (hb_font_t *font HB_UNUSED,
|
hb_ft_get_glyph_contour_point (hb_font_t *font HB_UNUSED,
|
||||||
void *font_data,
|
void *font_data,
|
||||||
hb_codepoint_t glyph,
|
hb_codepoint_t glyph,
|
||||||
unsigned int point_index,
|
unsigned int point_index,
|
||||||
hb_bool_t *vertical,
|
|
||||||
hb_position_t *x,
|
hb_position_t *x,
|
||||||
hb_position_t *y,
|
hb_position_t *y,
|
||||||
void *user_data HB_UNUSED)
|
void *user_data HB_UNUSED)
|
||||||
|
@ -213,7 +223,6 @@ hb_ft_get_contour_point (hb_font_t *font HB_UNUSED,
|
||||||
|
|
||||||
*x = ft_face->glyph->outline.points[point_index].x;
|
*x = ft_face->glyph->outline.points[point_index].x;
|
||||||
*y = ft_face->glyph->outline.points[point_index].y;
|
*y = ft_face->glyph->outline.points[point_index].y;
|
||||||
*vertical = FALSE; /* We always return position in horizontal coordinates */
|
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -227,11 +236,12 @@ static hb_font_funcs_t ft_ffuncs = {
|
||||||
hb_ft_get_glyph,
|
hb_ft_get_glyph,
|
||||||
hb_ft_get_glyph_h_advance,
|
hb_ft_get_glyph_h_advance,
|
||||||
hb_ft_get_glyph_v_advance,
|
hb_ft_get_glyph_v_advance,
|
||||||
|
hb_ft_get_glyph_h_origin,
|
||||||
hb_ft_get_glyph_v_origin,
|
hb_ft_get_glyph_v_origin,
|
||||||
hb_ft_get_h_kerning,
|
hb_ft_get_glyph_h_kerning,
|
||||||
hb_ft_get_v_kerning,
|
hb_ft_get_glyph_v_kerning,
|
||||||
hb_ft_get_glyph_extents,
|
hb_ft_get_glyph_extents,
|
||||||
hb_ft_get_contour_point,
|
hb_ft_get_glyph_contour_point,
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -121,7 +121,7 @@ struct CaretValueFormat2
|
||||||
inline int get_caret_value (hb_font_t *font, hb_direction_t direction, hb_codepoint_t glyph_id) const
|
inline int get_caret_value (hb_font_t *font, hb_direction_t direction, hb_codepoint_t glyph_id) const
|
||||||
{
|
{
|
||||||
hb_position_t x, y;
|
hb_position_t x, y;
|
||||||
if (hb_font_get_contour_point_for_direction (font, glyph_id, caretValuePoint, direction, &x, &y))
|
if (hb_font_get_glyph_contour_point_for_direction (font, glyph_id, caretValuePoint, direction, &x, &y))
|
||||||
return HB_DIRECTION_IS_HORIZONTAL (direction) ? x : y;
|
return HB_DIRECTION_IS_HORIZONTAL (direction) ? x : y;
|
||||||
else
|
else
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -245,7 +245,7 @@ struct AnchorFormat2
|
||||||
hb_bool_t ret = false;
|
hb_bool_t ret = false;
|
||||||
|
|
||||||
if (x_ppem || y_ppem)
|
if (x_ppem || y_ppem)
|
||||||
ret = hb_font_get_contour_point_for_direction (font, glyph_id, anchorPoint, direction, &cx, &cy);
|
ret = hb_font_get_glyph_contour_point_for_direction (font, glyph_id, anchorPoint, direction, &cx, &cy);
|
||||||
*x = x_ppem && ret ? cx : font->em_scale_x (xCoordinate);
|
*x = x_ppem && ret ? cx : font->em_scale_x (xCoordinate);
|
||||||
*y = y_ppem && ret ? cy : font->em_scale_y (yCoordinate);
|
*y = y_ppem && ret ? cy : font->em_scale_y (yCoordinate);
|
||||||
}
|
}
|
||||||
|
|
|
@ -278,7 +278,7 @@ hb_truetype_kern (hb_ot_shape_context_t *c)
|
||||||
unsigned int count = c->buffer->len;
|
unsigned int count = c->buffer->len;
|
||||||
for (unsigned int i = 1; i < count; i++) {
|
for (unsigned int i = 1; i < count; i++) {
|
||||||
hb_position_t x_kern, y_kern, kern1, kern2;
|
hb_position_t x_kern, y_kern, kern1, kern2;
|
||||||
hb_font_get_kerning_for_direction (c->font,
|
hb_font_get_glyph_kerning_for_direction (c->font,
|
||||||
c->buffer->info[i - 1].codepoint, c->buffer->info[i].codepoint,
|
c->buffer->info[i - 1].codepoint, c->buffer->info[i].codepoint,
|
||||||
c->buffer->props.direction,
|
c->buffer->props.direction,
|
||||||
&x_kern, &y_kern);
|
&x_kern, &y_kern);
|
||||||
|
|
Loading…
Reference in New Issue