Update Circle.kt

This commit is contained in:
bluefireoly
2020-09-15 18:30:36 +02:00
parent 16a27d0aa0
commit dde601a790

View File

@@ -8,16 +8,9 @@ import net.axay.kspigot.particles.KSpigotParticle
import org.bukkit.Material
import org.bukkit.entity.EntityType
abstract class Circle(val radius: Number) {
private fun circleEdgeLocations(radius: Number) = HashSet<SimpleLocation2D>().apply {
abstract val data: StructureData
val fillLocations: Set<SimpleLocation2D> by lazy {
val locationList: MutableSet<SimpleLocation2D> = HashSet()
var currentRadius = radius.toDouble()
while (currentRadius >= 0) {
val currentRadius = radius.toDouble()
var d = -currentRadius
var x = currentRadius
@@ -25,14 +18,14 @@ abstract class Circle(val radius: Number) {
while (y <= x) {
locationList.addCircleLoc(x, y)
locationList.addCircleLoc(x, -y)
locationList.addCircleLoc(-x, y)
locationList.addCircleLoc(-x, -y)
locationList.addCircleLoc(y, x)
locationList.addCircleLoc(y, -x)
locationList.addCircleLoc(-y, x)
locationList.addCircleLoc(-y, -x)
addSimpleLoc2D(x, y)
addSimpleLoc2D(x, -y)
addSimpleLoc2D(-x, y)
addSimpleLoc2D(-x, -y)
addSimpleLoc2D(y, x)
addSimpleLoc2D(y, -x)
addSimpleLoc2D(-y, x)
addSimpleLoc2D(-y, -x)
d += 2 * y + 1
y++
@@ -44,26 +37,44 @@ abstract class Circle(val radius: Number) {
}
currentRadius--
}
}
return@lazy locationList
}
private fun MutableSet<SimpleLocation2D>.addCircleLoc(first: Number, second: Number) {
private fun MutableSet<SimpleLocation2D>.addSimpleLoc2D(first: Number, second: Number) {
this += SimpleLocation2D(first, second)
}
abstract class Circle(val radius: Number) {
protected abstract val data: StructureData
val fillLocations by lazy {
var currentRadius = radius.toDouble()
HashSet<SimpleLocation2D>().apply {
while (currentRadius >= 0) {
this += circleEdgeLocations(currentRadius)
currentRadius -= 0.5
}
}
val structure by lazy {
Structure(
}
val edgeLocations by lazy {
circleEdgeLocations(radius)
}
val filledStructure by lazy { structure(true) }
val edgeStructure by lazy { structure(false) }
fun structure(filled: Boolean) = Structure(
HashSet<SingleStructureData>().apply {
for (it in fillLocations)
val locations = if (filled) fillLocations else edgeLocations
for (it in locations)
this += SingleStructureData(SimpleLocation3D(it.x, 0, it.y), data)
}
)
}
}