summaryrefslogtreecommitdiff
path: root/src/cd_text.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/cd_text.c')
-rw-r--r--src/cd_text.c96
1 files changed, 51 insertions, 45 deletions
diff --git a/src/cd_text.c b/src/cd_text.c
index 8a5ff81..4b3e839 100644
--- a/src/cd_text.c
+++ b/src/cd_text.c
@@ -32,21 +32,20 @@ void cdCanvasText(cdCanvas* canvas, int x, int y, const char *s)
y += canvas->origin.y;
}
- if (canvas->invert_yaxis)
- y = _cdInvertYAxis(canvas, y);
-
num_line = cdStrLineCount(s);
if (num_line == 1)
- canvas->cxText(canvas->ctxcanvas, x, y, s);
+ {
+ if (canvas->invert_yaxis)
+ y = _cdInvertYAxis(canvas, y);
+
+ canvas->cxText(canvas->ctxcanvas, x, y, s, strlen(s));
+ }
else
{
- int i, line_height;
- char *p, *q, *new_s;
+ int yr, i, line_height, len;
+ const char *p, *q;
double cos_theta = 0, sin_theta = 0;
- new_s = cdStrDup(s);
- p = new_s;
-
canvas->cxGetFontDim(canvas->ctxcanvas, NULL, &line_height, NULL, NULL);
if (canvas->text_orientation)
@@ -86,13 +85,19 @@ void cdCanvasText(cdCanvas* canvas, int x, int y, const char *s)
y += ((num_line-1)*line_height)/2;
}
+ p = s;
for(i = 0; i < num_line; i++)
{
q = strchr(p, '\n');
- if (q) *q = 0; /* Cut the string to contain only one line */
+ if (q) len = (int)(q-p); /* Cut the string to contain only one line */
+ else len = strlen(p);
/* Draw the line */
- canvas->cxText(canvas->ctxcanvas, x, y, p);
+ if (canvas->invert_yaxis)
+ yr = _cdInvertYAxis(canvas, y);
+ else
+ yr = y;
+ canvas->cxText(canvas->ctxcanvas, x, yr, p, len);
/* Advance the string */
if (q) p = q + 1;
@@ -103,8 +108,6 @@ void cdCanvasText(cdCanvas* canvas, int x, int y, const char *s)
else
y -= line_height;
}
-
- free(new_s);
}
}
@@ -125,25 +128,22 @@ void cdfCanvasText(cdCanvas* canvas, double x, double y, const char *s)
y += canvas->forigin.y;
}
- if (canvas->invert_yaxis)
- y = _cdInvertYAxis(canvas, y);
-
num_line = cdStrLineCount(s);
if (num_line == 1)
{
+ if (canvas->invert_yaxis)
+ y = _cdInvertYAxis(canvas, y);
+
if (canvas->cxFText)
- canvas->cxFText(canvas->ctxcanvas, x, y, s);
+ canvas->cxFText(canvas->ctxcanvas, x, y, s, strlen(s));
else
- canvas->cxText(canvas->ctxcanvas, _cdRound(x), _cdRound(y), s);
+ canvas->cxText(canvas->ctxcanvas, _cdRound(x), _cdRound(y), s, strlen(s));
}
else
{
- int i, line_height;
- char *p, *q, *new_s;
- double cos_theta = 0, sin_theta = 0;
-
- new_s = cdStrDup(s);
- p = new_s;
+ int i, line_height, len;
+ const char *p, *q;
+ double yr, cos_theta = 0, sin_theta = 0;
canvas->cxGetFontDim(canvas->ctxcanvas, NULL, &line_height, NULL, NULL);
@@ -167,16 +167,22 @@ void cdfCanvasText(cdCanvas* canvas, double x, double y, const char *s)
cdfMovePoint(&x, &y, 0, (num_line-1)*line_height/2.0, sin_theta, cos_theta);
}
+ p = s;
for(i = 0; i < num_line; i++)
{
q = strchr(p, '\n');
- if (q) *q = 0; /* Cut the string to contain only one line */
+ if (q) len = (int)(q-p); /* Cut the string to contain only one line */
+ else len = strlen(p);
/* Draw the line */
+ if (canvas->invert_yaxis)
+ yr = _cdInvertYAxis(canvas, y);
+ else
+ yr = y;
if (canvas->cxFText)
- canvas->cxFText(canvas->ctxcanvas, x, y, p);
+ canvas->cxFText(canvas->ctxcanvas, x, yr, p, len);
else
- canvas->cxText(canvas->ctxcanvas, _cdRound(x), _cdRound(y), p);
+ canvas->cxText(canvas->ctxcanvas, _cdRound(x), _cdRound(yr), p, len);
/* Advance the string */
if (q) p = q + 1;
@@ -187,8 +193,6 @@ void cdfCanvasText(cdCanvas* canvas, double x, double y, const char *s)
else
y -= line_height;
}
-
- free(new_s);
}
}
@@ -375,34 +379,32 @@ void cdCanvasGetTextSize(cdCanvas* canvas, const char *s, int *width, int *heigh
num_line = cdStrLineCount(s);
if (num_line == 1)
- canvas->cxGetTextSize(canvas->ctxcanvas, s, width, height);
+ canvas->cxGetTextSize(canvas->ctxcanvas, s, strlen(s), width, height);
else
{
- int i, line_height, max_w = 0, w;
- char *p, *q, *new_s;
+ int i, line_height, max_w = 0, w, len;
+ const char *p, *q;
- new_s = cdStrDup(s);
- p = new_s;
+ p = s;
canvas->cxGetFontDim(canvas->ctxcanvas, NULL, &line_height, NULL, NULL);
for(i = 0; i < num_line; i++)
{
q = strchr(p, '\n');
- if (q) *q = 0; /* Cut the string to contain only one line */
+ if (q) len = (int)(q-p); /* Cut the string to contain only one line */
+ else len = strlen(p);
/* Calculate line width */
- canvas->cxGetTextSize(canvas->ctxcanvas, p, &w, NULL);
+ canvas->cxGetTextSize(canvas->ctxcanvas, p, len, &w, NULL);
if (w > max_w) max_w = w;
/* Advance the string */
- if (q) p = q + 1;
+ if (q) p = q + 1; /* skip line break */
}
if (width) *width = max_w;
if (height) *height = num_line*line_height;
-
- free(new_s);
}
}
@@ -468,9 +470,9 @@ void cdTextTranslatePoint(cdCanvas* canvas, int x, int y, int w, int h, int base
void cdCanvasGetTextBounds(cdCanvas* canvas, int x, int y, const char *s, int *rect)
{
- int w, h, ascent, height, baseline;
+ int w, h, ascent, line_height, baseline;
int xmin, xmax, ymin, ymax;
- int old_invert_yaxis = canvas->invert_yaxis;
+ int old_invert_yaxis, num_lin;
assert(canvas);
assert(s);
@@ -480,10 +482,14 @@ void cdCanvasGetTextBounds(cdCanvas* canvas, int x, int y, const char *s, int *r
return;
cdCanvasGetTextSize(canvas, s, &w, &h);
- cdCanvasGetFontDim(canvas, NULL, &height, &ascent, NULL);
- baseline = height - ascent;
-
- /* in this case we are always upwards */
+ cdCanvasGetFontDim(canvas, NULL, &line_height, &ascent, NULL);
+ baseline = line_height - ascent;
+ num_lin = h/line_height;
+ if (num_lin > 1)
+ baseline += (num_lin-1)*line_height;
+
+ /* from here we are always upwards */
+ old_invert_yaxis = canvas->invert_yaxis;
canvas->invert_yaxis = 0;
/* move to bottom-left */