From: Irtimaled Date: Thu, 25 Jun 2020 07:46:01 +0000 (-0700) Subject: Tidy up overcrowding with spheres X-Git-Url: https://git.lizzy.rs/?a=commitdiff_plain;h=45f06c67bf9ee786a6098bf55c4f7bd7c2d3f2a5;p=BoundingBoxOutlineReloaded.git Tidy up overcrowding with spheres --- diff --git a/src/main/java/com/irtimaled/bbor/client/renderers/AbstractRenderer.java b/src/main/java/com/irtimaled/bbor/client/renderers/AbstractRenderer.java index 64f8fc7..de22773 100644 --- a/src/main/java/com/irtimaled/bbor/client/renderers/AbstractRenderer.java +++ b/src/main/java/com/irtimaled/bbor/client/renderers/AbstractRenderer.java @@ -2,6 +2,7 @@ package com.irtimaled.bbor.client.renderers; import com.irtimaled.bbor.client.config.ConfigManager; import com.irtimaled.bbor.client.models.Point; +import com.irtimaled.bbor.common.MathHelper; import com.irtimaled.bbor.common.models.AbstractBoundingBox; import net.minecraft.client.Minecraft; import net.minecraft.client.gui.FontRenderer; @@ -11,7 +12,9 @@ import java.util.function.Supplier; public abstract class AbstractRenderer { private static final double TAU = 6.283185307179586D; + public static final double PHI_SEGMENT = TAU / 90D; private static final double PI = TAU / 2D; + public static final double THETA_SEGMENT = PHI_SEGMENT / 2D; public abstract void render(T boundingBox); @@ -138,7 +141,8 @@ public abstract class AbstractRenderer { RenderHelper.lineWidth2(); double offset = ((radius - (int) radius) == 0) ? center.getY() - (int) center.getY() : 0; - for (double dy = offset - radius; dy <= radius + 1; dy++) { + int dyStep = radius < 64 ? 1 : MathHelper.floor(radius / 32); + for (double dy = offset - radius; dy <= radius + 1; dy += dyStep) { double circleRadius = Math.sqrt((radius * radius) - (dy * dy)); if (circleRadius == 0) circleRadius = Math.sqrt(2) / 2; renderCircle(center, circleRadius, color, dy + 0.001F); @@ -149,9 +153,8 @@ public abstract class AbstractRenderer { Renderer renderer = Renderer.startLineLoop() .setColor(color); - for (int a = 0; a < 360; a += 5) { - double heading = a * PI / 180; - renderer.addPoint(new OffsetPoint(center.offset(Math.cos(heading) * radius, dy, Math.sin(heading) * radius))); + for (double phi = 0.0D; phi < TAU; phi += PHI_SEGMENT) { + renderer.addPoint(new OffsetPoint(center.offset(Math.cos(phi) * radius, dy, Math.sin(phi) * radius))); } renderer.render(); @@ -163,15 +166,12 @@ public abstract class AbstractRenderer { Renderer renderer = Renderer.startPoints() .setColor(color); - int segments = 64; - double thetaSegment = PI / (double) segments; - double phiSegment = TAU / (double) segments; - - for (double phi = 0.0D; phi < TAU; phi += phiSegment) { - for (double theta = 0.0D; theta < PI; theta += thetaSegment) { - double dx = radius * Math.sin(phi) * Math.cos(theta); - double dz = radius * Math.sin(phi) * Math.sin(theta); - double dy = radius * Math.cos(phi); + for (double phi = 0.0D; phi < TAU; phi += PHI_SEGMENT) { + double dy = radius * Math.cos(phi); + double radiusBySinPhi = radius * Math.sin(phi); + for (double theta = 0.0D; theta < PI; theta += THETA_SEGMENT) { + double dx = radiusBySinPhi * Math.cos(theta); + double dz = radiusBySinPhi * Math.sin(theta); renderer.addPoint(new OffsetPoint(center.offset(dx, dy, dz))); }