This is a sample of how to integrate libGDX (1.6.1) with Ruboto (1.3.0). The aim is only to get things working, with as much code on the Java side as possible.
This project used to feed into Terrace, but branched off. (Terrace requires a shared/common repository structure, whereas this repository is intended to be standalone.)
- Edit src/terrace_game.rb. Change whatever you want (eg. background colour, sprite position)
- Run rake debug
- Deploy bin/Libgdx-debug.apkto your Android device/emulator.
- Rejoice.
LibGDX is an all-Java solution. Ruboto provides APK packaging and JRuby exection of code that can connect to Java code. Putting two and two together, we extract libGDX's core/main game class into Ruby code, and execute it, leaving the rest of the stack a Java stack.
Specifically, the current libGDX project setup creates a Core module (which contains the common game, with the game logic in it), and separate per-platform launchers, such as Desktop and Android. These launchers are thin wrappers that just launch the core game logic, on their respective platforms.
This repository contains, essentially, the Android platform launcher, with a Ruby game class from Core. We create the core class in Ruby code, then pass it to the Java side (through a static variable currently).
There are other repositories that demonstrate integration (not for Android), but which are now dead. Here's what we did to make this work:
- Get libGDX working on Android
- Get libGDX working for Desktop with JRuby
- Create a new Ruboto project
- Copy over all required JAR files and .sofiles from theAndroidproject (and Gradle/Maven repositories) intolibs. This list depends on if you need box2d or not
- Copy over the assetsdirectory from the Core project
- Copy the relevant Core and Android LauncherandGameclasses intosrc
- Update AndroidManifest.xmlto launch theAndroidLauncheractivity
- Run rake debugand test on an emulated device