mirror of
https://github.com/Jozufozu/Flywheel.git
synced 2025-01-15 00:36:08 +01:00
What makes it tick
- Tick visual managers on post LevelTickEvent. - Remove all field from VisualTickContext, but keep the interface there for later review. - Remove tick update limiter, though apparently we were passing the frame limiter to the tick context :lwe:
This commit is contained in:
parent
af28c39a48
commit
a82e3f8dd5
5 changed files with 17 additions and 39 deletions
|
@ -4,11 +4,5 @@ import org.jetbrains.annotations.ApiStatus;
|
||||||
|
|
||||||
@ApiStatus.NonExtendable
|
@ApiStatus.NonExtendable
|
||||||
public interface VisualTickContext {
|
public interface VisualTickContext {
|
||||||
double cameraX();
|
// TODO: remove?
|
||||||
|
|
||||||
double cameraY();
|
|
||||||
|
|
||||||
double cameraZ();
|
|
||||||
|
|
||||||
DistanceUpdateLimiter limiter();
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,6 @@
|
||||||
package com.jozufozu.flywheel.impl.visual;
|
package com.jozufozu.flywheel.impl.visual;
|
||||||
|
|
||||||
import com.jozufozu.flywheel.api.visual.DistanceUpdateLimiter;
|
|
||||||
import com.jozufozu.flywheel.api.visual.VisualTickContext;
|
import com.jozufozu.flywheel.api.visual.VisualTickContext;
|
||||||
|
|
||||||
public record VisualTickContextImpl(double cameraX, double cameraY, double cameraZ,
|
public record VisualTickContextImpl() implements VisualTickContext {
|
||||||
DistanceUpdateLimiter limiter) implements VisualTickContext {
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,46 +3,36 @@ package com.jozufozu.flywheel.impl.visualization;
|
||||||
import com.jozufozu.flywheel.api.event.BeginFrameEvent;
|
import com.jozufozu.flywheel.api.event.BeginFrameEvent;
|
||||||
import com.jozufozu.flywheel.api.event.RenderStageEvent;
|
import com.jozufozu.flywheel.api.event.RenderStageEvent;
|
||||||
import com.jozufozu.flywheel.api.visualization.VisualizationManager;
|
import com.jozufozu.flywheel.api.visualization.VisualizationManager;
|
||||||
import com.jozufozu.flywheel.lib.util.FlwUtil;
|
|
||||||
|
|
||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.Minecraft;
|
||||||
import net.minecraft.client.multiplayer.ClientLevel;
|
import net.minecraft.client.multiplayer.ClientLevel;
|
||||||
import net.minecraft.world.entity.Entity;
|
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraftforge.event.TickEvent;
|
import net.minecraftforge.event.TickEvent;
|
||||||
import net.minecraftforge.event.entity.EntityJoinLevelEvent;
|
import net.minecraftforge.event.entity.EntityJoinLevelEvent;
|
||||||
import net.minecraftforge.event.entity.EntityLeaveLevelEvent;
|
import net.minecraftforge.event.entity.EntityLeaveLevelEvent;
|
||||||
|
import net.minecraftforge.fml.LogicalSide;
|
||||||
|
|
||||||
public final class VisualizationEventHandler {
|
public final class VisualizationEventHandler {
|
||||||
private VisualizationEventHandler() {
|
private VisualizationEventHandler() {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void onClientTick(TickEvent.ClientTickEvent event) {
|
public static void onClientTick(TickEvent.LevelTickEvent event) {
|
||||||
if (event.phase != TickEvent.Phase.END || !FlwUtil.isGameActive()) {
|
// Make sure we don't tick on the server somehow.
|
||||||
|
if (event.phase != TickEvent.Phase.END || event.side != LogicalSide.CLIENT) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Minecraft mc = Minecraft.getInstance();
|
// The game won't be paused in the tick event, but let's make sure there's a player.
|
||||||
if (mc.isPaused()) {
|
if (Minecraft.getInstance().player == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Entity cameraEntity = mc.getCameraEntity() == null ? mc.player : mc.getCameraEntity();
|
VisualizationManagerImpl manager = VisualizationManagerImpl.get(event.level);
|
||||||
if (cameraEntity == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
Level level = cameraEntity.level();
|
|
||||||
VisualizationManagerImpl manager = VisualizationManagerImpl.get(level);
|
|
||||||
if (manager == null) {
|
if (manager == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
double cameraX = cameraEntity.getX();
|
manager.tick();
|
||||||
double cameraY = cameraEntity.getEyeY();
|
|
||||||
double cameraZ = cameraEntity.getZ();
|
|
||||||
|
|
||||||
manager.tick(cameraX, cameraY, cameraZ);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void onBeginFrame(BeginFrameEvent event) {
|
public static void onBeginFrame(BeginFrameEvent event) {
|
||||||
|
|
|
@ -77,11 +77,9 @@ public class VisualizationManagerImpl implements VisualizationManager {
|
||||||
private final Flag frameVisualsFlag = new NamedFlag("frameVisualUpdates");
|
private final Flag frameVisualsFlag = new NamedFlag("frameVisualUpdates");
|
||||||
private final Flag frameFlag = new NamedFlag("frameComplete");
|
private final Flag frameFlag = new NamedFlag("frameComplete");
|
||||||
|
|
||||||
protected DistanceUpdateLimiterImpl tickLimiter;
|
|
||||||
protected DistanceUpdateLimiterImpl frameLimiter;
|
protected DistanceUpdateLimiterImpl frameLimiter;
|
||||||
|
|
||||||
private VisualizationManagerImpl(LevelAccessor level) {
|
private VisualizationManagerImpl(LevelAccessor level) {
|
||||||
tickLimiter = createUpdateLimiter();
|
|
||||||
frameLimiter = createUpdateLimiter();
|
frameLimiter = createUpdateLimiter();
|
||||||
|
|
||||||
engine = BackendManager.getBackend()
|
engine = BackendManager.getBackend()
|
||||||
|
@ -219,7 +217,7 @@ public class VisualizationManagerImpl implements VisualizationManager {
|
||||||
* Call {@link TickableVisual#tick} on all visuals in this world.
|
* Call {@link TickableVisual#tick} on all visuals in this world.
|
||||||
* </p>
|
* </p>
|
||||||
*/
|
*/
|
||||||
public void tick(double cameraX, double cameraY, double cameraZ) {
|
public void tick() {
|
||||||
// Make sure we're done with any prior frame or tick to avoid racing.
|
// Make sure we're done with any prior frame or tick to avoid racing.
|
||||||
taskExecutor.syncUntil(frameFlag::isRaised);
|
taskExecutor.syncUntil(frameFlag::isRaised);
|
||||||
frameFlag.lower();
|
frameFlag.lower();
|
||||||
|
@ -227,18 +225,15 @@ public class VisualizationManagerImpl implements VisualizationManager {
|
||||||
taskExecutor.syncUntil(tickFlag::isRaised);
|
taskExecutor.syncUntil(tickFlag::isRaised);
|
||||||
tickFlag.lower();
|
tickFlag.lower();
|
||||||
|
|
||||||
tickLimiter.tick();
|
tickPlan.execute(taskExecutor, new VisualTickContextImpl());
|
||||||
|
|
||||||
tickPlan.execute(taskExecutor, new VisualTickContextImpl(cameraX, cameraY, cameraZ, frameLimiter));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get ready to render a frame.
|
* Get ready to render a frame.
|
||||||
* <p>
|
*
|
||||||
* Check and update the render origin.
|
* <p>Check and update the render origin.
|
||||||
* <br>
|
* <br>
|
||||||
* Call {@link DynamicVisual#beginFrame} on all visuals in this world.
|
* Call {@link DynamicVisual#beginFrame} on all visuals in this world.</p>
|
||||||
* </p>
|
|
||||||
*/
|
*/
|
||||||
public void beginFrame(RenderContext context) {
|
public void beginFrame(RenderContext context) {
|
||||||
// Make sure we're done with the last tick.
|
// Make sure we're done with the last tick.
|
||||||
|
|
|
@ -24,6 +24,7 @@ public class BlockEntityStorage extends Storage<BlockEntity> {
|
||||||
super(visualizationContextSupplier);
|
super(visualizationContextSupplier);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
public BlockEntityVisual<?> visualAtPos(long pos) {
|
public BlockEntityVisual<?> visualAtPos(long pos) {
|
||||||
return posLookup.get(pos);
|
return posLookup.get(pos);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue