diff options
| author | ManoloFLTK <41016272+ManoloFLTK@users.noreply.github.com> | 2024-05-03 21:55:01 +0200 |
|---|---|---|
| committer | ManoloFLTK <41016272+ManoloFLTK@users.noreply.github.com> | 2024-05-03 21:55:01 +0200 |
| commit | b726211b9b9eefeaabf5ba366565792e943a18b6 (patch) | |
| tree | e4cc5b5d46e81c1b5f47dfffd2881fa5f3d8427f | |
| parent | 70b84b491b889ecb528e46aae20b6105e0b96065 (diff) | |
Wayland: use frame_cb before redrawing GL subwindows (#967)
| -rw-r--r-- | src/drivers/Wayland/Fl_Wayland_Gl_Window_Driver.cxx | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/src/drivers/Wayland/Fl_Wayland_Gl_Window_Driver.cxx b/src/drivers/Wayland/Fl_Wayland_Gl_Window_Driver.cxx index 00c1ab0ca..5f96480ab 100644 --- a/src/drivers/Wayland/Fl_Wayland_Gl_Window_Driver.cxx +++ b/src/drivers/Wayland/Fl_Wayland_Gl_Window_Driver.cxx @@ -357,6 +357,13 @@ void Fl_Wayland_Gl_Window_Driver::swap_buffers() { } if (egl_surface) { + if (pWindow->parent()) { + struct wld_window *xid = fl_wl_xid(pWindow); + if (xid->frame_cb) return; + xid->frame_cb = wl_surface_frame(xid->wl_surface); + wl_callback_add_listener(xid->frame_cb, Fl_Wayland_Graphics_Driver::p_surface_frame_listener, + xid); + } eglSwapBuffers(Fl_Wayland_Gl_Window_Driver::egl_display, egl_surface); } } |
