A feature rich template for creating OPENRNDR programs based on Gradle/Kts.
The template consists of a configuration for Gradle and two example OPENRNDR programs. The Gradle configuration should serve as the go-to starting point for writing OPENRNDR-based software.
If you are looking at this from IntelliJ IDEA you can start by expanding the project tab on the left. You will find a template program in src/main/kotlin/TemplateProgram.kt
and a live-coding example in src/main/kotlin/TemplateLiveProgram.kt
.
You will find some basic instructions in the OPENRNDR guide
./gradlew run
runs the TemplateProgram (Usegradlew.bat run
under Windows)./gradlew shadowJar
creates an executable platform specific jar file with all dependencies. Run the resulting program by typingjava -jar build/libs/openrndr-template-1.0.0-all.jar
in a terminal from the project root../gradlew jpackageZip
creates a zip with a stand-alone executable for the current platform (works with Java 14 only)
To create a runnable jar for a platform different from your current platform, use ./gradlew jar -PtargetPlatform=<platform>
, where <platform>
is either windows
, macos
, linux-x64
, or linux-arm64
.
The openrndr-template depends on various packages including the core openrndr and the orx extensions. The version numbers of these dependencies are specified in your libs.versions.toml file. If you want to learn about file format visit the Gradle documentation website.
Newer versions of OPENRNDR and ORX bring useful features and bug fixes. The most recent versions are
for OPENRNDR.
for ORX.
You can use those version numbers in your toml file. They can look like "0.4.3" or "0.4.3-alpha4". Use the complete string, as in:
openrndr = "0.4.3-alpha4"
orx = "0.4.3-alpha4"
You can add other dependencies needed by your project to your build.gradle.kts file, inside the dependencies { }
block.
Remember to reload the Gradle configuration after changing any dependencies.
By default ./gradlew run
runs a program called TemplateProgram.kt
but a different one can be provided as an argument:
To run src/main/kotlin/myProgram.kt
./gradlew run -Popenrndr.application=MyProgramKt
To run src/main/kotlin/foo/bar/myProgram.kt
(assuming package foo.bar
in myProgram.kt)
./gradlew run -Popenrndr.application=foo.bar.MyProgramKt
This repository contains a number of Github Actions under ./github/workflows
.
build-on-commit.yaml runs a basic build on every commit, which can help detect issues in the source code.
publish-binaries.yaml publishes binaries for Linux, Mac and Windows
any time a commit is tagged with a version number like v1.*
.
For example, we can create and push a tag with these git commands:
git tag -a v1.0.0 -m "v1.0.0"
git push origin v1.0.0
The progress of the running actions can be followed under the Actions tab in GitHub. Once complete, the executables will be found under the Releases section.