You are not logged in.
Pages: 1
Hello all,
My OpenGL set up with SDL on Gnome+Wayland environment is super laggy with the window moving.
It's not a complex set up at all, essentially just:
while (should_run)
    {
        while (SDL_PollEvent(&window.getWindowData()->event))
            if (window.getWindowData()->event.type == SDL_QUIT)
                should_run = false;
        // ensure that SDL2 updated the keyboard state
        SDL_PumpEvents();
        // // automatically update window size
        // UpdateWindowSize(&window);
        // SDL2 should automatically clear this memory after each loop
        keys = SDL_GetKeyboardState(0);
        // black background color
        glClearColor(0.00f, 0.00f, 0.00f, 1.00f);
        // red background color if pressing W
        if(keys[SDL_SCANCODE_W])
            glClearColor(1.00f, 0.00f, 0.00f, 1.00f);
        
        glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
        SDL_GL_SwapWindow(window.getWindowData()->window);
    }There's nothing inherently slow with this code, it's pretty standard. Not seeing any performance loss when window is stagnant, only when moving.
Just asking because I didn't experience this issue on Mint, and I'm just curious if it's because SDL2 works better on Xorg or is it Gnome to blame?
Offline

There is an issue with window resizes not properly registering in SDL under wayland, though that doesn't sound like what you're describing (it doesn't affect window movement). If you provide complete code I'd be happy to test whether I could replicate your issue.
Last edited by Trilby (2022-09-27 21:40:04)
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
Sorry for the late reply, I kinda forgot I posted this. Anyway, yeah, so I went through my entire project here https://youtu.be/XCMcJ27nUpA and my recording crashed near the end it was lagging so bad while moving.
Essentially my project has a C implementation and a C++ wrapper connected together for ease of use. I have tried both, but only showed the C++ wrapped version in the video. There is no window resizing, but clearly showing a lot of lag (I mean, it crashed my recording lol) when moving the window. Stagnant, it's fine.
Offline
Update: I've given up on OpenGL because of its vagueness, I find it rather tough to learn even if it is all around simpler.
However, with relevance to this thread, I've tried Vulkan. Haven't gone into rendering much yet, however I am not having the same issues with the window lagging.
Possibly has to do with SDL_GLContext?
I don't know. Guess I'll update if I give up on Vulkan too lol.
Offline

As you're trying out different toolkits, are you looking for something specifically cross platform and / or display-server agnostic? As a shameless plug, I've made a wayland client library that will handle the heavy lifting for creating an egl context and allows the user to just do the gl drawing. However, it is just for linux / wayland.
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
As you're trying out different toolkits, are you looking for something specifically cross platform and / or display-server agnostic?
No, quite frankly, SDL does everything I need it to, and in a way I am very much happy with. Needs cross-platform compatibility, sound, input, window management, and support for OpenGL or Vulkan. I'm slowly but surely building an ecosystem for me to start my game development journey. Right now, I'm working on the build manager (CarePackage) and game engine (not available). I'm still in the process of learning 3D graphics. Wish I had more time and will to dedicate to it.
Offline
Pages: 1