Files
orx/orx-shapes/src/jvmDemo/kotlin/blend/DemoContourBlend02.kt
2025-08-30 23:56:56 +02:00

47 lines
1.7 KiB
Kotlin

package blend
import org.openrndr.application
import org.openrndr.color.ColorRGBa
import org.openrndr.draw.isolated
import org.openrndr.extra.shapes.blend.blend
import org.openrndr.extra.shapes.primitives.grid
import org.openrndr.extra.shapes.primitives.regularStar
import org.openrndr.math.Vector2
import org.openrndr.shape.Circle
import kotlin.math.PI
import kotlin.math.cos
/**
* Demonstration of non-uniform contour blending
*
* The `mix` method of a `ContourBlend` does not only accept a Double, but also a function.
* This function should take one Double argument, which specifies the normalized `t` value between
* the start and the end of the contour, and should return a normalized value indicating the
* morphing state between the first contour and the second contour, for that specific t value.
*
* This allows us, for instance, to morph one part of the shape first, then have other parts follow.
*
* This demo shows a grid of 9 contours which are part circle and part 5-point start.
*/
fun main() = application {
configure {
width = 720
height = 720
}
program {
val a = Circle(Vector2.ZERO, 90.0).contour
val b = regularStar(5, 30.0, 90.0, center = Vector2.ZERO, phase = 180.0)
val blend = a.blend(b)
extend {
drawer.clear(ColorRGBa.WHITE)
drawer.fill = ColorRGBa.BLACK
drawer.bounds.grid(3, 3).flatten().forEachIndexed { index, it ->
drawer.isolated {
drawer.translate(it.center)
drawer.contour(blend.mix { t -> cos(t * PI * 2.0 + index * PI * 2.0 / 9.0 + seconds) * 0.5 + 0.5 })
}
}
}
}
}