diff options
author | John Mark Bell <jmb@netsurf-browser.org> | 2004-03-03 23:17:15 +0000 |
---|---|---|
committer | John Mark Bell <jmb@netsurf-browser.org> | 2004-03-03 23:17:15 +0000 |
commit | 303e09a6c271b16b13674c5a9cbdd18f5c68ca49 (patch) | |
tree | 0b38bc5a2f9bf17e26ebbdbb299c12acf57d4c97 /riscos/save_draw.c | |
parent | 7fd5b22eb21b2d49bef48adec0368f7e3f1a339f (diff) | |
download | netsurf-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
Diffstat (limited to 'riscos/save_draw.c')
-rw-r--r-- | riscos/save_draw.c | 21 |
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); |