SDL (Simple DirectMedia Layer) is a cross-platform development library designed to provide low level access to audio, keyboard, mouse, joystick, and graphics hardware used by a great many companies and SDL 2 is now pretty much finished.
This software is used by Valve with Steam and Source 2, Unity game engine, tons of games, emulators and much more to provide easy cross-platform support for features noted above. It's a rather important thing for Linux gaming.
With the release of version 2.28.0, there's plenty of bug fixes and these additional features added:
- Added SDL_HasWindowSurface() and SDL_DestroyWindowSurface() to switch between the window surface and rendering APIs
- Added a display event SDL_DISPLAYEVENT_MOVED which is sent when the primary monitor changes or displays change position relative to each other
- Added the hint SDL_HINT_ENABLE_SCREEN_KEYBOARD to control whether the on-screen keyboard should be shown when text input is active
That's it for SDL 2 now though, as it's moving into maintenance mode since their focus has moved onto SDL 3. With the major new version in the works they're going to be making some huge changes like adding in a 3D GPU API, full support for high DPI displays and much more.
Like, we don't need yet snother 3d graphics API. Especially not now when the serious APIs (like Vulkan) are still struggling trying to figure out how to best do things. APIs like SDL's would end up based on those 3 APIs and naturally make the same mistakes.
Last edited by ShabbyX on 22 Jun 2023 at 8:28 pm UTC
SDL is awesome, but it looks like it's planning to to be not-so-simple anymore.Why not?
Like, we don't need yet snother 3d graphics API. Especially not now when the serious APIs (like Vulkan) are still struggling trying to figure out how to best do things. APIs like SDL's would end up based on those 3 APIs and naturally make the same mistakes.
<removed because I was talking about a subject I do not have the detailed knowledge of>
Last edited by hardpenguin on 22 Jun 2023 at 12:31 pm UTC
SDL is awesome, but it looks like it's planning to to be not-so-simple anymore.Why not?
Like, we don't need yet snother 3d graphics API. Especially not now when the serious APIs (like Vulkan) are still struggling trying to figure out how to best do things. APIs like SDL's would end up based on those 3 APIs and naturally make the same mistakes.
<removed because I was talking about a subject I do not have the detailed knowledge of>
I feel like I already said why not. A lot of ideas that shaped Vulkan turned out to be impractical (multipass render passes, fully static pipelines, decriptor pools, etc). A *lot* of it has fundamentally changed in recent years. Other APIs (d3d12 and metal) have solved some other problems but not half of what Vulkan has solved. A common API (which will necessarily be layered over the main APIs) will end up being a common denominator which means the worst of all worlds.
Also, SDL's strength is in making system integration easy. A real usable graphics API is soooo much work, it just takes away SDL's resources from what people need it for.
Also, SDL's strength is in making system integration easy. A real usable graphics API is soooo much work, it just takes away SDL's resources from what people need it for.
Nah, he got an Epic Megagrant specifically to work on that project. Dunno what he does nowadays, but in the past he made money through contracting on ports to fund his SDL work. Hard to say it's diverting his valuable attention when it's already funded. The API seems like it's been done for quite a while and seems like a nice simple subset of modern APIs. https://github.com/icculus/SDL/blob/gpu-api/include/SDL3/SDL_gpu.h
IMO, the most risky bit is that he's making his own shader cross-compiling tools. "custom language" always sounds like a terrifying idea since I've never done it, but he seems to be well underway already. (shrug)
https://github.com/libsdl-org/SDL_shader_tools/
I've written a simple Vulkan renderer, and it's "not that bad", but it's not simple either. I don't think I could have done it without a decade and a half of GL knowledge already. A main point of the SDL GPU API is to make something that's beginner friendly, or just friendly for writing simple stuff. I do *not* use Vulkan in my simple projects where I just want to hash out an idea...
Nah, he got an Epic Megagrant specifically to work on that project.Well, if someone's paying the piper . . . dunno how far that will stretch, though; lest we forget, they're actually more like Epic Kilogrants.
I hope we get an early SDL2->3 shim library this time in before distros decide to make SDL2 obsolete.We will. Which brings us to the question: Will SDL 1.2 to SDL 2.0 compatibility library be compatible with SDL 2.0 to SDL 3.0 compatibility library?!
I hope we get an early SDL2->3 shim library this time in before distros decide to make SDL2 obsolete.We will. Which brings us to the question: Will SDL 1.2 to SDL 2.0 compatibility library be compatible with SDL 2.0 to SDL 3.0 compatibility library?!
It should be, I mean the 1.2 to 2.0 shim would use the 2.0 to 3.0 shim, so yes there would be overhead due to every single call being several calls underneath the hood but it should work out of the box so to speak.
See more from me