|
Ivana Varekova |
f4776b |
--- gd-2.0.33/gd.c.pom 2006-11-16 14:29:57.000000000 +0100
|
|
Ivana Varekova |
f4776b |
+++ gd-2.0.33/gd.c 2006-11-16 14:30:44.000000000 +0100
|
|
Ivana Varekova |
f4776b |
@@ -3075,6 +3075,8 @@
|
|
Ivana Varekova |
f4776b |
/* keep them as 32bits */
|
|
Ivana Varekova |
f4776b |
long x, y, inc;
|
|
Ivana Varekova |
f4776b |
long dx, dy,tmp;
|
|
Ivana Varekova |
f4776b |
+ int w, wid, wstart;
|
|
Ivana Varekova |
f4776b |
+ int thick = im->thick;
|
|
Ivana Varekova |
f4776b |
if (!im->trueColor) {
|
|
Ivana Varekova |
f4776b |
/* TBB: don't crash when the image is of the wrong type */
|
|
Ivana Varekova |
f4776b |
gdImageLine(im, x1, y1, x2, y2, col);
|
|
Ivana Varekova |
f4776b |
@@ -3087,12 +3089,30 @@
|
|
Ivana Varekova |
f4776b |
return;
|
|
Ivana Varekova |
f4776b |
dx = x2 - x1;
|
|
Ivana Varekova |
f4776b |
dy = y2 - y1;
|
|
Ivana Varekova |
f4776b |
-
|
|
Ivana Varekova |
f4776b |
if (dx == 0 && dy == 0) {
|
|
Ivana Varekova |
f4776b |
/* TBB: allow setting points */
|
|
Ivana Varekova |
f4776b |
gdImageSetAAPixelColor(im, x1, y1, col, 0xFF);
|
|
Ivana Varekova |
f4776b |
return;
|
|
Ivana Varekova |
f4776b |
}
|
|
Ivana Varekova |
f4776b |
+ else {
|
|
Ivana Varekova |
f4776b |
+ double ag;
|
|
Ivana Varekova |
f4776b |
+ if (dy < dx)
|
|
Ivana Varekova |
f4776b |
+ ag = cos (atan2 (dy, dx));
|
|
Ivana Varekova |
f4776b |
+ else
|
|
Ivana Varekova |
f4776b |
+ ag = sin (atan2 (dy, dx));
|
|
Ivana Varekova |
f4776b |
+ if (ag != 0)
|
|
Ivana Varekova |
f4776b |
+ {
|
|
Ivana Varekova |
f4776b |
+ wid = thick / ag;
|
|
Ivana Varekova |
f4776b |
+ }
|
|
Ivana Varekova |
f4776b |
+ else
|
|
Ivana Varekova |
f4776b |
+ {
|
|
Ivana Varekova |
f4776b |
+ wid = 1;
|
|
Ivana Varekova |
f4776b |
+ }
|
|
Ivana Varekova |
f4776b |
+ if (wid == 0)
|
|
Ivana Varekova |
f4776b |
+ {
|
|
Ivana Varekova |
f4776b |
+ wid = 1;
|
|
Ivana Varekova |
f4776b |
+ }
|
|
Ivana Varekova |
f4776b |
+ }
|
|
Ivana Varekova |
f4776b |
if (abs(dx) > abs(dy)) {
|
|
Ivana Varekova |
f4776b |
if (dx < 0) {
|
|
Ivana Varekova |
f4776b |
tmp = x1;
|
|
Ivana Varekova |
f4776b |
@@ -3109,8 +3129,11 @@
|
|
Ivana Varekova |
f4776b |
inc = (dy * 65536) / dx;
|
|
Ivana Varekova |
f4776b |
/* TBB: set the last pixel for consistency (<=) */
|
|
Ivana Varekova |
f4776b |
while ((x >> 16) <= x2) {
|
|
Ivana Varekova |
f4776b |
- gdImageSetAAPixelColor(im, x >> 16, y >> 16, col, (y >> 8) & 0xFF);
|
|
Ivana Varekova |
f4776b |
- gdImageSetAAPixelColor(im, x >> 16, (y >> 16) + 1,col, (~y >> 8) & 0xFF);
|
|
Ivana Varekova |
f4776b |
+ wstart = (y >> 16) - wid / 2;
|
|
Ivana Varekova |
f4776b |
+ for (w = wstart; w < wstart + wid; w++) {
|
|
Ivana Varekova |
f4776b |
+ gdImageSetAAPixelColor(im, (x >> 16) , w , col , (y >> 8) & 0xFF);
|
|
Ivana Varekova |
f4776b |
+ gdImageSetAAPixelColor(im, (x >> 16) , w + 1 , col, (~y >> 8) & 0xFF);
|
|
Ivana Varekova |
f4776b |
+ }
|
|
Ivana Varekova |
f4776b |
x += (1 << 16);
|
|
Ivana Varekova |
f4776b |
y += inc;
|
|
Ivana Varekova |
f4776b |
}
|
|
Ivana Varekova |
f4776b |
@@ -3130,8 +3153,11 @@
|
|
Ivana Varekova |
f4776b |
inc = (dx * 65536) / dy;
|
|
Ivana Varekova |
f4776b |
/* TBB: set the last pixel for consistency (<=) */
|
|
Ivana Varekova |
f4776b |
while ((y>>16) <= y2) {
|
|
Ivana Varekova |
f4776b |
- gdImageSetAAPixelColor(im, x >> 16, y >> 16, col, (x >> 8) & 0xFF);
|
|
Ivana Varekova |
f4776b |
- gdImageSetAAPixelColor(im, (x >> 16) + 1, (y >> 16),col, (~x >> 8) & 0xFF);
|
|
Ivana Varekova |
f4776b |
+ wstart = (x >> 16) - wid / 2;
|
|
Ivana Varekova |
f4776b |
+ for (w = wstart; w < wstart + wid; w++) {
|
|
Ivana Varekova |
f4776b |
+ gdImageSetAAPixelColor(im, w , y >> 16 , col, (x >> 8) & 0xFF);
|
|
Ivana Varekova |
f4776b |
+ gdImageSetAAPixelColor(im, w + 1, y >> 16, col, (~x >> 8) & 0xFF);
|
|
Ivana Varekova |
f4776b |
+ }
|
|
Ivana Varekova |
f4776b |
x += inc;
|
|
Ivana Varekova |
f4776b |
y += (1<<16);
|
|
Ivana Varekova |
f4776b |
}
|