mirror of
https://github.com/Jozufozu/Flywheel.git
synced 2025-01-07 12:56:31 +01:00
Spheres your cubes
- Use sphere-frustum intersection tests in visuals. - Seems to be ~20x faster.
This commit is contained in:
parent
e87eb4e371
commit
aa75e7c276
4 changed files with 30 additions and 10 deletions
|
@ -4,6 +4,11 @@ public final class MoreMath {
|
||||||
private MoreMath() {
|
private MoreMath() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The circumsphere of a cube has a radius of sqrt(3) / 2 * sideLength.
|
||||||
|
*/
|
||||||
|
public static final float SQRT_3_OVER_2 = (float) (Math.sqrt(3.0) / 2.0);
|
||||||
|
|
||||||
public static int align16(int numToRound) {
|
public static int align16(int numToRound) {
|
||||||
return (numToRound + 16 - 1) & -16;
|
return (numToRound + 16 - 1) & -16;
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,7 @@ import com.jozufozu.flywheel.api.visualization.VisualManager;
|
||||||
import com.jozufozu.flywheel.api.visualization.VisualizationContext;
|
import com.jozufozu.flywheel.api.visualization.VisualizationContext;
|
||||||
import com.jozufozu.flywheel.lib.box.Box;
|
import com.jozufozu.flywheel.lib.box.Box;
|
||||||
import com.jozufozu.flywheel.lib.box.MutableBox;
|
import com.jozufozu.flywheel.lib.box.MutableBox;
|
||||||
|
import com.jozufozu.flywheel.lib.math.MoreMath;
|
||||||
|
|
||||||
import net.minecraft.core.BlockPos;
|
import net.minecraft.core.BlockPos;
|
||||||
import net.minecraft.world.level.block.entity.BlockEntity;
|
import net.minecraft.world.level.block.entity.BlockEntity;
|
||||||
|
@ -73,7 +74,10 @@ public abstract class AbstractBlockEntityVisual<T extends BlockEntity> extends A
|
||||||
* @return {@code true} if this visual within the given frustum.
|
* @return {@code true} if this visual within the given frustum.
|
||||||
*/
|
*/
|
||||||
public boolean isVisible(FrustumIntersection frustum) {
|
public boolean isVisible(FrustumIntersection frustum) {
|
||||||
return frustum.testAab(visualPos.getX(), visualPos.getY(), visualPos.getZ(), visualPos.getX() + 1, visualPos.getY() + 1, visualPos.getZ() + 1);
|
float x = visualPos.getX() + 0.5f;
|
||||||
|
float y = visualPos.getY() + 0.5f;
|
||||||
|
float z = visualPos.getZ() + 0.5f;
|
||||||
|
return frustum.testSphere(x, y, z, MoreMath.SQRT_3_OVER_2);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -41,7 +41,7 @@ public abstract class AbstractEntityVisual<T extends Entity> extends AbstractVis
|
||||||
super(ctx, entity.level());
|
super(ctx, entity.level());
|
||||||
this.entity = entity;
|
this.entity = entity;
|
||||||
bounds = MutableBox.from(entity.getBoundingBox());
|
bounds = MutableBox.from(entity.getBoundingBox());
|
||||||
visibilityTester = new EntityVisibilityTester(entity, ctx.renderOrigin());
|
visibilityTester = new EntityVisibilityTester(entity, ctx.renderOrigin(), 1.5f);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -3,7 +3,10 @@ package com.jozufozu.flywheel.lib.visual;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
import org.joml.FrustumIntersection;
|
import org.joml.FrustumIntersection;
|
||||||
|
|
||||||
|
import com.jozufozu.flywheel.lib.math.MoreMath;
|
||||||
|
|
||||||
import net.minecraft.core.Vec3i;
|
import net.minecraft.core.Vec3i;
|
||||||
|
import net.minecraft.util.Mth;
|
||||||
import net.minecraft.world.entity.Entity;
|
import net.minecraft.world.entity.Entity;
|
||||||
import net.minecraft.world.phys.AABB;
|
import net.minecraft.world.phys.AABB;
|
||||||
|
|
||||||
|
@ -15,12 +18,22 @@ import net.minecraft.world.phys.AABB;
|
||||||
public class EntityVisibilityTester {
|
public class EntityVisibilityTester {
|
||||||
private final Entity entity;
|
private final Entity entity;
|
||||||
private final Vec3i renderOrigin;
|
private final Vec3i renderOrigin;
|
||||||
|
private final float scale;
|
||||||
@Nullable
|
@Nullable
|
||||||
private AABB lastVisibleAABB;
|
private AABB lastVisibleAABB;
|
||||||
|
|
||||||
public EntityVisibilityTester(Entity entity, Vec3i renderOrigin) {
|
/**
|
||||||
|
* Create a new EntityVisibilityTester.
|
||||||
|
*
|
||||||
|
* @param entity The Entity to test.
|
||||||
|
* @param renderOrigin The render origin according to the VisualizationContext.
|
||||||
|
* @param scale Multiplier for the Entity's size, can be used to adjust for when
|
||||||
|
* an entity's model is larger than its hitbox.
|
||||||
|
*/
|
||||||
|
public EntityVisibilityTester(Entity entity, Vec3i renderOrigin, float scale) {
|
||||||
this.entity = entity;
|
this.entity = entity;
|
||||||
this.renderOrigin = renderOrigin;
|
this.renderOrigin = renderOrigin;
|
||||||
|
this.scale = scale;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -47,12 +60,10 @@ public class EntityVisibilityTester {
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean adjustAndTestAABB(FrustumIntersection frustum, AABB aabb) {
|
private boolean adjustAndTestAABB(FrustumIntersection frustum, AABB aabb) {
|
||||||
float minX = (float) (aabb.minX - renderOrigin.getX() - 0.5);
|
float x = (float) Mth.lerp(0.5D, aabb.minX, aabb.maxX) - renderOrigin.getX();
|
||||||
float minY = (float) (aabb.minY - renderOrigin.getY() - 0.5);
|
float y = (float) Mth.lerp(0.5D, aabb.minY, aabb.maxY) - renderOrigin.getY();
|
||||||
float minZ = (float) (aabb.minZ - renderOrigin.getZ() - 0.5);
|
float z = (float) Mth.lerp(0.5D, aabb.minZ, aabb.maxZ) - renderOrigin.getZ();
|
||||||
float maxX = (float) (aabb.maxX - renderOrigin.getX() + 0.5);
|
float maxSize = (float) Math.max(aabb.getXsize(), Math.max(aabb.getYsize(), aabb.getZsize()));
|
||||||
float maxY = (float) (aabb.maxY - renderOrigin.getY() + 0.5);
|
return frustum.testSphere(x, y, z, maxSize * MoreMath.SQRT_3_OVER_2 * scale);
|
||||||
float maxZ = (float) (aabb.maxZ - renderOrigin.getZ() + 0.5);
|
|
||||||
return frustum.testAab(minX, minY, minZ, maxX, maxY, maxZ);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue