Compare commits

...

35 Commits

Author SHA1 Message Date
Edwin Jakobs
b7dbf58574 Bump to latest OPENRNDR release 2020-07-06 19:18:53 +02:00
Edwin Jakobs
55eff802c5 Prepare for OPENRNDR 0.3.43 2020-07-06 15:07:34 +02:00
Edwin Jakobs
88782c614f Fix runtime configuration to produce working macOS binaries 2020-06-15 12:18:35 +02:00
Edwin Jakobs
a90e036620 Merge pull request #9 from hamoid/removeRedundantBoofcv
Remove redundant boofcv dependency
2020-06-10 20:53:07 +02:00
Abe Pazos
6964febf08 Remove redundant boofcv dependency 2020-06-09 15:04:34 +02:00
Edwin Jakobs
4f2bea7d94 Merge pull request #7 from hamoid/upstreamMaster
Add boofcv to build.gradle.kts
2020-05-20 08:54:33 +02:00
Abe Pazos
a483ecfd64 Add boofcv to build.gradle.kts 2020-05-19 09:58:10 +02:00
Edwin Jakobs
c9bbe84471 Merge pull request #6 from ricardomatias/patch-1
Add orx-time-operators
2020-05-18 16:57:09 +02:00
Ricardo Matias
ae0ef47a44 Add orx-time-operators 2020-05-17 20:49:28 +02:00
Edwin Jakobs
f391fed255 Add jpackageZip and Github actions for publishing binaries 2020-05-17 11:00:48 +02:00
Edwin Jakobs
896a8629fa Upgrade OPENRNDR/ORX 2020-05-15 18:15:31 +02:00
Edwin Jakobs
53dec983b1 Upgrade OPENRNDR/ORX, kotlin-coroutines core 1.3.6 2020-05-11 09:08:17 +02:00
Edwin Jakobs
0296f5036f Upgrade to Gradle 6.4 2020-05-06 23:26:31 +02:00
Edwin Jakobs
5151b7af89 Upgrade OPENRNDR, change TemplateLiveProgram.kt 2020-05-06 19:13:30 +02:00
Edwin Jakobs
38254b084d Fix issue with IntelliJ and not having the script runtime on the classpath 2020-04-29 14:48:21 +02:00
Edwin Jakobs
5c0b2b2c3f Upgrade to OPENRNDR 0.3.42-rc.2, ORX 0.3.51-rc.3, Kotlin 1.3.72 2020-04-29 12:13:33 +02:00
Edwin Jakobs
e86cf3f7e6 Upgrade to OPENRNDR 0.3.40, ORX 0.3.50 2020-03-27 22:21:57 +01:00
Edwin Jakobs
3374024592 Merge pull request #4 from reinvdwoerd/patch-3
Added orx-shapes
2020-03-09 14:55:29 +01:00
Rein van der Woerd
14bb87c02e Update build.gradle.kts 2020-03-09 13:18:31 +01:00
Edwin Jakobs
6c0d0ed16b Merge pull request #3 from reinvdwoerd/patch-2
Added missing orx features...
2020-03-04 13:54:40 +01:00
Rein van der Woerd
eab750d7f7 Added missing orx features... 2020-03-04 13:22:19 +01:00
Edwin Jakobs
63bbdb1218 Merge pull request #2 from reinvdwoerd/patch-1
orx-noclear has been renamed to orx-no-clear
2020-03-02 18:14:58 +01:00
Rein van der Woerd
59349d83f2 orx-noclear has been renamed to orx-no-clear 2020-03-02 08:29:03 +01:00
Edwin Jakobs
998a5051c1 Update build.gradle.kts 2020-03-01 15:21:13 +01:00
Edwin Jakobs
97c55825e2 Upgrade to OPENRNDR 0.3.39 2020-02-14 15:48:06 +01:00
Edwin Jakobs
15c188aee0 Fix for aarch64 architecture 2020-01-29 14:07:47 +01:00
Edwin Jakobs
6c3d1319cb Update README.md 2020-01-29 12:44:43 +01:00
Edwin Jakobs
ede734d74c Add support for cross building and support for future linux-arm64 version 2020-01-29 12:43:32 +01:00
Edwin Jakobs
89fce80aff Upgrade to OPENRNDR 0.3.38, add TemplateLiveProgram.kt 2020-01-28 00:12:33 +01:00
Edwin Jakobs
0a478a98a6 Fix orx-kinect-v1 native dependencies 2020-01-13 21:00:56 +01:00
Edwin Jakobs
b994ccfd28 Update README.md 2020-01-13 20:17:02 +01:00
edwin
79d9a7971a Bump OPENRNDR, ORX, Panel, Gradle 2019-12-16 18:48:34 +01:00
Edwin Jakobs
d99af16ab8 Bump to ORX 0.3.42 2019-11-29 13:52:05 +01:00
Edwin Jakobs
b781680fb6 Bump to ORX 0.3.41 2019-11-28 16:36:13 +01:00
edwin
e2108f86e5 Bump to OPENRNDR 0.3.36, ORX 0.3.40, Panel 0.3.18 2019-11-25 19:41:26 +01:00
11 changed files with 339 additions and 92 deletions

15
.github/workflows/build-on-commit.yaml vendored Normal file
View File

@@ -0,0 +1,15 @@
name: Build on commit
on:
push:
branches:
- master
jobs:
build:
runs-on: ubuntu-18.04
steps:
- uses: actions/checkout@v2
- uses: actions/setup-java@v1
with:
java-version: 14
- name: Build sources
run: ./gradlew build

View File

@@ -0,0 +1,30 @@
name: Publish Linux/x64 binaries
on:
push:
tags:
- v0.*
- v0.*.*
- v1.*
- v1.*.*
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Set up JDK 14
uses: actions/setup-java@v1
with:
java-version: 14
- name: Build with Gradle
run: ./gradlew jpackageZip
- name: Create Release
uses: ncipollo/release-action@v1.6.1
id: create_release
with:
token: ${{ secrets.GITHUB_TOKEN }}
allowUpdates: true
replaceArtifacts: false
body: Fully automated release
artifacts: "./build/distributions/openrndr-application-linux-x64.zip"

View File

@@ -0,0 +1,30 @@
name: Publish macOS binaries
on:
push:
tags:
- v0.*
- v0.*.*
- v1.*
- v1.*.*
jobs:
build:
runs-on: macos-latest
steps:
- uses: actions/checkout@v2
- name: Set up JDK 14
uses: actions/setup-java@v1
with:
java-version: 14
- name: Build with Gradle
run: ./gradlew jpackageZip
- name: Create Release
uses: ncipollo/release-action@v1.6.1
id: create_release
with:
token: ${{ secrets.GITHUB_TOKEN }}
allowUpdates: true
replaceArtifacts: false
body: Fully automated release
artifacts: "./build/distributions/openrndr-application-macos.zip"

View File

@@ -0,0 +1,30 @@
name: Publish Windows binaries
on:
push:
tags:
- v0.*
- v0.*.*
- v1.*
- v1.*.*
-
jobs:
build:
runs-on: windows-latest
steps:
- uses: actions/checkout@v2
- name: Set up JDK 14
uses: actions/setup-java@v1
with:
java-version: 14
- name: Build with Gradle
run: ./gradlew jpackageZip
- name: Create Release
uses: ncipollo/release-action@v1.6.1
id: create_release
with:
token: ${{ secrets.GITHUB_TOKEN }}
allowUpdates: true
replaceArtifacts: false
body: Fully automated release
artifacts: "./build/distributions/openrndr-application-windows.zip"

View File

@@ -1,12 +1,24 @@
# openrndr-template # OPENRNDR template project
A feature rich template for creating OPENRNDR programs based on Gradle/Kts A feature rich template for creating OPENRNDR programs based on Gradle/Kts
You will find some [basic instructions](https://guide.openrndr.org/#/02_Getting_Started_with_OPENRNDR/C00_SetupYourFirstProgram) in the [OPENRNDR guide](https://guide.openrndr.org)
The template consists of a configuration for Gradle and an example OPENRNDR program. The Gradle configuration should serve as the The template consists of a configuration for Gradle and an example OPENRNDR program. The Gradle configuration should serve as the
go-to starting point for writing OPENRNDR-based software. 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`
You will find some [basic instructions](https://guide.openrndr.org/#/02_Getting_Started_with_OPENRNDR/C00_SetupYourFirstProgram) in the [OPENRNDR guide](https://guide.openrndr.org)
## Gradle tasks ## Gradle tasks
- `run` runs the TemplateProgram - `run` runs the TemplateProgram
- `jar` creates an executable platform specific jar file with all dependencies - `jar` creates an executable platform specific jar file with all dependencies
- `zipDistribution` creates a zip file containing the application jar and the data folder - `zipDistribution` creates a zip file containing the application jar and the data folder
- `jpackageZip` creates a zip with a stand-alone executable for the current platform (works with Java 14 only)
## Cross builds
To create runnable jars for a platform different from the platform you use to build one uses `./gradlew jar --PtargetPlatform=<platform>`. The supported platforms are `windows`, `macos`, `linux-x64` and `linux-arm64`. Note that the `linux-arm64` platform will only work with OPENRNDR snapshot builds from master and OPENRNDR 0.3.39 (a future version).
## Github Actions
This repository contains a number of Github Actions in `./github/workflows`.
The actions enable a basic build run on commit, plus publication actions that are executed when
a commit is tagged with a version number like `v0.*` or `v1.*`.

View File

@@ -1,52 +1,111 @@
import com.github.jengelman.gradle.plugins.shadow.tasks.ShadowJar
import org.gradle.internal.os.OperatingSystem import org.gradle.internal.os.OperatingSystem
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile import org.jetbrains.kotlin.gradle.tasks.KotlinCompile
import org.gradle.nativeplatform.platform.internal.DefaultNativePlatform
val kotlinVersion = "1.3.50" /* the name of this project, default is the template version but you are free to change these */
plugins {
java
kotlin("jvm") version("1.3.50")
}
group = "org.openrndr.template" group = "org.openrndr.template"
version = "0.3.6" version = "0.3.13"
val applicationMainClass = "TemplateProgramKt" val applicationMainClass = "TemplateProgramKt"
/* Which additional (ORX) libraries should be added to this project. */
val orxFeatures = setOf(
// "orx-boofcv",
// "orx-camera",
// "orx-chataigne",
"orx-compositor",
// "orx-dnk3"
// "orx-easing",
// "orx-file-watcher",
// "orx-parameters",
// "orx-filter-extension",
"orx-fx",
// "orx-glslify",
// "orx-gradient-descent",
"orx-gui",
"orx-image-fit",
// "orx-integral-image",
// "orx-interval-tree",
// "orx-jumpflood",
// "orx-kdtree",
// "orx-mesh-generators",
// "orx-midi",
// "orx-no-clear",
"orx-noise",
// "orx-obj-loader",
"orx-olive",
// "orx-osc",
// "orx-palette",
// "orx-poisson-fill",
// "orx-rabbit-control
// "orx-runway",
"orx-shade-styles",
// "orx-shader-phrases",
// "orx-shapes",
// "orx-syphon",
// "orx-temporal-blur",
// "orx-time-operators,
// "orx-kinect-v1",
"orx-panel"
)
/* Which OPENRNDR libraries should be added to this project? */
val openrndrFeatures = setOf(
"video"
)
/* Which version of OPENRNDR and ORX should be used? */
val openrndrUseSnapshot = false
val openrndrVersion = if (openrndrUseSnapshot) "0.4.0-SNAPSHOT" else "0.3.43"
val orxUseSnapshot = false
val orxVersion = if (orxUseSnapshot) "0.4.0-SNAPSHOT" else "0.3.52"
//<editor-fold desc="This is code for OPENRNDR, no need to edit this .. most of the times">
val supportedPlatforms = setOf("windows", "macos", "linux-x64", "linux-arm64")
val openrndrOs = if (project.hasProperty("targetPlatform")) {
val platform : String = project.property("targetPlatform") as String
if (platform !in supportedPlatforms) {
throw IllegalArgumentException("target platform not supported: $platform")
} else {
platform
}
} else when (OperatingSystem.current()) {
OperatingSystem.WINDOWS -> "windows"
OperatingSystem.MAC_OS -> "macos"
OperatingSystem.LINUX -> when(val h = DefaultNativePlatform("current").architecture.name) {
"x86-64" -> "linux-x64"
"aarch64" -> "linux-arm64"
else ->throw IllegalArgumentException("architecture not supported: $h")
}
else -> throw IllegalArgumentException("os not supported")
}
//</editor-fold>
enum class Logging { enum class Logging {
NONE, NONE,
SIMPLE, SIMPLE,
FULL FULL
} }
val applicationLogging = Logging.SIMPLE /* What type of logging should this project use? */
val applicationLogging = Logging.FULL
val openrndrUseSnapshot = false val kotlinVersion = "1.3.72"
val openrndrVersion = if (openrndrUseSnapshot) "0.4.0-SNAPSHOT" else "0.3.35"
val openrndrOs = when (OperatingSystem.current()) { plugins {
OperatingSystem.WINDOWS -> "windows" java
OperatingSystem.MAC_OS -> "macos" kotlin("jvm") version("1.3.72")
OperatingSystem.LINUX -> "linux-x64" id("com.github.johnrengelman.shadow") version ("6.0.0")
else -> throw IllegalArgumentException("os not supported") id("org.beryx.runtime") version ("1.9.1")
} }
// supported features are: video, panel
val openrndrFeatures = setOf("video", "panel")
val panelUseSnapshot = false
val panelVersion = if (panelUseSnapshot) "0.4.0-SNAPSHOT" else "0.3.17-m3"
val orxUseSnapshot = false
val orxVersion = if (orxUseSnapshot) "0.4.0-SNAPSHOT" else "0.3.38"
// supported features are: orx-camera, orx-compositor,orx-easing, orx-filter-extension,orx-file-watcher,
// orx-integral-image, orx-interval-tree, orx-jumpflood, orx-kdtree, orx-mesh-generators,orx-midi, orx-no-clear,
// orx-noise, orx-obj, orx-olive, orx-osc
val orxFeatures = setOf("orx-noise")
repositories { repositories {
mavenCentral() mavenCentral()
if (openrndrUseSnapshot || orxUseSnapshot || panelUseSnapshot) { if (openrndrUseSnapshot || orxUseSnapshot) {
mavenLocal() mavenLocal()
} }
maven(url = "https://dl.bintray.com/openrndr/openrndr") maven(url = "https://dl.bintray.com/openrndr/openrndr")
@@ -64,54 +123,66 @@ fun DependencyHandler.openrndrNatives(module: String): Any {
return "org.openrndr:openrndr-$module-natives-$openrndrOs:$openrndrVersion" return "org.openrndr:openrndr-$module-natives-$openrndrOs:$openrndrVersion"
} }
fun DependencyHandler.orxNatives(module: String): Any {
return "org.openrndr.extra:$module-natives-$openrndrOs:$orxVersion"
}
dependencies { dependencies {
runtime(openrndr("gl3")) /* This is where you add additional (third-party) dependencies */
runtime(openrndrNatives("gl3"))
compile(openrndr("core"))
compile(openrndr("svg"))
compile(openrndr("animatable"))
compile(openrndr("extensions"))
compile(openrndr("filter"))
compile("org.jetbrains.kotlinx", "kotlinx-coroutines-core","1.3.0") // implementation("org.jsoup:jsoup:1.12.2")
// implementation("com.google.code.gson:gson:2.8.6")
compile("io.github.microutils", "kotlin-logging","1.7.6") runtimeOnly(openrndr("gl3"))
runtimeOnly(openrndrNatives("gl3"))
implementation(openrndr("openal"))
runtimeOnly(openrndrNatives("openal"))
implementation(openrndr("core"))
implementation(openrndr("svg"))
implementation(openrndr("animatable"))
implementation(openrndr("extensions"))
implementation(openrndr("filter"))
implementation("org.jetbrains.kotlinx", "kotlinx-coroutines-core","1.3.7")
implementation("io.github.microutils", "kotlin-logging","1.7.10")
when(applicationLogging) { when(applicationLogging) {
Logging.NONE -> { Logging.NONE -> {
runtime("org.slf4j","slf4j-nop","1.7.29") runtimeOnly("org.slf4j","slf4j-nop","1.7.30")
} }
Logging.SIMPLE -> { Logging.SIMPLE -> {
runtime("org.slf4j","slf4j-simple","1.7.29") runtimeOnly("org.slf4j","slf4j-simple","1.7.30")
} }
Logging.FULL -> { Logging.FULL -> {
runtime("org.apache.logging.log4j", "log4j-slf4j-impl", "2.12.1") runtimeOnly("org.apache.logging.log4j", "log4j-slf4j-impl", "2.13.3")
runtime("com.fasterxml.jackson.core", "jackson-databind", "2.8.7") runtimeOnly("com.fasterxml.jackson.core", "jackson-databind", "2.11.1")
runtime("com.fasterxml.jackson.dataformat", "jackson-dataformat-yaml", "2.8.7") runtimeOnly("com.fasterxml.jackson.dataformat", "jackson-dataformat-yaml", "2.11.1")
} }
} }
if ("video" in openrndrFeatures) { if ("video" in openrndrFeatures) {
compile(openrndr("ffmpeg")) implementation(openrndr("ffmpeg"))
runtime(openrndrNatives("ffmpeg")) runtimeOnly(openrndrNatives("ffmpeg"))
}
if ("panel" in openrndrFeatures) {
compile("org.openrndr.panel:openrndr-panel:$panelVersion")
} }
for (feature in orxFeatures) { for (feature in orxFeatures) {
compile(orx(feature)) implementation(orx(feature))
}
if ("orx-kinect-v1" in orxFeatures) {
runtimeOnly(orxNatives("orx-kinect-v1"))
} }
if ("orx-olive" in orxFeatures) { if ("orx-olive" in orxFeatures) {
compile("org.jetbrains.kotlin", "kotlin-scripting-compiler-embeddable") implementation("org.jetbrains.kotlin:kotlin-script-runtime:$kotlinVersion")
} }
implementation(kotlin("stdlib-jdk8")) implementation(kotlin("stdlib-jdk8"))
testCompile("junit", "junit", "4.12") testImplementation("junit", "junit", "4.12")
} }
// --------------------------------------------------------------------------------------------------------------------
configure<JavaPluginConvention> { configure<JavaPluginConvention> {
sourceCompatibility = JavaVersion.VERSION_1_8 sourceCompatibility = JavaVersion.VERSION_1_8
} }
@@ -119,28 +190,65 @@ tasks.withType<KotlinCompile> {
kotlinOptions.jvmTarget = "1.8" kotlinOptions.jvmTarget = "1.8"
} }
tasks.withType<Jar> {
project.setProperty("mainClassName", applicationMainClass)
tasks {
named<ShadowJar>("shadowJar") {
manifest { manifest {
attributes["Main-Class"] = applicationMainClass attributes["Main-Class"] = applicationMainClass
} }
doFirst { minimize {
from(configurations.compileClasspath.get().map { if (it.isDirectory) it else zipTree(it) }) exclude(dependency("org.openrndr:openrndr-gl3:.*"))
from(configurations.runtimeClasspath.get().map { if (it.isDirectory) it else zipTree(it) }) exclude(dependency("org.jetbrains.kotlin:kotlin-reflect:.*"))
}
}
named<org.beryx.runtime.JPackageTask>("jpackage") {
doLast {
when (OperatingSystem.current()) {
OperatingSystem.WINDOWS, OperatingSystem.LINUX -> {
copy {
from("data") {
include("**/*")
}
into("build/jpackage/openrndr-application/data")
}
}
OperatingSystem.MAC_OS -> {
copy {
from("data") {
include("**/*")
}
into("build/jpackage/openrndr-application.app/data")
}
}
}
}
}
} }
exclude(listOf("META-INF/*.RSA", "META-INF/*.SF", "META-INF/*.DSA", "**/module-info*")) tasks.register<Zip>("jpackageZip") {
archiveFileName.set("application-$openrndrOs.jar") archiveFileName.set("openrndr-application-$openrndrOs.zip")
from("$buildDir/jpackage") {
include("**/*")
} }
tasks.create("zipDistribution", Zip::class.java) {
archiveFileName.set("application-$openrndrOs.zip")
from("./") {
include("data/**")
} }
from("$buildDir/libs/application-$openrndrOs.jar") tasks.findByName("jpackageZip")?.dependsOn("jpackage")
}.dependsOn(tasks.jar)
tasks.create("run", JavaExec::class.java) { runtime {
main = applicationMainClass jpackage {
classpath = sourceSets.main.get().runtimeClasspath imageName = "openrndr-application"
}.dependsOn(tasks.build) skipInstaller = true
if (OperatingSystem.current() == OperatingSystem.MAC_OS) {
jvmArgs.add("-XstartOnFirstThread")
}
}
options.empty()
options.add("--strip-debug")
options.add("--compress")
options.add("1")
options.add("--no-header-files")
options.add("--no-man-pages")
modules.empty()
modules.add("jdk.unsupported")
modules.add("java.management")
}

View File

@@ -1,5 +1,5 @@
#Thu Aug 01 12:32:31 CEST 2019 #Thu Aug 01 12:32:31 CEST 2019
distributionUrl=https\://services.gradle.org/distributions/gradle-5.2.1-all.zip distributionUrl=https\://services.gradle.org/distributions/gradle-6.5.1-all.zip
distributionBase=GRADLE_USER_HOME distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists distributionPath=wrapper/dists
zipStorePath=wrapper/dists zipStorePath=wrapper/dists

View File

@@ -0,0 +1,22 @@
import org.openrndr.application
import org.openrndr.color.ColorRGBa
import org.openrndr.extra.olive.oliveProgram
/**
* This is a template for a live program.
*
* It uses oliveProgram {} instead of program {}. All code inside the
* oliveProgram {} can be changed while the program is running.
*/
fun main() = application {
configure {
width = 800
height = 800
}
oliveProgram {
extend {
drawer.clear(ColorRGBa.PINK)
}
}
}

View File

@@ -13,7 +13,6 @@ fun main() = application {
} }
program { program {
val image = loadImage("data/images/pm5544.png") val image = loadImage("data/images/pm5544.png")
val font = loadFont("data/fonts/IBMPlexMono-Regular.ttf", 64.0) val font = loadFont("data/fonts/IBMPlexMono-Regular.ttf", 64.0)

View File

@@ -2,10 +2,11 @@ Configuration:
status: warn status: warn
Appenders: Appenders:
Console: Console:
name: Console - name: Console_Info
target: SYSTEM_OUT target: SYSTEM_ERR
PatternLayout: PatternLayout:
Pattern: "%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" Pattern: "%highlight{${LOG_LEVEL_PATTERN:-%5p}}{FATAL=red, ERROR=red, WARN=yellow, INFO=green, DEBUG=green, TRACE=green} %style{[%t]}{white} %style{%-30.30c{1.}}{white} %style{ ↘ %m%n%ex}{white}"
#Pattern: "%style{%d{yyyy-MM-dd HH:mm:ss.SSS}}{white} %highlight{${LOG_LEVEL_PATTERN:-%5p}}{FATAL=red, ERROR=red, WARN=yellow, INFO=green, DEBUG=green, TRACE=green} %style{[%t]}{white} %style{%-30.30c{1.}}{cyan} %style{:%m%n%ex}{white}"
File: File:
append: false append: false
name: File_Appender name: File_Appender
@@ -14,7 +15,7 @@ Configuration:
Pattern: "%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" Pattern: "%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"
Loggers: Loggers:
Root: Root:
level: debug level: info
AppenderRef: AppenderRef:
- ref: Console - ref: Console_Info
- ref: File_Appender - ref: File_Appender