import io.data2viz.color.*
import io.data2viz.geom.*
import io.data2viz.math.*
import io.data2viz.viz.*
import io.data2viz.random.*
import kotlin.math.sin
import kotlin.math.cos
private val vizSize = 600.0
private val circles = 1000
private val randomPosition = RandomDistribution.uniform(.0, vizSize)
private val randomSpeed = RandomDistribution.uniform(-2.0, 2.0)
private val positions = (0 .. circles).map { Point(randomPosition(), randomPosition()) }.toMutableList()
private val speeds = (0 .. circles).map { Point(randomSpeed(), randomSpeed()) }.toMutableList()
private fun updatePositions() = positions.forEachIndexed { index, position ->
val newPos = position + speeds[index]
positions[index] = newPos
if (newPos.x < .0 || newPos.x > vizSize) {
speeds[index] = Point(-speeds[index].x, speeds[index].y)
}
if (newPos.y < .0 || newPos.y > vizSize) {
speeds[index] = Point(speeds[index].x, -speeds[index].y)
}
}
fun main() {
viz {
size = size(vizSize, vizSize)
val elements = positions.map { position ->
circle {
x = position.x
y = position.y
radius = 5.0
fill = Colors.Web.red
}
}
animation {
updatePositions()
elements.forEachIndexed { index, element ->
element.x = positions[index].x
element.y = positions[index].y
}
}
}.bindRendererOnNewCanvas()
}