Check Engine
data:image/s3,"s3://crabby-images/f9b3c/f9b3ccabf474b916696d8f626f02656fe9b8b63a" alt="Lighting and Game Mode Demo"
Platform Support |
|
OpenGL | Core 4.3 or ES 3.0 |
Runtime | OpenJDK 11 or similar |
Downloads | Runnable Test Game |
data:image/s3,"s3://crabby-images/f1086/f1086eecad1f7541f0d020e35b14e13eae9c7103" alt="Pathtraced 2D Lighting"
Pathtraced Lighting
Lighting is performed by generating a vector of distance measurements organized in a radial pattern. A path can be drawn along each vector to determine which areas of the screen are in light, and which are cast in shadow.
The result is a hard-edged shadow effect, several of which can be blended to account for multiply-lit scenes.
data:image/s3,"s3://crabby-images/37ba4/37ba41572bd5a1cf35fa6a0f8ad323ae2c8b07a3" alt="Non-player Character With Behavior"
Behavior System
Non-player characters can be assigned behaviors which update each frame and re-calculate the entity's goal within the game.
Complex behaviors, such as player-following and random wandering algorithms, are implemented in the provided test game.
data:image/s3,"s3://crabby-images/860b3/860b3c77cd9d78a765079fd4912d394c161eb4f5" alt="Dependency Injection Code Example"
Dependency Injection
The engine provides automatic injection of singleton types called "engine objects." Types are scanned from the classpath based on annotations.
Engine objects can rely on other singletons to access and affect game state.
data:image/s3,"s3://crabby-images/bd4d4/bd4d4ede5d3566c5288663d6ad865b2b41508cd3" alt="AABB Physics, Friction, and Momentum"
AABB Collision, Friction, and Platforming
Limited physics calculations are supported by the engine, including resolving collisions between dynamic and static entities.
Entities which are not affected by gravity (such as platforms) are able to support and carry players, and also give them momentum if they jump off.
data:image/s3,"s3://crabby-images/24616/24616934702303f658f6da8dd0d3a42f6345b7cd" alt="Imgui Integration Example"
Included Imgui bindings
In order to guarantee compatibility with Raspberry Pi and the engine's own rendering, the Java bindings for Imgui were adapted to support OpenGL ES and ARM platforms.
The game engine includes special native libraries and Java bindings which have been specifically verified to work on the Raspberry Pi 4 with OpenGL ES 3.0.
Animation and Resource Loading
The engine supports loading several common image formats, and also supports loading animations as GIFs. GIF images are automatically converted into a knit spritesheet; animation frames are automatically swapped in and out by the engine according to the GIF's animation speed.
Programmers are able to load GIFs just like any other texture due to abstraction layers in the process of creating and binding textures.
data:image/s3,"s3://crabby-images/6354d/6354d248bfc081b5b7194c6011526ed39bdc893d" alt="Code to Load a GIF in the Engine"
data:image/s3,"s3://crabby-images/3b3db/3b3db106d76ecea1a725049328388094d3927ad6" alt="Character Yelling Right Animation"
data:image/s3,"s3://crabby-images/3b3db/3b3db106d76ecea1a725049328388094d3927ad6" alt="Character Yelling Left Animation"