diff options
| author | Matthias Melcher <fltk@matthiasm.com> | 2006-09-04 19:24:51 +0000 |
|---|---|---|
| committer | Matthias Melcher <fltk@matthiasm.com> | 2006-09-04 19:24:51 +0000 |
| commit | 84360f49f2087b884902e99279d8c9959cb73874 (patch) | |
| tree | 68b00e279818731c160dd8a2c68f61eb7b3797c7 /src | |
| parent | 8247d773d3acb58c5327fd254dcd23b165b07483 (diff) | |
STR 1412: fixed RGB image block copy for ld() values != 0
git-svn-id: file:///fltk/svn/fltk/branches/branch-1.1@5411 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
Diffstat (limited to 'src')
| -rw-r--r-- | src/Fl_Image.cxx | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/src/Fl_Image.cxx b/src/Fl_Image.cxx index cd992e9fc..0b844255c 100644 --- a/src/Fl_Image.cxx +++ b/src/Fl_Image.cxx @@ -156,9 +156,19 @@ Fl_Image *Fl_RGB_Image::copy(int W, int H) { if (array) { // Make a copy of the image data and return a new Fl_RGB_Image... new_array = new uchar[w() * h() * d()]; - memcpy(new_array, array, w() * h() * d()); - - new_image = new Fl_RGB_Image(new_array, w(), h(), d(), ld()); + if (ld()) { + const uchar *src = array; + uchar *dst = new_array; + int dy, dh = h(), wd = w()*d(), wdld = wd+ld(); + for (dy=0; dy<dh; dy++) { + memcpy(dst, src, wd); + src += wdld; + dst += wd; + } + } else { + memcpy(new_array, array, w() * h() * d()); + } + new_image = new Fl_RGB_Image(new_array, w(), h(), d()); new_image->alloc_array = 1; return new_image; |
