[orx-jumpflood] Add DemoDirectionField01.kt and DemoDistanceField01.kt (#281)
This commit is contained in:
80
orx-jumpflood/src/demo/kotlin/DemoDirectionField01.kt
Normal file
80
orx-jumpflood/src/demo/kotlin/DemoDirectionField01.kt
Normal file
@@ -0,0 +1,80 @@
|
|||||||
|
import org.openrndr.application
|
||||||
|
import org.openrndr.color.ColorRGBa
|
||||||
|
import org.openrndr.draw.*
|
||||||
|
import org.openrndr.extra.jumpfill.DirectionalField
|
||||||
|
import org.openrndr.extra.noise.simplex
|
||||||
|
import org.openrndr.math.Vector2
|
||||||
|
import org.openrndr.math.Vector3
|
||||||
|
import org.openrndr.shape.Rectangle
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Shows how to use the [DirectionalField] filter.
|
||||||
|
* Draws moving white shapes on black background,
|
||||||
|
* then applies the DirectionalField filter which returns a [ColorBuffer] in which
|
||||||
|
* the red and green components encode the direction to the closest black/white edge.
|
||||||
|
*
|
||||||
|
* Hold down a mouse button to see the raw animation.
|
||||||
|
*/
|
||||||
|
fun main() = application {
|
||||||
|
configure {
|
||||||
|
width = 1024
|
||||||
|
height = 1024
|
||||||
|
}
|
||||||
|
|
||||||
|
program {
|
||||||
|
val rt = renderTarget(width, height) { colorBuffer() }
|
||||||
|
val directionalField = DirectionalField().also {
|
||||||
|
it.distanceScale = 0.004
|
||||||
|
}
|
||||||
|
|
||||||
|
// Needs to be FLOAT32 so we can have negative values
|
||||||
|
val result = colorBuffer(width, height, type = ColorType.FLOAT32)
|
||||||
|
val shader = shadeStyle {
|
||||||
|
fragmentTransform = """
|
||||||
|
x_fill.rgb = vec3(x_fill.rg + 0.5, x_fill.b);
|
||||||
|
|
||||||
|
// interesting when distanceScale = 1.0
|
||||||
|
//x_fill.rgb = vec3(1.0 / (x_fill.r + x_fill.g));
|
||||||
|
"""
|
||||||
|
}
|
||||||
|
|
||||||
|
extend {
|
||||||
|
// Draw moving white shapes on a black background
|
||||||
|
drawer.isolatedWithTarget(rt) {
|
||||||
|
clear(ColorRGBa.BLACK)
|
||||||
|
stroke = null
|
||||||
|
fill = ColorRGBa.WHITE
|
||||||
|
repeat(10) {
|
||||||
|
val pos = Vector2.simplex(it, seconds * 0.2) *
|
||||||
|
bounds.center + bounds.center
|
||||||
|
val size = (it * it + 5.0) * 2.0
|
||||||
|
|
||||||
|
isolated {
|
||||||
|
translate(pos)
|
||||||
|
if (it % 2 == 0) {
|
||||||
|
circle(Vector2.ZERO, size)
|
||||||
|
} else {
|
||||||
|
rotate(Vector3.UNIT_Z, pos.x)
|
||||||
|
rectangle(
|
||||||
|
Rectangle.fromCenter(
|
||||||
|
Vector2.ZERO, size, size * 2
|
||||||
|
)
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
directionalField.apply(rt.colorBuffer(0), result)
|
||||||
|
|
||||||
|
drawer.isolated {
|
||||||
|
if (mouse.pressedButtons.isEmpty()) {
|
||||||
|
shadeStyle = shader
|
||||||
|
image(result)
|
||||||
|
} else {
|
||||||
|
image(rt.colorBuffer(0))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
85
orx-jumpflood/src/demo/kotlin/DemoDistanceField01.kt
Normal file
85
orx-jumpflood/src/demo/kotlin/DemoDistanceField01.kt
Normal file
@@ -0,0 +1,85 @@
|
|||||||
|
import org.openrndr.application
|
||||||
|
import org.openrndr.color.ColorRGBa
|
||||||
|
import org.openrndr.draw.*
|
||||||
|
import org.openrndr.extra.jumpfill.DistanceField
|
||||||
|
import org.openrndr.extra.noise.simplex
|
||||||
|
import org.openrndr.math.Vector2
|
||||||
|
import org.openrndr.math.Vector3
|
||||||
|
import org.openrndr.shape.Rectangle
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Shows how to use the [DistanceField] filter.
|
||||||
|
* Draws moving white shapes on black background,
|
||||||
|
* then applies the DistanceField filter which returns a [ColorBuffer] in which
|
||||||
|
* the red component encodes the distance to the closest black/white edge.
|
||||||
|
* The value is positive when on the black background and negative
|
||||||
|
* when inside white shapes. The sign is used in the [shadeStyle] to choose
|
||||||
|
* between two colors. The inverse of the distance is used to obtain a
|
||||||
|
* non-linear brightness.
|
||||||
|
* Hold down a mouse button to see the raw animation.
|
||||||
|
*/
|
||||||
|
fun main() = application {
|
||||||
|
configure {
|
||||||
|
width = 1024
|
||||||
|
height = 1024
|
||||||
|
}
|
||||||
|
|
||||||
|
program {
|
||||||
|
val rt = renderTarget(width, height) { colorBuffer() }
|
||||||
|
val distanceField = DistanceField()
|
||||||
|
|
||||||
|
// Needs to be FLOAT32 so we can have negative values
|
||||||
|
val result = colorBuffer(width, height, type = ColorType.FLOAT32)
|
||||||
|
val shader = shadeStyle {
|
||||||
|
fragmentTransform = """
|
||||||
|
float distance = abs(x_fill.r);
|
||||||
|
float bri = 1.0 / (1.0 + 0.03 * distance);
|
||||||
|
|
||||||
|
// wavy effect
|
||||||
|
// bri *= (1.0 + 0.2 * sin(distance * 0.2));
|
||||||
|
|
||||||
|
x_fill.rgb = bri * (x_fill.r > 0 ?
|
||||||
|
vec3(1.0, 0.0, 0.0) : vec3(0.0, 1.0, 1.0));
|
||||||
|
"""
|
||||||
|
}
|
||||||
|
|
||||||
|
extend {
|
||||||
|
// Draw moving white shapes on a black background
|
||||||
|
drawer.isolatedWithTarget(rt) {
|
||||||
|
clear(ColorRGBa.BLACK)
|
||||||
|
stroke = null
|
||||||
|
fill = ColorRGBa.WHITE
|
||||||
|
repeat(10) {
|
||||||
|
val pos = Vector2.simplex(it, seconds * 0.2) *
|
||||||
|
bounds.center + bounds.center
|
||||||
|
val size = (it * it + 5.0) * 2.0
|
||||||
|
|
||||||
|
isolated {
|
||||||
|
translate(pos)
|
||||||
|
if (it % 2 == 0) {
|
||||||
|
circle(Vector2.ZERO, size)
|
||||||
|
} else {
|
||||||
|
rotate(Vector3.UNIT_Z, pos.x)
|
||||||
|
rectangle(
|
||||||
|
Rectangle.fromCenter(
|
||||||
|
Vector2.ZERO, size, size * 2
|
||||||
|
)
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
distanceField.apply(rt.colorBuffer(0), result)
|
||||||
|
|
||||||
|
drawer.isolated {
|
||||||
|
if (mouse.pressedButtons.isEmpty()) {
|
||||||
|
shadeStyle = shader
|
||||||
|
image(result)
|
||||||
|
} else {
|
||||||
|
image(rt.colorBuffer(0))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user