Wayland platform: more accurate procedure to map a GL (sub)window.

This commit is contained in:
ManoloFLTK 2022-05-25 18:37:43 +02:00
parent a118732f7c
commit 7fcd4b73d7
2 changed files with 12 additions and 11 deletions

View File

@ -231,16 +231,17 @@ void Fl_Wayland_Gl_Window_Driver::make_current_before() {
egl_surface = eglCreateWindowSurface(egl_display, g->egl_conf, egl_window, NULL);
//fprintf(stderr, "Created egl surface=%p at scale=%d\n", egl_surface, win->scale);
wl_surface_set_buffer_scale(surface, win->scale);
// Tested apps: shape, glpuzzle, cube, fractals, gl_overlay, fullscreen,
// OpenGL3-glut-test, OpenGL3test
// Tested wayland compositors: mutter, kde-plasma, weston, sway on FreeBSD
// Origin of the value 3 below :
// All tests run OK with value 3 whereas some tests fail with 2, e.g.,
// glpuzzle + KDE, glpuzzle + sway sometimes.
for (int count = 0; count < 3; count++) {
// Tested apps: shape, glpuzzle, cube, fractals, gl_overlay, fullscreen, unittests,
// OpenGL3-glut-test, OpenGL3test.
// Tested wayland compositors: mutter, kde-plasma, weston, sway on FreeBSD.
// Origin of the 3 "roundtrips" below :
// All tests run OK with code below but glpuzzle, OpenGL3-glut-test and gl_overlay
// fail sometimes under KDE and sway without the 3rd roundtrip.
wl_display_roundtrip(Fl_Wayland_Screen_Driver::wl_display);
eglSwapBuffers(Fl_Wayland_Gl_Window_Driver::egl_display, egl_surface);
wl_display_roundtrip(Fl_Wayland_Screen_Driver::wl_display);
if (!pWindow->parent() || overlay()) { wl_display_roundtrip(Fl_Wayland_Screen_Driver::wl_display);
}
eglSwapBuffers(Fl_Wayland_Gl_Window_Driver::egl_display, egl_surface);
}
}

View File

@ -1090,9 +1090,9 @@ void Fl_Wayland_Screen_Driver::open_display_platform() {
if (!has_xrgb) {
Fl::fatal("Error: no WL_SHM_FORMAT_ARGB8888 shm format\n");
}
if (compositor == Fl_Wayland_Screen_Driver::unspecified) {
/*if (compositor == Fl_Wayland_Screen_Driver::unspecified) {
Fl::warning("FLTK could not identify the type of the running Wayland compositor");
}
}*/
Fl::add_fd(wl_display_get_fd(wl_display), FL_READ, (Fl_FD_Handler)fd_callback, wl_display);
fl_create_print_window();
}