47 lines
1.7 KiB
Kotlin
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 })
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|