libGDX is a free and open-source[3] game-development application framework[2] written in the Java programming language with some C and C++ components for performance dependent code.[4] It allows for the development of desktop and mobile games by using the same code base.[5] It is cross-platform, supporting Windows, Linux, macOS, Android, iOS, BlackBerry and web browsers with WebGL support.[2][6]
Original author(s) | Mario Zechner |
---|---|
Initial release | 20 April 2014[1] |
Stable release | 1.13.0
/ 17 October 2024 |
Repository | |
Written in | Java, C, C++ |
Operating system | Windows, Linux, macOS, Android, BlackBerry OS, iOS, Java Applet, JavaScript/WebGL[2] |
Platform | Java platform |
License | Apache License 2.0[2] |
Website | https://libgdx.com |
History
editIn the middle of 2009 Mario Zechner, the creator of libGDX, wanted to write Android games and started developing a framework called AFX (Android Effects) for this. When he found that deploying the changes from Desktop to Android device was cumbersome, he modified AFX to work on the Desktop as well, making it easier to test programs. This was the first step toward the game framework later known as libGDX.[1]
In March 2010 Zechner decided to open-source AFX, hosting it on Google Code under the GNU Lesser General Public License (LGPL). However, at the time he stated that "It's not the intention of the framework to be used for creating desktop games anyway", intending the framework to primarily target Android. In April, it got its first contributor.[1][7]
When Zechner created a Box2D JNI wrapper, this attracted more users and contributors because physics games were popular at the time.[better source needed] Many of the issues with Android were resolved because of this.[1]
Because many users suggested switching to a different license due to LGPL not being suitable for Android, libGDX changed its license to the Apache License 2.0 in July 2010, making it possible to use the framework in closed-source commercial games.[1][8] The same month its phpBB forum was launched.[1][9]
Due to issues with Java Sound the audio desktop implementation switched to OpenAL in January 2011.[1][10] Development of a small image manipulation library called Gdx2D was finished as well, which depends on the open source STB library.[1][11]
The rest of 2011 was spent adding a UI library[12] and working on the basics of a 3D API.[1]
At the start of 2012 Zechner created a small helper library called gdx-jnigen for easing the development of JNI bindings.[1][13] This made it possible for the gdx-audio[14] and gdx-freetype[15] extensions to be developed over the following months.[1]
Inspired by Google's PlayN cross-platform game development framework that used Google Web Toolkit (GWT) to compile Java to JavaScript code, Zechner wrote an HTML/JavaScript backend over the course of several weeks, which allowed libGDX applications to be run in any browser with WebGL support.[1] After Google abandoned PlayN, it was maintained by Michael Bayne, who added iOS support to it. libGDX used parts of this work for its own MonoTouch-based backend.[1][16][17]
In August 2012 the project switched its version control system from Subversion to Git, moving from Google Code to GitHub. However, the issue tracker and wiki remained on Google Code for another year. The main build system was also changed to Maven, making it easier for developers with different IDEs to work together.[1][18][19]
Because of issues with the MonoTouch iOS backend Niklas Thernig wrote a RoboVM backend for libGDX in March 2013, which was integrated into the project in September.[1][20][21] From March to May 2013 a new 3D API was developed as well and integrated into the library.[1][22][23]
In June 2013 the project's website was redone, now featuring a gallery where users can submit their games created with libGDX.[1][24] As of January 2016[update] more than 3000 games have been submitted.[25]
After the source code migration to GitHub the year before, in September 2013 the issue tracker and wiki were also moved there from Google Code.[1][26] The same month the build and dependency management system was switched from Maven to Gradle.[1][27]
After a cleanup phase in the first months of 2014 libGDX version 1.0 was released on 20 April, more than four years after the start of the project.[1]
In 2014 libGDX was one of the annual Duke's Choice Award winners, being chosen for its focus on platform-independence.[28][29]
From a diverse team of open source enthusiasts comes libGDX, a cross-platform game development framework that allows programmers to write, test, and debug Java games on a desktop PC running Windows, Linux, or Mac OS X and deploy that same code to Android, iOS and WebGL-enabled browsers—something not widely available right now. The goal of libGDX, says creator Mario Zechner, "is to fulfill the 'write once, run anywhere' promise of the Java platform specifically for game development."
— Java Magazine September/October 2014[30]
In April 2016 it was announced that libGDX would switch to Intel's Multi-OS Engine on the iOS backend after the discontinuation of RoboVM.[31][32] With the release of libGDX 1.9.3 on 16 May 2016 Multi-OS is provided as an alternative, while by default the library uses its own fork of the open source version of RoboVM.[33][34]
libGDX Jam
editFrom 18 December 2015 to 18 January 2016 a libGDX game jam was organized together with RoboVM, itch.io and Robotality. From initially 180 theme suggestions "Life in space" was chosen as the jam's main theme, and 83 games were created over the course of the competition.[35][36]
Release versions
editVersion | Release date |
---|---|
1.0 | 20 April 2014[1] |
1.1 | 23 May 2014[37] |
1.2 | 22 June 2014[38] |
1.3 | 9 August 2014[39] |
1.4 | 10 October 2014[40] |
1.5 | 8 December 2014[41] |
1.6 | 6 May 2015[42] |
1.7 | 21 September 2015[43] |
1.8 | 5 January 2016[44] |
1.9 | 24 January 2016[45] |
1.10 | 18 April 2021[46] |
1.11 | 11 May 2022[47] |
1.12 | 2 July 2023[48] |
1.13 | 17 October 2024[49] |
Legend: | Old version, not maintained | Current stable version |
---|
Architecture
editlibGDX allows the developer to write, test, and debug their application on their own desktop PC and use the same code on Android. It abstracts away the differences between a common Windows/Linux application and an Android application. The usual development cycle consists of staying on the desktop PC as much as possible while periodically verifying that the project still works on Android. Its main goal is to provide total compatibility between desktop and mobile devices, the main difference being speed and processing power.[5]
Backends
editThe library transparently uses platform-specific code through various backends to access the capabilities of the host platform. Most of the time the developer does not have to write platform-specific code, except for starter classes (also called launchers) that require different setup depending on the backend.[50]
- On the desktop the Lightweight Java Game Library (LWJGL) is used. There is also an experimental JGLFW backend that is not being continued anymore.[citation needed][when?] In Version 1.8 a new LWJGL 3 backend was introduced, intended to replace the older LWJGL 2 backend.[51]
- The HTML5 backend uses the Google Web Toolkit (GWT) for compiling the Java to JavaScript code, which is then run in a normal browser environment. libGDX provides several implementations of standard APIs that are not directly supported there, most notably reflection.[52][53][54]
- The Android backend runs Java code compiled for Android with the Android SDK.[citation needed]
- For iOS a custom fork of RoboVM is used to compile Java to native iOS instructions. Intel's Multi-OS Engine has been provided as an alternative since the discontinuation of RoboVM.[31][33]
Other JVM languages
editWhile libGDX is written primarily in Java, the compiled bytecode is language-independent, allowing many other JVM languages to directly use the library. The documentation specifically states the interoperability with Ceylon, Clojure, Kotlin, Jython, JRuby and Scala.[55]
Extensions
editSeveral official and third-party extensions exist that add additional functionality to the library.
gdxAI
editAn artificial intelligence (AI) framework that was split from the main library with version 1.4.1 in October 2014 and moved into its own repository. While it was initially made for libGDX, it can be used with other frameworks as well. The project focuses on AI useful for games, among them pathfinding, decision making and movement.[56][57]
gdx freetype
editCan be used to render FreeType fonts at run time instead of using static bitmap images, which do not scale as well.[58]
Box2D
editA wrapper for the Box2D physics library was introduced in 2010 and moved to an extension with the 1.0 release.[1][59]
packr
editA helper tool that bundles a custom JRE with the application so end users do not have to have their own one installed.[60][61]
Notable games
edit- Ingress (before it was relaunched as Ingress Prime)
- Slay the Spire[62]
- Delver
- Mindustry
- Shattered Pixel Dungeon
- Wildermyth[63]
See also
editReferences
edit- ^ a b c d e f g h i j k l m n o p q r s t u v Zechner, Mario (20 April 2014). "libGDX 1.0 released". badlogicgames.com. Archived from the original on 13 February 2021. Retrieved 31 December 2015.
- ^ a b c d "Goals and Features". libgdx.badlogicgames.com. Archived from the original on 6 June 2012. Retrieved 16 December 2015.
- ^ "Official website". libgdx.badlogicgames.com. Archived from the original on 27 May 2011. Retrieved 2 January 2016.
- ^ "mobilegameengines.com/game_engines/32-libgdx". Archived from the original on 18 January 2015.
- ^ a b "Home - libGDX". libgdx.com.
- ^ "libgdx/README.md at master". github.com.
- ^ Zechner, Mario (6 March 2010). "The Future..." badlogicgames.com. Archived from the original on 14 March 2016. Retrieved 31 December 2015.
- ^ Zechner, Mario (13 July 2010). "libgdx changes its license". badlogicgames.com. Archived from the original on 14 January 2016. Retrieved 31 December 2015.
- ^ Zechner, Mario (10 July 2010). "Forums!". badlogicgames.com. Archived from the original on 4 March 2016. Retrieved 3 January 2016.
- ^ Zechner, Mario (21 January 2011). "OpenAL & Natives Loading in Libgdx". badlogicgames.com. Archived from the original on 4 March 2016. Retrieved 3 January 2016.
- ^ Zechner, Mario (26 January 2011). "Gdx2D and Super Jumper". badlogicgames.com. Archived from the original on 14 March 2016. Retrieved 3 January 2016.
- ^ Zechner, Mario (25 June 2011). "UI Fun on Android with libgdx". badlogicgames.com. Archived from the original on 4 March 2016. Retrieved 3 January 2016.
- ^ Zechner, Mario (3 January 2012). "gdx-jnigen: a stupid idea that might just work". badlogicgames.com. Archived from the original on 14 March 2016. Retrieved 3 January 2016.
- ^ Zechner, Mario (8 January 2012). "gdx-audio". badlogicgames.com. Archived from the original on 14 March 2016. Retrieved 3 January 2016.
- ^ Zechner, Mario (6 March 2012). "Create BitmapsFonts on the fly with gdx-freetype". badlogicgames.com. Archived from the original on 21 January 2016. Retrieved 3 January 2016.
- ^ Zechner, Mario (8 June 2012). "Libgdx on iOS, days 1–2". badlogicgames.com. Archived from the original on 14 March 2016. Retrieved 3 January 2016.
- ^ Zechner, Mario (13 June 2012). "Libgdx on iOS, day 5". badlogicgames.com. Archived from the original on 12 January 2016. Retrieved 3 January 2016.
- ^ Zechner, Mario (8 August 2012). "Git & Maven". badlogicgames.com. Archived from the original on 4 March 2016. Retrieved 4 January 2016.
- ^ Zechner, Mario (10 August 2012). "Libgdx is now on Github (sorta)". badlogicgames.com. Archived from the original on 4 March 2016. Retrieved 4 January 2016.
- ^ Zechner, Mario (9 March 2013). "Early stage RoboVM libgdx backend". badlogicgames.com. Archived from the original on 13 March 2016. Retrieved 6 January 2016.
- ^ Zechner, Mario (10 September 2013). "RoboVM backend in libgdx nightlies and first performance figures!". badlogicgames.com. Archived from the original on 4 March 2016. Retrieved 6 January 2016.
- ^ Zechner, Mario (28 March 2013). "Brace yourselfs, new 3D API incoming". badlogicgames.com. Archived from the original on 24 February 2016. Retrieved 6 January 2016.
- ^ Zechner, Mario (20 May 2013). "New 3D API in master". badlogicgames.com. Archived from the original on 4 March 2016. Retrieved 6 January 2016.
- ^ Zechner, Mario (29 June 2013). "New libgdx site live!". badlogicgames.com. Archived from the original on 4 March 2016. Retrieved 6 January 2016.
- ^ "Gallery". libgdx.badlogicgames.com. Archived from the original on 19 January 2016. Retrieved 6 January 2016.
- ^ Zechner, Mario (14 September 2013). "The great libgdx Issue Tracker & Wiki Github Migration". badlogicgames.com. Archived from the original on 4 March 2016. Retrieved 6 January 2016.
- ^ Zechner, Mario (22 September 2013). "Welcome your new overlord: Gradle". badlogicgames.com. Archived from the original on 4 March 2016. Retrieved 6 January 2016.
- ^ Kvitkar, Caroline (28 September 2014). "2014 Duke's Choice Award Winners". blogs.oracle.com. Retrieved 30 December 2015.
Programmers can use this cross-platform game development framework to write, test, and debug Java games.
- ^ Zechner, Mario (29 September 2014). "libgdx wins Duke's Choice Award". badlogicgames.com. Archived from the original on 1 March 2016. Retrieved 30 December 2015.
- ^ Gill, Philip J. "2014 Duke's Choice Awards". Java Magazine. p. 8. Retrieved 31 December 2015.
- ^ a b Zechner, Mario (15 April 2016). "RoboVM is no more, what now?". Archived from the original on 8 November 2020. Retrieved 15 April 2016.
- ^ Müller, Henric (15 April 2016). "RoboVM Winding Down". Archived from the original on 15 April 2016. Retrieved 16 April 2016.
- ^ a b Zechner, Mario (16 May 2016). "libGDX 1.9.3 released – New iOS backends". Archived from the original on 18 May 2016. Retrieved 17 May 2016.
- ^ "MobiDevelop's RoboVM fork". Retrieved 17 May 2016.
- ^ Zechner, Mario (22 November 2015). "libGDX Jam is on! – Theme Voting Round #1". badlogicgames.com. Archived from the original on 16 February 2016. Retrieved 13 February 2016.
- ^ Zechner, Mario (6 February 2016). "libGDX Jam – And the winner is…". badlogicgames.com. Archived from the original on 16 February 2016. Retrieved 13 February 2016.
- ^ Zechner, Mario (23 May 2014). "libGDX 1.1.0 released". badlogicgames.com. Archived from the original on 16 February 2016. Retrieved 13 February 2016.
- ^ Zechner, Mario (22 June 2014). "libGDX 1.2.0 released". badlogicgames.com. Archived from the original on 16 February 2016. Retrieved 13 February 2016.
- ^ Zechner, Mario (9 August 2014). "libGDX 1.3.0 released". badlogicgames.com. Archived from the original on 16 February 2016. Retrieved 13 February 2016.
- ^ Zechner, Mario (10 October 2014). "libGDX 1.4.1 released". badlogicgames.com. Archived from the original on 16 February 2016. Retrieved 13 February 2016.
- ^ Zechner, Mario (8 December 2014). "libGDX 1.5.0 released". badlogicgames.com. Archived from the original on 16 February 2016. Retrieved 13 February 2016.
- ^ Zechner, Mario (6 May 2015). "libGDX 1.6.0 released". badlogicgames.com. Archived from the original on 16 February 2016. Retrieved 13 February 2016.
- ^ Zechner, Mario (21 September 2015). "libGDX 1.7.0 released". badlogicgames.com. Archived from the original on 16 February 2016. Retrieved 13 February 2016.
- ^ Zechner, Mario (5 January 2016). "libGDX 1.8.0 released". badlogicgames.com. Archived from the original on 16 February 2016. Retrieved 13 February 2016.
- ^ Zechner, Mario (24 January 2016). "libGDX 1.9.0 released". badlogicgames.com. Archived from the original on 16 February 2016. Retrieved 13 February 2016.
- ^ damios (18 April 2021). "libGDX 1.10.0". libgdx.com. Retrieved 19 April 2021.
- ^ damios (11 May 2022). "libGDX 1.11.0". libgdx.com. Retrieved 12 May 2022.
- ^ damios (2 July 2023). "libGDX 1.12.0". libgdx.com. Retrieved 24 July 2023.
- ^ damios (17 October 2024). "libGDX 1.13.0". libgdx.com. Retrieved 21 October 2024.
- ^ "Starter classes & configuration - libGDX". libgdx.com. Retrieved 18 January 2022.
- ^ Zechner, Mario (5 January 2016). "libGDX 1.8.0". badlogicgames.com. Archived from the original on 12 January 2016. Retrieved 11 January 2016.
- ^ Zechner, Mario (12 March 2012). "Libgdx goes HTML5". badlogicgames.com. Archived from the original on 29 March 2016. Retrieved 17 May 2016.
- ^ Zechner, Mario (19 January 2013). "Reflection in libgdx's GWT backend". badlogicgames.com. Archived from the original on 10 June 2016. Retrieved 17 May 2016.
- ^ Zechner, Mario (17 June 2013). "Reflection API with GWT support!". badlogicgames.com. Archived from the original on 10 June 2016. Retrieved 17 May 2016.
- ^ "Using libgdx with other jvm languages". libgdx.com. Retrieved 18 January 2022.
- ^ "gdx-ai/README.md". github.com. 12 October 2015. Retrieved 16 January 2016.
- ^ "Artificial Intelligence". libgdx.com. Retrieved 18 January 2022.
- ^ "Gdx freetype". libgdx.com. Retrieved 18 January 2022.
- ^ "Box2d". libgdx.com. Retrieved 18 January 2022.
- ^ "libgdx/packr: Packages your JAR, assets and a JVM for distribution on Windows, Linux and Mac OS X". github.com. Retrieved 6 February 2016.
- ^ Zechner, Mario (4 May 2014). "Packr – pack your libGDX app for Windows, Linux, Mac OS X". badlogicgames.com. Archived from the original on 27 April 2020. Retrieved 6 February 2016.
- ^ Couture, Joel (22 January 2020). "Road to the IGF: Mega Crit Games' Slay the Spire". www.gamasutra.com. Retrieved 22 January 2020.
- ^ "Patch notes - Wildermyth Wiki". wildermyth.com. Retrieved 23 August 2022.