diff options
author | David Reveman <c99drn@cs.umu.se> | 2005-05-01 22:55:25 +0000 |
---|---|---|
committer | David Reveman <c99drn@cs.umu.se> | 2005-05-01 22:55:25 +0000 |
commit | 5b4462ed9bbb17212dd57617cb7e837142b6270a (patch) | |
tree | 80778a6d69d2632afe39a26538e1059dda2208d9 | |
parent | e4b33f4e91a5379c99ecf78ffb6a3e836cb42491 (diff) |
New algorithm for calculating glyph extents in Xgl
-rw-r--r-- | hw/xgl/xglglyph.c | 114 |
1 files changed, 82 insertions, 32 deletions
diff --git a/hw/xgl/xglglyph.c b/hw/xgl/xglglyph.c index b854a83f5..b5b905730 100644 --- a/hw/xgl/xglglyph.c +++ b/hw/xgl/xglglyph.c @@ -844,15 +844,21 @@ xglGlyphExtents (PicturePtr pDst, BoxPtr extents) { GlyphPtr glyph; + BoxRec line; int x1, x2, y1, y2; int n; int x; int y; - Bool x_overlap, overlap = FALSE; + Bool overlap = FALSE; x = 0; y = 0; + extents->x1 = MAXSHORT; + extents->x2 = MINSHORT; + extents->y1 = MAXSHORT; + extents->y2 = MINSHORT; + while (!list->len) { if (--nlist) @@ -863,11 +869,6 @@ xglGlyphExtents (PicturePtr pDst, } else { - extents->x1 = MAXSHORT; - extents->x2 = MINSHORT; - extents->y1 = MAXSHORT; - extents->y2 = MINSHORT; - return FALSE; } } @@ -880,10 +881,10 @@ xglGlyphExtents (PicturePtr pDst, if (y1 < MINSHORT) y1 = MINSHORT; - extents->x1 = x1; - extents->x2 = x1; - extents->y1 = y1; - extents->y2 = y1; + line.x1 = x1; + line.x2 = x1; + line.y1 = y1; + line.y2 = y1; while (nlist--) { @@ -908,33 +909,55 @@ xglGlyphExtents (PicturePtr pDst, if (y2 > MAXSHORT) y2 = MAXSHORT; - x_overlap = FALSE; - if (x1 >= extents->x2) - extents->x2 = x2; - else if (x2 <= extents->x1) - extents->x1 = x1; - else + if (x1 >= line.x2) { - x_overlap = TRUE; - if (x1 < extents->x1) - extents->x1 = x1; - if (x2 > extents->x2) - extents->x2 = x2; + line.x2 = x2; + if (y1 < line.y1) + line.y1 = y1; + if (y2 > line.y2) + line.y2 = y2; + } + else if (x2 <= line.x1) + { + line.x1 = x1; + if (y1 < line.y1) + line.y1 = y1; + if (y2 > line.y2) + line.y2 = y2; } - - if (y1 >= extents->y2) - extents->y2 = y2; - else if (y2 <= extents->y1) - extents->y1 = y1; else { - if (y1 < extents->y1) - extents->y1 = y1; - if (y2 > extents->y2) - extents->y2 = y2; - - if (x_overlap) + if (line.y1 >= extents->y2) + { + extents->y2 = line.y2; + if (line.y1 < extents->y1) + extents->y1 = line.y1; + } + else if (line.y2 <= extents->y1) + { + extents->y1 = line.y1; + if (line.y2 > extents->y2) + extents->y2 = line.y2; + } + else + { + if (line.y1 < extents->y1) + extents->y1 = line.y1; + if (line.y2 > extents->y2) + extents->y2 = line.y2; + overlap = TRUE; + } + + if (line.x1 < extents->x1) + extents->x1 = line.x1; + if (line.x2 > extents->x2) + extents->x2 = line.x2; + + line.x1 = x1; + line.y1 = y1; + line.x2 = x2; + line.y2 = y2; } x += glyph->info.xOff; @@ -942,6 +965,33 @@ xglGlyphExtents (PicturePtr pDst, } } + if (line.y1 >= extents->y2) + { + extents->y2 = line.y2; + if (line.y1 < extents->y1) + extents->y1 = line.y1; + } + else if (line.y2 <= extents->y1) + { + extents->y1 = line.y1; + if (line.y2 > extents->y2) + extents->y2 = line.y2; + } + else + { + if (line.y1 < extents->y1) + extents->y1 = line.y1; + if (line.y2 > extents->y2) + extents->y2 = line.y2; + + overlap = TRUE; + } + + if (line.x1 < extents->x1) + extents->x1 = line.x1; + if (line.x2 > extents->x2) + extents->x2 = line.x2; + xglPictureClipExtents (pDst, extents); return overlap; |