/FXGL-on-RaspberryPi-embedded

Bare Bones FXGL on a embedded Raspberry Pi (no desktop).

Primary LanguageJavaMIT LicenseMIT

FXGL-on-RaspberryPi-embedded

Bare bones demo of FXGL(with JavaFX) on an embedded 64-bit RaspberryPi Zero 2 W with attached HDMI screen. Hopefully this framework will get you started on making cool arcade-game-like things with FXGL on Raspberry Pi.

When designing an embedded kiosk-style system on RaspBerry Pi that uses FXGL for it's main app, this code base will quickly get you to a starting point for your own system.

This tutorial is an enhancement of my basic tutorial for a bare bones install of JavaFX onto a Raspberry Pi. Here we have the addition of FXGL via Maven repository and a simple FXGL 'hello world' screen.

This example uses a Raspberry Pi 2W but should work for any 64-bit Raspberry Pi board. Remote terminal tasks were performed on a Mac, so your Windows terminal experience might differ.

Prepare the Raspberry Pi

Using Raspberry Pi Imager, create a 64-bit version of the OS (without desktop) onto the SD card. Configure the card for SSH, password and your WiFi settings so that you can log into it after first boot. The latest Raspberry Pi Imager has a feature to help pre-configure this.

Boot the Raspberry Pi

Boot your Pi and log in using a terminal on your workstation.

ssh pi@raspberrypi.local

Update the Pi

sudo apt update
sudo apt upgrade

Add these packages:

sudo apt install openjdk-17-jdk -y
sudo apt install git
sudo apt install maven
sudo apt install tree
sudo apt install libgdm-dev
sudo apt install libegl-dev
sudo apt install libgles2-mesa-dev

Install JavaFX

Unless you posses a commercial license, you will always need to use early access (EA) releases of JavaFX. The Direct Rendering features used for kiosk mode applications are licensed by Gluon but are available for developers. Browse your download options here: https://gluonhq.com/products/javafx/

You should be choosing an Early Access, Linux, aarch64, Monocle SDK download.

As of 2022 September, I used version 20 EA + 2 (example):

wget https://download2.gluonhq.com/openjfx/20/openjfx-20-ea+2_monocle-linux-aarch64_bin-sdk.zip

To get the download link, right-click the 'Download' button and copy the link. It should point to a zip file.

If you have issues attempting to use 'wget' for downloading, use the web page on your workstation to download the ZIP file and then use 'scp' to place it onto your Pi.

Unpack the JavaFX zip file (from your Pi SSH session)

unzip openjfx-20-ea+2_monocle-linux-aarch64_bin-sdk.zip
sudo mv javafx-sdk-20 /opt/

Clone this repository onto the Pi

git clone https://github.com/maehem/FXGL-on-RaspberryPi-embedded
cd FXGL-on-RaspberryPi-embedded

Adjust path to JavaFX

Edit the pom.xml file for the script to properly point to the version of JavaFX that you installed. Look for 'javafx.version' definition.

Adjust library path in execution script

Edit the 'run-kiosk.sh' file under the 'assets' folder to point to your JavaFX installation path in /opt (the variable JAVAFX_VER). You might also have to edit the GLUON_VER in the same file ( 1.1.7 as of 2022-September). If you look in /opt/javafx-sdk-**/lib, you'll see the 'lib-gluon-1.1.?.so' file. Use that number.

Compile the Example

mvn package

Run the Example

If you use an input device for any interaction, you will need to 'sudo' execution. However, there are things you can do to allow 'pi' user input device access. Use the Googles to find out more.

cd target/distribution
sudo ./run-kiosk.sh