LWJGL

The Lightweight Java Game Library (LWJGL) is an open-source software library that provides bindings to a variety of C libraries for video game developers to Java. It exposes cross-platform libraries commonly used in developing video games and multimedia titles, such as Vulkan, OpenGL, OpenAL and OpenCL.

Lightweight Java Game Library (LWJGL)
Original author(s)Caspian Prince
Developer(s)Ioannis Tsakpinis
Initial release4 February 2007; 17 years ago (2007-02-04)[1]
Stable release
3.3.3 / 16 September 2023; 6 months ago (2023-09-16)
Repositorygithub.com/lwjgl
Written inJava, C, Kotlin[2][3]
Operating systemLinux, macOS, Windows, FreeBSD
PlatformJava platform
TypeFree computer library
LicenseBSD,[4] some bindings under different licenses[2]
Websitelwjgl.org

The primary goal of the project is to provide a way for Java developers to get access to resources that are otherwise unavailable or poorly implemented on the existing Java platform. The main philosophy is to expose underlying technology as a thin wrapper, thus creating an API close to the original. It is also the basis of many high-level Java game engines and libraries, such as libGDX or the jMonkeyEngine.

History edit

Development of the library began in 2002 with the release of J2SE 1.4, making use of the newly-added non-blocking I/O operations and off-heap memory access. These additions to the JDK allowed for better access to native memory and libraries not a part of the JDK. The first official release of the library was on 4 February 2007.[1]

On 13 November 2014, version 3 was announced, which was released in the alpha version on 27 April 2015 and is a complete rewrite of LWJGL.[5][6][7] Many new bindings, including GLFW, EGL and Objective-C, were added.[4][6] Support for Oculus Rift development was also added with LibOVR bindings.[4][7] The new version was released on 4 June 2016, after more than 3 and a half years in development.[8]

Bindings edit

The library accesses native C code through the Java Native Interface (JNI). Bindings to each of the native libraries exist as different modules so developers can make custom builds with only the things they need in a certain program.[4][7][9]

While utility classes are written in pure Java, most of the binding classes are automatically generated by a custom generator implemented in Kotlin.[2][3]

Since version 3.1, LWJGL is fully split into 51 modules that can be downloaded and used separately. To make this process easier, the project provides an online build configurator, which allows users to download custom combinations of modules and automatically generates Maven and Gradle configuration files to ease their use with existing projects.[10][11]

Provided bindings[2][4]
BindingCategoryDescriptionNotes
EGLKhronos APIsInterface between Khronos rendering APIs and the underlying native platform window system.
OpenCLAPI for cross-platform parallel computing.
OpenGL3D graphics specification implemented by most GPU vendors.Most extensions are supported, but less popular ones will be added on request.
OpenGL ESOpenGL for embedded systems like mobile phones, tablets, or consoles.
VulkanUpcoming cross-platform 3D graphics API.
GLFWDisplay and InputWindow management library needed for handling OpenGL and Vulkan contexts as well as user input.
JAWTAWT native interface.
nfdSmall cross-platform native file dialogs library.
tinyfdSmall native dialog library.
OpenALAudioThree-dimensional audio API.ALC and other extensions are supported. Specifically bundles the OpenAL Soft implementation.
OpusOpen, royalty-free audio codec.
AssimpGraphicsPortable open source library to import various 3D model formats.
bgfxCross-platform rendering library supporting multiple graphics backends.
DriftFXLibrary to render OpenGL content into JavaFX nodes.
LibOVRAPI of the Oculus Rift SDK.
meshoptimizerA mesh optimization library that makes meshes smaller and faster to render
NanoSVGSimple SVG parser.
NanoVG2D vector graphics rendering library using OpenGL.
NuklearSimple GUI library.
par_shapesGenerator for parametric and other simple shapes.
par_streamlinesTriangulate wide lines and curves.
OpenVRAn API runtime that allows access to VR hardware from multiple vendors without requiring applications have specific knowledge of the type of hardware they are targeting.
ShadercA collection of libraries for shader compilation
SPIRV-CrossA library for performing reflection on SPIR-V and disassembling SPIR-V back to high level languages.
OpenEXRA small, single-header library to load and save OpenEXR (.exr) images.
Tootle (AMD)A 3D triangle mesh optimization library that improves on existing mesh preprocessing techniques.
Vulkan Memory AllocatorAn easy to integrate Vulkan memory allocation library.
YogaAn open-source, cross-platform layout library that implements CSS Flexbox.
STBSTBLightweight single-file libraries for loading images, sounds and fonts.
Bullet PhysicsOtherReal-time collision detection and multi-physics simulation for VR, games, visual effects, robotics, machine-learning, etc.
CUDAA parallel computing platform and programming model developed by NVIDIA for general computing on GPUs.
dyncallLibrary for dynamically calling C functions in a portable way.Set to be removed.
jemallocLow-level memory management.
libffiA portable, high level programming interface to various calling conventions.Replaces dyncall.
libdivideA library that replaces expensive integer divides with comparatively cheap multiplication and bitshifts.
LLVMA collection of modular and reusable compiler and toolchain technologies.
LMDBFast database library using memory-mapped files.
LZ4A lossless data compression algorithm that is focused on speed.
Meow HashFast non-cryptographic hash.
ODBCA C-language interface that makes it possible for applications to access data from a variety of database management systems.
RemoteryRealtime CPU/GPU profiler.
rpmallocCross-platform thread caching memory allocator.
xxHashFast hash algorithm.
ZstandardA fast lossless compression algorithm.

Notable uses edit

References edit

  1. ^ a b Matzon, Brian (4 February 2007). "LWJGL 1.0 Released". LWJGL Forum. Retrieved 23 July 2016.
  2. ^ a b c d "LWJGL/lwjgl3". github.com. Retrieved 13 August 2016.
  3. ^ a b "lwjgl3/doc – Generator". github.com. 11 August 2015. Retrieved 30 August 2015.
  4. ^ a b c d e "Official website". Retrieved 14 August 2015.
  5. ^ Tsakpinis, Ioannis (13 November 2014). "Welcome to LWJGL 3". blog.lwjgl.org.
  6. ^ a b "LWJGL 3 Roadmap". github.com. Retrieved 2 June 2015.
  7. ^ a b c Tsakpinis, Ioannis (27 April 2015). "LWJGL 3.0.0a released". blog.lwjgl.org.
  8. ^ "LWJGL 3.0.0 Released!". blog.lwjgl.org. 4 June 2016. Retrieved 4 June 2016.
  9. ^ "Bindings FAQ". github.com. 27 December 2014. Retrieved 27 July 2015.
  10. ^ "LWJGL 3.1.0 Released!". blog.lwjgl.org. 30 October 2016. Retrieved 11 November 2016.
  11. ^ "Download – LWJGL". lwjgl.org. Retrieved 11 November 2016.
  12. ^ "Minecraft Attributions | Minecraft". Minecraft.net. Retrieved 9 July 2020.
  13. ^ "APZDTISA #3: This time with LIVE MULTIPLAYER!". Project Zomboid. 17 February 2014. Retrieved 25 January 2022.

External links edit