Merge pull request #3 from CodeCox/feature-noclear-backdrop
NoClear() extension : provide a custom backdrop
This commit is contained in:
@@ -5,17 +5,50 @@ OPENRNDR does not support natively.
|
|||||||
|
|
||||||
#### Usage
|
#### Usage
|
||||||
|
|
||||||
```
|
```kotlin
|
||||||
class NoClearProgram: Program() {
|
fun main() = application {
|
||||||
|
configure {
|
||||||
override fun setup() {
|
title = "NoClearProgram"
|
||||||
|
}
|
||||||
|
program {
|
||||||
backgroundColor = ColorRGBa.PINK
|
backgroundColor = ColorRGBa.PINK
|
||||||
extend(NoClear())
|
extend(NoClear())
|
||||||
}
|
extend {
|
||||||
|
drawer.circle(Math.cos(seconds) * width / 2.0 + width / 2.0, Math.sin(seconds * 0.24) * height / 2.0 + height / 2.0, 20.0)
|
||||||
override fun draw() {
|
}
|
||||||
drawer.circle(Math.cos(seconds) * width / 2.0 + width / 2.0, Math.sin(seconds * 0.24) * height / 2.0 + height / 2.0, 20.0)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
|
#### Usage with additional configuration
|
||||||
|
Optionally, a static `backdrop` may be setup by providing custom code.
|
||||||
|
|
||||||
|
- Example 1. Customising the backdrop with an image
|
||||||
|
```kotlin
|
||||||
|
extend(NoClear()) {
|
||||||
|
val img = loadImage("data\\backdrop.png")
|
||||||
|
backdrop = {
|
||||||
|
drawer.image(img, 0.0, 0.0, width * 1.0, height * 1.0)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
- Example 2. Customising the backdrop with a checker-board pattern
|
||||||
|
```kotlin
|
||||||
|
extend(NoClear()) {
|
||||||
|
backdrop = {
|
||||||
|
val xw = width / 8.0
|
||||||
|
val yh = height / 8.0
|
||||||
|
drawer.fill = ColorRGBa.RED
|
||||||
|
(0..7).forEach { row ->
|
||||||
|
(0..7).forEach { col ->
|
||||||
|
if ((row + col) % 2 == 0) {
|
||||||
|
drawer.rectangle(row * xw, col * yh, xw, yh)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
NB! any submitted _lambda expression_ must be valid within the `renderTarget` context.
|
||||||
@@ -13,6 +13,10 @@ class NoClear : Extension {
|
|||||||
override var enabled: Boolean = true
|
override var enabled: Boolean = true
|
||||||
private var renderTarget: RenderTarget? = null
|
private var renderTarget: RenderTarget? = null
|
||||||
|
|
||||||
|
/**
|
||||||
|
* code-block to draw an optional custom backdrop
|
||||||
|
*/
|
||||||
|
var backdrop: (() -> Unit)? = null
|
||||||
|
|
||||||
override fun beforeDraw(drawer: Drawer, program: Program) {
|
override fun beforeDraw(drawer: Drawer, program: Program) {
|
||||||
if (program.width > 0 && program.height > 0) { // only if the window is not minimised
|
if (program.width > 0 && program.height > 0) { // only if the window is not minimised
|
||||||
@@ -30,6 +34,7 @@ class NoClear : Extension {
|
|||||||
renderTarget?.let {
|
renderTarget?.let {
|
||||||
drawer.withTarget(it) {
|
drawer.withTarget(it) {
|
||||||
background(program.backgroundColor ?: ColorRGBa.TRANSPARENT)
|
background(program.backgroundColor ?: ColorRGBa.TRANSPARENT)
|
||||||
|
backdrop?.invoke() // draw custom backdrop
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user