summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Reveman <c99drn@cs.umu.se>2005-05-01 22:55:25 +0000
committerDavid Reveman <c99drn@cs.umu.se>2005-05-01 22:55:25 +0000
commit5b4462ed9bbb17212dd57617cb7e837142b6270a (patch)
tree80778a6d69d2632afe39a26538e1059dda2208d9
parente4b33f4e91a5379c99ecf78ffb6a3e836cb42491 (diff)
New algorithm for calculating glyph extents in Xgl
-rw-r--r--hw/xgl/xglglyph.c114
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;