Fixes and move to jvmDemo (#286)
This commit is contained in:
86
orx-shade-styles/src/jvmDemo/kotlin/DemoAllGradients01.kt
Normal file
86
orx-shade-styles/src/jvmDemo/kotlin/DemoAllGradients01.kt
Normal file
@@ -0,0 +1,86 @@
|
||||
import org.openrndr.application
|
||||
import org.openrndr.color.ColorRGBa
|
||||
import org.openrndr.draw.isolated
|
||||
import org.openrndr.extensions.SingleScreenshot
|
||||
import org.openrndr.extra.shadestyles.*
|
||||
import org.openrndr.math.Polar
|
||||
import org.openrndr.shape.Rectangle
|
||||
|
||||
/**
|
||||
* Example of 5 gradient styles.
|
||||
* NPointLinear and NPoingGradient have separate demos.
|
||||
*/
|
||||
fun main() {
|
||||
application {
|
||||
configure {
|
||||
width = 1000
|
||||
height = 500
|
||||
}
|
||||
program {
|
||||
// Create gradients with initial colors
|
||||
val gradients = listOf(
|
||||
RadialGradient(ColorRGBa.PINK, ColorRGBa.WHITE),
|
||||
AngularGradient(ColorRGBa.PINK, ColorRGBa.WHITE),
|
||||
NPointGradient(Array(4) {
|
||||
ColorRGBa.PINK.shade(it / 3.0)
|
||||
}),
|
||||
LinearGradient(ColorRGBa.PINK, ColorRGBa.WHITE),
|
||||
HalfAngularGradient(ColorRGBa.PINK, ColorRGBa.WHITE)
|
||||
)
|
||||
|
||||
extend {
|
||||
gradients.forEachIndexed { gradientId, gradient ->
|
||||
for (column in 0 until 10) {
|
||||
val color1 = ColorRGBa.PINK.toHSVa().shiftHue(column * 12.0)
|
||||
.shade(0.5).toRGBa()
|
||||
|
||||
val w = width.toDouble() / 10.0
|
||||
val h = height.toDouble() / gradients.size
|
||||
val rect = Rectangle(column * w, gradientId * h, w, h)
|
||||
|
||||
val offset = Polar((seconds + column) * 15.0, 0.3).cartesian
|
||||
|
||||
drawer.isolated {
|
||||
when (gradient) {
|
||||
is RadialGradient -> {
|
||||
gradient.color1 = color1
|
||||
gradient.exponent = column / 3.0 + 0.3
|
||||
gradient.length = 0.6
|
||||
gradient.offset = offset
|
||||
}
|
||||
is AngularGradient -> {
|
||||
gradient.color1 = color1
|
||||
gradient.exponent = column / 3.0 + 0.3
|
||||
gradient.rotation = (seconds - column) * 10.0
|
||||
gradient.offset = offset
|
||||
}
|
||||
is LinearGradient -> {
|
||||
gradient.color1 = color1
|
||||
gradient.exponent = column / 3.0 + 0.3
|
||||
gradient.rotation = seconds * 10.0
|
||||
}
|
||||
is HalfAngularGradient -> {
|
||||
gradient.color1 = color1
|
||||
gradient.exponent = column / 3.0 + 0.3
|
||||
gradient.rotation = (column - seconds) * 10.0
|
||||
gradient.offset = offset
|
||||
}
|
||||
is NPointGradient -> {
|
||||
// Animate points.
|
||||
// We could also animate colors.
|
||||
gradient.points = Array(gradient.colors.size) {
|
||||
rect.center + Polar(it * 90.0 +
|
||||
column * 36 - seconds * 10,
|
||||
40.0).cartesian
|
||||
}
|
||||
}
|
||||
}
|
||||
shadeStyle = gradient
|
||||
rectangle(rect)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
23
orx-shade-styles/src/jvmDemo/kotlin/DemoImageFit01.kt
Normal file
23
orx-shade-styles/src/jvmDemo/kotlin/DemoImageFit01.kt
Normal file
@@ -0,0 +1,23 @@
|
||||
import org.openrndr.application
|
||||
import org.openrndr.color.ColorRGBa
|
||||
import org.openrndr.draw.loadImage
|
||||
import org.openrndr.extra.shadestyles.imageFit
|
||||
import org.openrndr.extra.shadestyles.linearGradient
|
||||
import org.openrndr.math.Vector2
|
||||
import org.openrndr.shape.Circle
|
||||
import kotlin.math.cos
|
||||
import kotlin.math.sin
|
||||
|
||||
fun main() = application {
|
||||
program {
|
||||
val image = loadImage("demo-data/images/image-001.png")
|
||||
extend {
|
||||
drawer.shadeStyle = imageFit(image, Vector2(cos(seconds), sin(seconds))) + linearGradient(ColorRGBa.RED, ColorRGBa.BLUE)
|
||||
drawer.circle(drawer.bounds.center, 200.0)
|
||||
drawer.rectangle(10.0, 10.0, 400.0, 50.0)
|
||||
drawer.rectangle(10.0, 10.0, 50.0, 400.0)
|
||||
drawer.contour(Circle(width/2.0, height/2.0, 50.0).contour)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
25
orx-shade-styles/src/jvmDemo/kotlin/DemoLinearGradient.kt
Normal file
25
orx-shade-styles/src/jvmDemo/kotlin/DemoLinearGradient.kt
Normal file
@@ -0,0 +1,25 @@
|
||||
import org.openrndr.application
|
||||
import org.openrndr.color.ColorRGBa
|
||||
import org.openrndr.extra.color.spaces.toOKLABa
|
||||
import org.openrndr.extra.shadestyles.linearGradient
|
||||
|
||||
fun main() {
|
||||
application {
|
||||
program {
|
||||
extend {
|
||||
drawer.shadeStyle = linearGradient(
|
||||
ColorRGBa.RED.toOKLABa(),
|
||||
ColorRGBa.BLUE.toOKLABa(),
|
||||
)
|
||||
drawer.rectangle(120.0, 40.0, 200.0, 400.0)
|
||||
|
||||
drawer.shadeStyle = linearGradient(
|
||||
ColorRGBa.RED,
|
||||
ColorRGBa.BLUE
|
||||
)
|
||||
|
||||
drawer.rectangle(120.0+200.0, 40.0, 200.0, 400.0)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
47
orx-shade-styles/src/jvmDemo/kotlin/DemoNPointGradient01.kt
Normal file
47
orx-shade-styles/src/jvmDemo/kotlin/DemoNPointGradient01.kt
Normal file
@@ -0,0 +1,47 @@
|
||||
import org.openrndr.application
|
||||
import org.openrndr.color.ColorRGBa
|
||||
import org.openrndr.color.ColorXSVa
|
||||
import org.openrndr.extensions.SingleScreenshot
|
||||
import org.openrndr.extra.shadestyles.NPointGradient
|
||||
import org.openrndr.math.Polar
|
||||
import org.openrndr.shape.ShapeContour
|
||||
import kotlin.math.PI
|
||||
import kotlin.math.cos
|
||||
|
||||
/**
|
||||
* Demonstrate using an n-point gradient.
|
||||
* The gradient has 8 points in screen coordinates and 8 colors.
|
||||
* The colors are fixed, the points of the gradient move.
|
||||
* A contour is drawn using the same points from the gradient,
|
||||
* but note that this is not necessary: you can animate the gradient
|
||||
* on a static shape (a circle for example) or you can animate a shape
|
||||
* with a static gradient.
|
||||
*/
|
||||
fun main() {
|
||||
application {
|
||||
program {
|
||||
val numPoints = 8
|
||||
val gradient = NPointGradient(Array(numPoints) {
|
||||
ColorXSVa(it * 360.0 / numPoints, 1.0, 1.0).toRGBa()
|
||||
})
|
||||
|
||||
extend {
|
||||
drawer.run {
|
||||
clear(ColorRGBa.WHITE.shade(0.9))
|
||||
val t = PI * 2 * (frameCount % 300) / 300.0
|
||||
val points = Array(numPoints) {
|
||||
val lfo = cos(it * PI / 2 - t)
|
||||
val theta = it * 360.0 / numPoints - 22.5 * lfo
|
||||
val radius = 200 + 170 * lfo
|
||||
bounds.center + Polar(theta, radius).cartesian
|
||||
}
|
||||
gradient.points = points
|
||||
shadeStyle = gradient
|
||||
stroke = ColorRGBa.WHITE
|
||||
strokeWeight = 4.0
|
||||
contour(ShapeContour.fromPoints(points.asList(), true))
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,66 @@
|
||||
import org.openrndr.application
|
||||
import org.openrndr.color.ColorXSVa
|
||||
import org.openrndr.color.rgb
|
||||
import org.openrndr.extra.color.spaces.toOKLABa
|
||||
import org.openrndr.extra.shadestyles.NPointLinearGradient
|
||||
import org.openrndr.extra.shadestyles.NPointLinearGradientOKLab
|
||||
import org.openrndr.shape.Rectangle
|
||||
import kotlin.math.pow
|
||||
import kotlin.math.sin
|
||||
|
||||
/**
|
||||
* Demonstrate using a multicolor linear gradient.
|
||||
* The gradient has 8 static saturated colors.
|
||||
* The positions of the colors are first distributed
|
||||
* uniformly between 0.0 and 1.0 and then animated towards one of
|
||||
* the ends over time using pow() and sin(seconds).
|
||||
*/
|
||||
fun main() {
|
||||
application {
|
||||
program {
|
||||
val numPoints = 8
|
||||
// Create gradients using two different color spaces
|
||||
val gradients = listOf(
|
||||
NPointLinearGradient(Array(numPoints) {
|
||||
ColorXSVa(it * 360.0 / numPoints, 1.0, 1.0).toRGBa()
|
||||
}),
|
||||
// OKLab is better at maintaining luminosity across the gradient
|
||||
NPointLinearGradientOKLab(Array(numPoints) {
|
||||
ColorXSVa(it * 360.0 / numPoints, 1.0, 1.0).toRGBa()
|
||||
.toOKLABa()
|
||||
})
|
||||
)
|
||||
|
||||
extend {
|
||||
// The points should be sorted values between 0.0 and 1.0
|
||||
val distribution = Array(numPoints) {
|
||||
// uniform distribution
|
||||
// (it / (numPoints - 1.0))
|
||||
|
||||
// skewed and animated distribution
|
||||
(it / (numPoints - 1.0)).pow(1.0 + 0.5 * sin(seconds))
|
||||
}
|
||||
drawer.run {
|
||||
clear(rgb(0.2))
|
||||
stroke = rgb(0.35)
|
||||
strokeWeight = 8.0
|
||||
|
||||
gradients.forEachIndexed { i, gradient ->
|
||||
shadeStyle = gradient
|
||||
gradient.points = distribution
|
||||
|
||||
gradient.rotation = seconds * 10
|
||||
circle(bounds.position(0.34, 0.29 + 0.44 * i), 110.0)
|
||||
|
||||
gradient.rotation += 90
|
||||
rectangle(
|
||||
Rectangle.fromCenter(
|
||||
bounds.position(0.655, 0.29 + 0.44 * i), 200.0
|
||||
)
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,41 @@
|
||||
import org.openrndr.application
|
||||
import org.openrndr.color.ColorRGBa
|
||||
import org.openrndr.color.rgb
|
||||
import org.openrndr.extensions.SingleScreenshot
|
||||
import org.openrndr.extra.shadestyles.NPointRadialGradient
|
||||
import org.openrndr.shape.Circle
|
||||
import kotlin.random.Random
|
||||
|
||||
/**
|
||||
* Demonstrate using a multi color radial gradient.
|
||||
* The gradient has 5 colors (first and last ones are transparent).
|
||||
* Any of the properties can be animated, including colors and points.
|
||||
* See DemoNPointLinearGradient01.kt for an example of animated properties.
|
||||
*/
|
||||
fun main() {
|
||||
application {
|
||||
program {
|
||||
val gradient = NPointRadialGradient(arrayOf(
|
||||
ColorRGBa.PINK.opacify(0.0),
|
||||
ColorRGBa.PINK, ColorRGBa.WHITE, ColorRGBa.PINK,
|
||||
ColorRGBa.PINK.opacify(0.0)
|
||||
), arrayOf(0.0, 0.4, 0.5, 0.6, 1.0))
|
||||
|
||||
val circles = List(25) {
|
||||
Circle(Random.nextDouble() * drawer.width,
|
||||
Random.nextDouble() * drawer.height,
|
||||
Random.nextDouble() * 150.0)
|
||||
}
|
||||
|
||||
extend {
|
||||
drawer.run {
|
||||
clear(rgb(0.2))
|
||||
shadeStyle = gradient
|
||||
fill = ColorRGBa.WHITE
|
||||
stroke = null
|
||||
circles(circles)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
21
orx-shade-styles/src/jvmDemo/kotlin/DemoRadialGradient01.kt
Normal file
21
orx-shade-styles/src/jvmDemo/kotlin/DemoRadialGradient01.kt
Normal file
@@ -0,0 +1,21 @@
|
||||
import org.openrndr.application
|
||||
import org.openrndr.color.ColorRGBa
|
||||
import org.openrndr.extensions.SingleScreenshot
|
||||
|
||||
import org.openrndr.extra.shadestyles.radialGradient
|
||||
import kotlin.math.cos
|
||||
|
||||
fun main() {
|
||||
application {
|
||||
program {
|
||||
extend {
|
||||
drawer.shadeStyle = radialGradient(
|
||||
ColorRGBa.PINK,
|
||||
ColorRGBa.PINK.toHSVa().shiftHue(180.0).shade(0.5).toRGBa(),
|
||||
exponent = cos(seconds)*0.5+0.5
|
||||
)
|
||||
drawer.rectangle(120.0, 40.0, 400.0, 400.0)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user