-
Notifications
You must be signed in to change notification settings - Fork 0
Project setup, running & debugging
Libgdx is very Eclipse centric due to it's Android and HTML5/GWT back-ends. this article discusses how to setup libgdx projects for Eclipse. Check out this Using libgdx with IntelliJ IDEA if you use IntelliJ. If you prefer to use a different IDE, please refer to the bottom of this page which outlines the dependencies in detail.
To target Windows, Linux, Mac OS X, Android and HTML5 you will need:
- Java Development Kit (JDK)
- Eclipse, the "Eclipse IDE for Java Developers" is usually sufficient.
- Android SDK and Eclipse ADT Plugin, simply follow the installation instructions. If you work from source, make sure to install all platforms in the Android SDK manager!
- Google Web Toolkit
To additionally target iOS you will also need:
- A Mac, iOS Development does not work on Windows/Linux thanks to Apple.
- The latest XCode, which you can get from the Mac OS X App Store for free
- RoboVM, simply install the Eclipse plugin, or use the command line version.
Follow this if you don't want to read a lot of text. Otherwise continue below.
As of version 0.9.3, libgdx comes with an easy to use application called "Libgdx Setup" by Aurelien Ribon. The following steps will create everything needed to develop for the desktop, android, ios and html5.
- Download the gdx-setup-ui.jar from http://libgdx.badlogicgames.com/nightlies/dist/gdx-setup-ui.jar. The jar is also contained in all stable and nightly releases.
- Execute the jar by double clicking it or from the command line via
java -jar gdx-setup-ui.jar
- Specify your project's configuration (Configuration Panel)
- Specify the libgdx stable/nightly release zip file or press one of the buttons to download the latest stable/nightly release (Library Selection Panel).
- Hit the "Generate projects" button (Generation Panel)
- Open Eclipse and import the generated projects into your workspace
File -> Import -> Existing Projects into Workspace
- Click "Browse", select the folder containing the generated projects.
- Make sure all the projects are checked, then click "Finish"
- To fix the error of the HTML5/GWT project, go to the "Problems" view, right click the error message "The GWT SDK JAR gwt-servlet.jar is missing in the WEB-INF/lib directory" and select "Quick Fix". Click "Finish".
Assuming you named your project "my-gdx-game" in the Setup UI, you will end up with 4 projects:
- Core project ("my-gdx-game"): contains all the code of your application, minus the so called starter classes. All other projects link to this project. This project is usually referred to as the "core project".
- Android project ("my-gdx-game-android"): contains the starter class and other necessary files to run your application on Android. The assets/ folder stores the assets of your application for all platforms.
- Desktop project ("my-gdx-game-desktop"): contains the starter class to run your application on the desktop. Links to the Android project's assets/ folder as well as the core project.
- HTML5 project ("my-gdx-game-html"): contains the starter class and other necessary files to run your application as a native HTML5 application. Links to the Anroid project's assets/ folder (see gwt.xml file) as well as to the core project.
- iOS RoboVM project ("my-gdx-game-robovm"): contains the starter classes and other necessary files to run your application on iOS through RoboVM. Links to the Android project's assets/ folder (see robovm.xml) as well as the core project.
iOS Xamarin project DEPRECATED! ("my-gdx-game-ios"): contains the starter class and other necessary files to run your application as a native iOS application. Links to the Android project's assets/data folder. Contains an Ant script that will be invoked before each build that compiles your core project's source code to a .Net assembly (.dll file) which is then used to build the native app. Please read this article for more information on the iOS backend!
All your application's assets should be stored in the Android project's assets folder. The desktop, iOS and HTML5 projects link to this folder, so there is no need to store duplicates of these assets.
Note for Xamarin iOS DEPRECATED!: Xamarin Studio will not automatically add files you put into your Android project's assets folder. You have to add those manually by right clicking the project and linking to the files. You then have to set the "Build Action" of each newly added file to "Content", otherwise the file will not be included in the final build output! Also, please read through this article You'll also have to manipulate a script that comes with the iOS SDK!
-
Desktop: Right click the desktop project,
Run As -> Java Application
. Select the desktop starter class (e.g. Main.java). -
Android: make sure you have a device connected and that it shows up in DDMS. If you do not know what this means, please refer to the Android Developer Guide. Right click your Android project,
Run As -> Android Application
. -
iOS RoboVM: Right click the robovm project,
Run As -> iOS Device App
to run on a connected device, orRun As -> iOS Simulator App
to run on the iOS simulator. If you run on a device, you need to provision it to be able to deploy to it! -
HTML5: there are two modes in which you can run your application.
development/hosted mode: runs the actual Java code via GWT plugin magic and allows debugging and hot swapping code (kind of).
In the "Web Development" view, click the URL. Your standard browser will open up. If you have not installed the GWT plugin yet, you will be prompted to do so. After installation of the plugin, simply refresh the site in the browser.
production/web mode: you will need a web server that serves the compiled files (e.g. Ngnix or a browser that allows to execute JavaScript from local files.
-
iOS Xamarin DEPRECATED!: In Xamarin Studio, select a release or debug profile (either simulator or device) then hit the build and run button.
-
Desktop: Right click the desktop project,
Debug As -> Java Application
. Select the desktop starter class (e.g. Main.java). Set breakpoints where you need them, hot swap code (edit & save while debugging) to quickly test changes without restarting the app. -
Android: assuming you have a device connected,
Debug As -> Android Application
. Hot swapping is not supported, but you can use the DDMS perspective to check your memory usage, profile your application and so on. Refer to the Android Development Guide for more information. - iOS RoboVM: debugging is currently not supported by RoboVM
iOS Xamarin DEPRECATED!: in Xamarin Studio, select a debug profile (either simulator or device) then hit the build and debug button.-
HTML5:
development/hosted mode: runs the actual Java code via GWT plugin magic and allows debugging and hot swapping code (kind of).
Set breakpoints in your Java code. If you edit & save code, you'll have to refresh your browser for the changes to take effect. This will essentially restart your application. It's faster than recompiling though.
Change the flags in "Advanced" to
-strict -draftCompile
and the "Output Style" to "detailed". This will produce very readable Javascript that you can map almost 1:1 to your Java code.
Please refer to [Manual Project Setup] (does not include iOS RoboVM Setup)
-
Developer's Guide
- Introduction
- Goals & Features
- Community & Support
- Contributing
- Games Built with Libgdx
- Prerequisites
- Gradle Project Setup, Running, Debugging and Packaging
- Project Setup, Running & Debugging
- Third Party Services
- Working from Source
- Using libgdx with other JVM languages
- The Application Framework
- A Simple Game
- File Handling
- Networking
- Preferences
- Input Handling
- Memory Management
- Audio
-
Graphics
- Configuration & Querying Graphics ??
- Fullscreen & VSync
- Continuous & Non-Continuous Rendering
- Clearing the Screen
- Take a Screenshot
- OpenGL ES Support * Configuration & Querying OpenGL ?? * Direct Access ?? * Utility Classes * Rendering Shapes * Textures & TextureRegions * Meshes * Shaders * Frame Buffer Objects
- 2D Graphics * SpriteBatch, TextureRegions, and Sprite * 2D Animation * Clipping, with the use of ScissorStack * Orthographic camera * Mapping Touch Coordinates ?? * Viewports * NinePatches * Bitmap Fonts * Distance field fonts * Using TextureAtlases * Pixmaps * Packing Atlases Offline * Packing Atlases at Runtime * 2D Particle Effects * Tile Maps * scene2d * scene2d.ui * Skin
- 3D Graphics * Quick Start * Models * Material and environment * 3D animations and skinning * Importing Blender models in LibGDX * Perspective Camera ?? * Picking ??
- Managing Your Assets
- Utilities
-
Math Utilities
- Interpolation
- Vectors, Matrices, Quaternions
- Circles, Planes, Rays, etc.
- Path interface & Splines
- Bounding Volumes ??
- Intersection & Overlap Testing ??
- Physics
- Tools
- Extensions
- Deploying your Application
- Building Libgdx ??
- Known Issues
- Articles
- Deprecated (May be outdated)