From 7152891c65fc50a809a20632160901bea41f13da Mon Sep 17 00:00:00 2001 From: Grigori Goronzy Date: Thu, 29 Jul 2010 02:38:29 +0200 Subject: [PATCH] Fix drawing cbox calculation Use extremes of all points fed to the parser, instead of only points that are added to the outline. Fixes a rendering problem reported on IRC and should fix Issue #7. --- libass/ass_drawing.c | 20 ++++++++++++++++++-- libass/ass_drawing.h | 1 + 2 files changed, 19 insertions(+), 2 deletions(-) diff --git a/libass/ass_drawing.c b/libass/ass_drawing.c index 4be03ba..6bf9ee1 100644 --- a/libass/ass_drawing.c +++ b/libass/ass_drawing.c @@ -112,7 +112,7 @@ static void drawing_prepare(ASS_Drawing *drawing) static void drawing_finish(ASS_Drawing *drawing, int raw_mode) { int i, offset; - FT_BBox bbox; + FT_BBox bbox = drawing->cbox; FT_Outline *ol = &drawing->glyph->outline; // Close the last contour @@ -137,7 +137,6 @@ static void drawing_finish(ASS_Drawing *drawing, int raw_mode) if (raw_mode) return; - FT_Outline_Get_CBox(&drawing->glyph->outline, &bbox); drawing->glyph->root.advance.x = d6_to_d16(bbox.xMax - bbox.xMin); drawing->desc = double_to_d6(-drawing->pbo * drawing->scale_y); @@ -255,6 +254,19 @@ static void drawing_free_tokens(ASS_DrawingToken *token) } } +/* + * \brief Update drawing cbox + */ +static inline void update_cbox(ASS_Drawing *drawing, FT_Vector *point) +{ + FT_BBox *box = &drawing->cbox; + + box->xMin = FFMIN(box->xMin, point->x); + box->xMax = FFMAX(box->xMax, point->x); + box->yMin = FFMIN(box->yMin, point->y); + box->yMax = FFMAX(box->yMax, point->y); +} + /* * \brief Translate and scale a point coordinate according to baseline * offset and scale. @@ -263,6 +275,8 @@ static inline void translate_point(ASS_Drawing *drawing, FT_Vector *point) { point->x = drawing->point_scale_x * point->x; point->y = drawing->point_scale_y * -point->y; + + update_cbox(drawing, point); } /* @@ -369,6 +383,8 @@ ASS_Drawing *ass_drawing_new(void *fontconfig_priv, ASS_Font *font, drawing = calloc(1, sizeof(*drawing)); drawing->text = calloc(1, DRAWING_INITIAL_SIZE); drawing->size = DRAWING_INITIAL_SIZE; + drawing->cbox.xMin = drawing->cbox.yMin = INT_MAX; + drawing->cbox.xMax = drawing->cbox.yMax = INT_MIN; drawing->ftlibrary = lib; if (font) { diff --git a/libass/ass_drawing.h b/libass/ass_drawing.h index 913588e..0223271 100644 --- a/libass/ass_drawing.h +++ b/libass/ass_drawing.h @@ -65,6 +65,7 @@ typedef struct { int max_contours; double point_scale_x; double point_scale_y; + FT_BBox cbox; // bounding box, or let's say... VSFilter's idea of it } ASS_Drawing; ASS_Drawing *ass_drawing_new(void *fontconfig_priv, ASS_Font *font, -- 2.40.0