summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Mark Bell <jmb@netsurf-browser.org>2004-03-03 23:17:15 +0000
committerJohn Mark Bell <jmb@netsurf-browser.org>2004-03-03 23:17:15 +0000
commit303e09a6c271b16b13674c5a9cbdd18f5c68ca49 (patch)
tree0b38bc5a2f9bf17e26ebbdbb299c12acf57d4c97
parent7fd5b22eb21b2d49bef48adec0368f7e3f1a339f (diff)
downloadnetsurf-303e09a6c271b16b13674c5a9cbdd18f5c68ca49.tar.gz
netsurf-303e09a6c271b16b13674c5a9cbdd18f5c68ca49.tar.bz2
[project @ 2004-03-03 23:17:15 by jmb]
Fix scaled jpeg bug, with any luck... svn path=/import/netsurf/; revision=581
-rw-r--r--riscos/save_draw.c21
1 files changed, 13 insertions, 8 deletions
diff --git a/riscos/save_draw.c b/riscos/save_draw.c
index 8a6929188..19c81a272 100644
--- a/riscos/save_draw.c
+++ b/riscos/save_draw.c
@@ -397,23 +397,28 @@ void add_jpeg(struct content *content, struct box *box,
drawfile_object *dro = xcalloc(8+60+((content->data.jpeg.length+3)/4*4), sizeof(char));
drawfile_jpeg *dj = xcalloc(60+((content->data.jpeg.length+3)/4*4), sizeof(char));
+ int flags;
- dj->bbox.x0 = x;
- dj->bbox.y0 = y-((box->padding[TOP] + box->height + box->padding[BOTTOM])*512);
- dj->bbox.x1 = x+((box->padding[LEFT] + box->width + box->padding[RIGHT])*512);
- dj->bbox.y1 = y;
+ dj->bbox.x0 = x+(box->padding[LEFT]*512);
+ dj->bbox.y0 = y-((box->padding[TOP] + box->height)*512);
+ dj->bbox.x1 = x+((box->padding[LEFT] + box->width)*512);
+ dj->bbox.y1 = y-(box->padding[TOP]*512);
xjpeginfo_dimensions((jpeg_image const*)content->data.jpeg.data,
(int)content->data.jpeg.length,
- 0, &dj->width, &dj->height,
+ &flags, &dj->width, &dj->height,
&dj->xdpi, &dj->ydpi, 0);
dj->width *= 512;
dj->height *= 512;
- dj->trfm.entries[0][0] = 1 << 16;
+ if (flags & 4) { /* pixel density is a ratio */
+ dj->ydpi = 90 * (dj->ydpi / dj->xdpi);
+ dj->xdpi = 90;
+ }
+ dj->trfm.entries[0][0] = (dj->width*256) / ((dj->bbox.x1-dj->bbox.x0)/256);
dj->trfm.entries[0][1] = 0;
dj->trfm.entries[1][0] = 0;
- dj->trfm.entries[1][1] = 1 << 16;
- dj->trfm.entries[2][0] = x;
+ dj->trfm.entries[1][1] = (dj->height*256) / ((dj->bbox.y1-dj->bbox.y0)/256);
+ dj->trfm.entries[2][0] = dj->bbox.x0;
dj->trfm.entries[2][1] = dj->bbox.y0;
dj->len = content->data.jpeg.length;
memcpy((char*)&dj->image, content->data.jpeg.data, (unsigned)dj->len);