diff options
| author | ManoloFLTK <41016272+ManoloFLTK@users.noreply.github.com> | 2023-04-23 10:03:02 +0200 |
|---|---|---|
| committer | ManoloFLTK <41016272+ManoloFLTK@users.noreply.github.com> | 2023-04-23 10:03:02 +0200 |
| commit | 4bf9172a8e4f76842a2e011671cf5c057e8fe1d1 (patch) | |
| tree | 1c87724b15d5166a6c6f62204f5de2d3e4ac8dd0 /src/drivers/Xlib | |
| parent | 897a6910b60ad8331ddb451d9dbc6c62da2b4657 (diff) | |
Replace internal fl_create_offscreen() calls by new Fl_Image_Surface
Diffstat (limited to 'src/drivers/Xlib')
| -rw-r--r-- | src/drivers/Xlib/Fl_Xlib_Copy_Surface_Driver.H | 4 | ||||
| -rw-r--r-- | src/drivers/Xlib/Fl_Xlib_Copy_Surface_Driver.cxx | 13 |
2 files changed, 10 insertions, 7 deletions
diff --git a/src/drivers/Xlib/Fl_Xlib_Copy_Surface_Driver.H b/src/drivers/Xlib/Fl_Xlib_Copy_Surface_Driver.H index 2932a3f1c..fa3c0ee90 100644 --- a/src/drivers/Xlib/Fl_Xlib_Copy_Surface_Driver.H +++ b/src/drivers/Xlib/Fl_Xlib_Copy_Surface_Driver.H @@ -23,11 +23,13 @@ # include <cairo/cairo.h> #endif // FLTK_USE_CAIRO +class Fl_Image_Surface; + class Fl_Xlib_Copy_Surface_Driver : public Fl_Copy_Surface_Driver { friend class Fl_Copy_Surface_Driver; void end_current() FL_OVERRIDE; protected: - Fl_Offscreen xid; + Fl_Image_Surface *xid; Window oldwindow; Fl_Xlib_Copy_Surface_Driver(int w, int h); ~Fl_Xlib_Copy_Surface_Driver(); diff --git a/src/drivers/Xlib/Fl_Xlib_Copy_Surface_Driver.cxx b/src/drivers/Xlib/Fl_Xlib_Copy_Surface_Driver.cxx index 014314def..95ee14e99 100644 --- a/src/drivers/Xlib/Fl_Xlib_Copy_Surface_Driver.cxx +++ b/src/drivers/Xlib/Fl_Xlib_Copy_Surface_Driver.cxx @@ -18,6 +18,7 @@ #include "Fl_Xlib_Copy_Surface_Driver.H" #include <FL/Fl.H> #include <FL/platform.H> +#include <FL/Fl_Image_Surface.H> #include <FL/fl_draw.H> #include "../X11/Fl_X11_Screen_Driver.H" #if FLTK_USE_CAIRO @@ -39,9 +40,9 @@ Fl_Xlib_Copy_Surface_Driver::Fl_Xlib_Copy_Surface_Driver(int w, int h) : Fl_Copy float s = Fl_Graphics_Driver::default_driver().scale(); driver()->scale(s); oldwindow = fl_window; - xid = fl_create_offscreen(w,h); + xid = new Fl_Image_Surface(w, h, 1); #if FLTK_USE_CAIRO - cairo_surface_t *surf = cairo_xlib_surface_create(fl_display, xid, fl_visual->visual, w * s, h * s); + cairo_surface_t *surf = cairo_xlib_surface_create(fl_display, xid->offscreen(), fl_visual->visual, w * s, h * s); cairo_ = cairo_create(surf); cairo_surface_destroy(surf); cairo_scale(cairo_, 1/s, 1/s); @@ -49,7 +50,7 @@ Fl_Xlib_Copy_Surface_Driver::Fl_Xlib_Copy_Surface_Driver(int w, int h) : Fl_Copy ((Fl_X11_Cairo_Graphics_Driver*)driver())->set_cairo(cairo_); #endif driver()->push_no_clip(); - fl_window = xid; + fl_window = xid->offscreen(); driver()->color(FL_WHITE); driver()->rectf(0, 0, w, h); fl_window = oldwindow; @@ -59,13 +60,13 @@ Fl_Xlib_Copy_Surface_Driver::Fl_Xlib_Copy_Surface_Driver(int w, int h) : Fl_Copy Fl_Xlib_Copy_Surface_Driver::~Fl_Xlib_Copy_Surface_Driver() { driver()->pop_clip(); Window old_win = fl_window; - fl_window = xid; + fl_window = xid->offscreen(); Fl_RGB_Image *rgb = Fl::screen_driver()->read_win_rectangle(0, 0, width, height, 0); fl_window = old_win; if (is_current()) end_current(); Fl_X11_Screen_Driver::copy_image(rgb->array, rgb->w(), rgb->h(), 1); delete rgb; - fl_delete_offscreen(xid); + delete xid; #if FLTK_USE_CAIRO cairo_destroy(cairo_); #endif @@ -76,7 +77,7 @@ Fl_Xlib_Copy_Surface_Driver::~Fl_Xlib_Copy_Surface_Driver() { void Fl_Xlib_Copy_Surface_Driver::set_current() { Fl_Surface_Device::set_current(); oldwindow = fl_window; - fl_window = xid; + fl_window = xid->offscreen(); #if FLTK_USE_CAIRO ((Fl_X11_Cairo_Graphics_Driver*)driver())->set_cairo(cairo_); #endif |
