diff options
| author | ManoloFLTK <41016272+ManoloFLTK@users.noreply.github.com> | 2025-02-22 08:33:20 +0100 |
|---|---|---|
| committer | ManoloFLTK <41016272+ManoloFLTK@users.noreply.github.com> | 2025-02-22 08:33:20 +0100 |
| commit | e27edad5f14195a6a8609597ba86b3ff24b414c4 (patch) | |
| tree | e3ab9567a33bc650d94f46f945d1b7a27fbfdff8 /src/Fl_Image.cxx | |
| parent | 7ce2632bfc035257b1f7af80ed8cf1c61af8efaf (diff) | |
Fix "Fl_RGB_Image::draw() seg faults when offset is too big" (#1211)
Diffstat (limited to 'src/Fl_Image.cxx')
| -rw-r--r-- | src/Fl_Image.cxx | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/src/Fl_Image.cxx b/src/Fl_Image.cxx index caec5103f..d5fdeca5d 100644 --- a/src/Fl_Image.cxx +++ b/src/Fl_Image.cxx @@ -733,12 +733,13 @@ void Fl_RGB_Image::draw(int XP, int YP, int WP, int HP, int cx, int cy) { rectangle_int_t r1 = { XP-cx, YP-cy, w(), h() }; rectangle_int_t r2 = { XP, YP, WP, HP }; crect_intersect(&r1, &r2); + if (!r1.width || !r1.height) return; // After this, r1.x,r1.y = position of top-left of drawn image part; // r1.width,r1.height = size of drawn image part, in FLTK units; // fl_max(cx, 0),fl_max(cy, 0) = top-left of drawn part in image. - int l = (ld() ? ld() : d() * w()); + int l = (ld() ? ld() : d() * data_w()); const uchar *p = array + fl_max(cy, 0) * l + fl_max(cx, 0) * d(); - fl_graphics_driver->draw_image(p, XP, YP, WP, HP, d(), l); + fl_graphics_driver->draw_image(p, r1.x, r1.y, r1.width, r1.height, d(), l); } else fl_graphics_driver->draw_rgb(this, XP, YP, WP, HP, cx, cy); } |
