mirror of
https://github.com/Jozufozu/Flywheel.git
synced 2025-01-12 23:36:09 +01:00
Mojmixins
This commit is contained in:
parent
09e52e974f
commit
f19444e271
11 changed files with 35 additions and 35 deletions
|
@ -25,7 +25,7 @@ public class CancelTileEntityRenderMixin {
|
||||||
* list of tile entities to render. By filtering the output here, we prevent the game from
|
* list of tile entities to render. By filtering the output here, we prevent the game from
|
||||||
* doing unnecessary light lookups and frustum checks.
|
* doing unnecessary light lookups and frustum checks.
|
||||||
*/
|
*/
|
||||||
@Inject(at = @At("RETURN"), method = "getTileEntities", cancellable = true)
|
@Inject(at = @At("RETURN"), method = "getRenderableBlockEntities", cancellable = true)
|
||||||
private void noRenderInstancedTiles(CallbackInfoReturnable<List<TileEntity>> cir) {
|
private void noRenderInstancedTiles(CallbackInfoReturnable<List<TileEntity>> cir) {
|
||||||
if (Backend.getInstance()
|
if (Backend.getInstance()
|
||||||
.canUseInstancing()) {
|
.canUseInstancing()) {
|
||||||
|
|
|
@ -20,7 +20,7 @@ import net.minecraftforge.api.distmarker.OnlyIn;
|
||||||
@Mixin(WorldRenderer.class)
|
@Mixin(WorldRenderer.class)
|
||||||
public class FixFabulousDepthMixin {
|
public class FixFabulousDepthMixin {
|
||||||
|
|
||||||
@Inject(method = "render", at = @At(value = "INVOKE", ordinal = 1, target = "Lnet/minecraft/client/shader/ShaderGroup;render(F)V"))
|
@Inject(method = "renderLevel", at = @At(value = "INVOKE", ordinal = 1, target = "Lnet/minecraft/client/shader/ShaderGroup;process(F)V"))
|
||||||
private void disableTransparencyShaderDepth(MatrixStack p_228426_1_, float p_228426_2_, long p_228426_3_, boolean p_228426_5_, ActiveRenderInfo p_228426_6_, GameRenderer p_228426_7_, LightTexture p_228426_8_, Matrix4f p_228426_9_, CallbackInfo ci) {
|
private void disableTransparencyShaderDepth(MatrixStack p_228426_1_, float p_228426_2_, long p_228426_3_, boolean p_228426_5_, ActiveRenderInfo p_228426_6_, GameRenderer p_228426_7_, LightTexture p_228426_8_, Matrix4f p_228426_9_, CallbackInfo ci) {
|
||||||
GlStateManager._depthMask(false);
|
GlStateManager._depthMask(false);
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,7 @@ import com.mojang.blaze3d.platform.GlStateManager;
|
||||||
@Mixin(GlStateManager.class)
|
@Mixin(GlStateManager.class)
|
||||||
public class FogColorTrackerMixin {
|
public class FogColorTrackerMixin {
|
||||||
|
|
||||||
@Inject(at = @At("TAIL"), method = "fog")
|
@Inject(at = @At("TAIL"), method = "_fog")
|
||||||
private static void copyFogColor(int pname, float[] params, CallbackInfo ci) {
|
private static void copyFogColor(int pname, float[] params, CallbackInfo ci) {
|
||||||
if (pname == GL11.GL_FOG_COLOR) {
|
if (pname == GL11.GL_FOG_COLOR) {
|
||||||
GlFog.FOG_COLOR = params;
|
GlFog.FOG_COLOR = params;
|
||||||
|
|
|
@ -35,11 +35,11 @@ import net.minecraftforge.common.MinecraftForge;
|
||||||
public class RenderHooksMixin {
|
public class RenderHooksMixin {
|
||||||
|
|
||||||
@Shadow
|
@Shadow
|
||||||
private ClientWorld world;
|
private ClientWorld level;
|
||||||
|
|
||||||
@Inject(at = @At(value = "INVOKE", target = "net.minecraft.client.renderer.WorldRenderer.updateChunks(J)V"), method = "render")
|
@Inject(at = @At(value = "INVOKE", target = "net.minecraft.client.renderer.WorldRenderer.compileChunksUntil(J)V"), method = "renderLevel")
|
||||||
private void setupFrame(MatrixStack stack, float p_228426_2_, long p_228426_3_, boolean p_228426_5_, ActiveRenderInfo info, GameRenderer gameRenderer, LightTexture lightTexture, Matrix4f p_228426_9_, CallbackInfo ci) {
|
private void setupFrame(MatrixStack stack, float p_228426_2_, long p_228426_3_, boolean p_228426_5_, ActiveRenderInfo info, GameRenderer gameRenderer, LightTexture lightTexture, Matrix4f p_228426_9_, CallbackInfo ci) {
|
||||||
MinecraftForge.EVENT_BUS.post(new BeginFrameEvent(world, stack, info, gameRenderer, lightTexture));
|
MinecraftForge.EVENT_BUS.post(new BeginFrameEvent(level, stack, info, gameRenderer, lightTexture));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -47,7 +47,7 @@ public class RenderHooksMixin {
|
||||||
* layer-correct custom rendering. RenderWorldLast is not refined enough for rendering world objects.
|
* layer-correct custom rendering. RenderWorldLast is not refined enough for rendering world objects.
|
||||||
* This should probably be a forge event.
|
* This should probably be a forge event.
|
||||||
*/
|
*/
|
||||||
@Inject(at = @At("TAIL"), method = "renderLayer")
|
@Inject(at = @At("TAIL"), method = "renderChunkLayer")
|
||||||
private void renderLayer(RenderType type, MatrixStack stack, double camX, double camY, double camZ, CallbackInfo ci) {
|
private void renderLayer(RenderType type, MatrixStack stack, double camX, double camY, double camZ, CallbackInfo ci) {
|
||||||
Matrix4f view = stack.last()
|
Matrix4f view = stack.last()
|
||||||
.pose();
|
.pose();
|
||||||
|
@ -55,22 +55,22 @@ public class RenderHooksMixin {
|
||||||
viewProjection.multiplyBackward(Backend.getInstance()
|
viewProjection.multiplyBackward(Backend.getInstance()
|
||||||
.getProjectionMatrix());
|
.getProjectionMatrix());
|
||||||
|
|
||||||
MinecraftForge.EVENT_BUS.post(new RenderLayerEvent(world, type, viewProjection, camX, camY, camZ));
|
MinecraftForge.EVENT_BUS.post(new RenderLayerEvent(level, type, viewProjection, camX, camY, camZ));
|
||||||
|
|
||||||
if (!OptifineHandler.usingShaders()) GL20.glUseProgram(0);
|
if (!OptifineHandler.usingShaders()) GL20.glUseProgram(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Inject(at = @At("TAIL"), method = "loadRenderers")
|
@Inject(at = @At("TAIL"), method = "allChanged")
|
||||||
private void refresh(CallbackInfo ci) {
|
private void refresh(CallbackInfo ci) {
|
||||||
Backend.getInstance()
|
Backend.getInstance()
|
||||||
.refresh();
|
.refresh();
|
||||||
|
|
||||||
MinecraftForge.EVENT_BUS.post(new ReloadRenderersEvent(world));
|
MinecraftForge.EVENT_BUS.post(new ReloadRenderersEvent(level));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Inject(at = @At(value = "INVOKE", target = "Lnet/minecraft/client/renderer/WorldRenderer;checkEmpty(Lcom/mojang/blaze3d/matrix/MatrixStack;)V", ordinal = 2 // after the game renders the breaking overlay normally
|
@Inject(at = @At(value = "INVOKE", target = "Lnet/minecraft/client/renderer/WorldRenderer;checkPoseStack(Lcom/mojang/blaze3d/matrix/MatrixStack;)V", ordinal = 2 // after the game renders the breaking overlay normally
|
||||||
), method = "render")
|
), method = "renderLevel")
|
||||||
private void renderBlockBreaking(MatrixStack stack, float p_228426_2_, long p_228426_3_, boolean p_228426_5_, ActiveRenderInfo info, GameRenderer gameRenderer, LightTexture lightTexture, Matrix4f p_228426_9_, CallbackInfo ci) {
|
private void renderBlockBreaking(MatrixStack stack, float p_228426_2_, long p_228426_3_, boolean p_228426_5_, ActiveRenderInfo info, GameRenderer gameRenderer, LightTexture lightTexture, Matrix4f p_228426_9_, CallbackInfo ci) {
|
||||||
if (!Backend.getInstance()
|
if (!Backend.getInstance()
|
||||||
.available()) return;
|
.available()) return;
|
||||||
|
@ -82,16 +82,16 @@ public class RenderHooksMixin {
|
||||||
.getProjectionMatrix());
|
.getProjectionMatrix());
|
||||||
|
|
||||||
Vector3d cameraPos = info.getPosition();
|
Vector3d cameraPos = info.getPosition();
|
||||||
CrumblingRenderer.renderBreaking(world, viewProjection, cameraPos.x, cameraPos.y, cameraPos.z);
|
CrumblingRenderer.renderBreaking(level, viewProjection, cameraPos.x, cameraPos.y, cameraPos.z);
|
||||||
|
|
||||||
if (!OptifineHandler.usingShaders()) GL20.glUseProgram(0);
|
if (!OptifineHandler.usingShaders()) GL20.glUseProgram(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Instancing
|
// Instancing
|
||||||
|
|
||||||
@Inject(at = @At("TAIL"), method = "scheduleBlockRerenderIfNeeded")
|
@Inject(at = @At("TAIL"), method = "setBlockDirty(Lnet/minecraft/util/math/BlockPos;Lnet/minecraft/block/BlockState;Lnet/minecraft/block/BlockState;)V")
|
||||||
private void checkUpdate(BlockPos pos, BlockState lastState, BlockState newState, CallbackInfo ci) {
|
private void checkUpdate(BlockPos pos, BlockState lastState, BlockState newState, CallbackInfo ci) {
|
||||||
InstancedRenderDispatcher.getTiles(world)
|
InstancedRenderDispatcher.getTiles(level)
|
||||||
.update(world.getBlockEntity(pos));
|
.update(level.getBlockEntity(pos));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,12 +19,12 @@ public class ShaderCloseMixin {
|
||||||
|
|
||||||
@Shadow
|
@Shadow
|
||||||
@Nullable
|
@Nullable
|
||||||
public Screen currentScreen;
|
public Screen screen;
|
||||||
|
|
||||||
@Inject(at = @At("HEAD"), method = "displayGuiScreen")
|
@Inject(at = @At("HEAD"), method = "setScreen")
|
||||||
private void whenScreenChanges(Screen screen, CallbackInfo info) {
|
private void whenScreenChanges(Screen screen, CallbackInfo info) {
|
||||||
if (OptifineHandler.optifineInstalled() && screen instanceof VideoSettingsScreen) {
|
if (OptifineHandler.optifineInstalled() && screen instanceof VideoSettingsScreen) {
|
||||||
Screen old = this.currentScreen;
|
Screen old = this.screen;
|
||||||
if (old != null && old.getClass()
|
if (old != null && old.getClass()
|
||||||
.getName()
|
.getName()
|
||||||
.startsWith(OptifineHandler.SHADER_PACKAGE)) {
|
.startsWith(OptifineHandler.SHADER_PACKAGE)) {
|
||||||
|
|
|
@ -22,12 +22,12 @@ public abstract class StoreProjectionMatrixMixin {
|
||||||
* We only want to copy the projection matrix if it is going to be used to render the world.
|
* We only want to copy the projection matrix if it is going to be used to render the world.
|
||||||
* We don't care about the mat for your hand.
|
* We don't care about the mat for your hand.
|
||||||
*/
|
*/
|
||||||
@Inject(method = "renderWorld", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/renderer/GameRenderer;loadProjectionMatrix(Lnet/minecraft/util/math/vector/Matrix4f;)V"))
|
@Inject(method = "renderLevel", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/renderer/GameRenderer;resetProjectionMatrix(Lnet/minecraft/util/math/vector/Matrix4f;)V"))
|
||||||
private void projectionMatrixReady(float p_228378_1_, long p_228378_2_, MatrixStack p_228378_4_, CallbackInfo ci) {
|
private void projectionMatrixReady(float p_228378_1_, long p_228378_2_, MatrixStack p_228378_4_, CallbackInfo ci) {
|
||||||
shouldCopy = true;
|
shouldCopy = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Inject(method = "loadProjectionMatrix", at = @At("TAIL"))
|
@Inject(method = "resetProjectionMatrix", at = @At("TAIL"))
|
||||||
private void onProjectionMatrixLoad(Matrix4f projection, CallbackInfo ci) {
|
private void onProjectionMatrixLoad(Matrix4f projection, CallbackInfo ci) {
|
||||||
if (shouldCopy) {
|
if (shouldCopy) {
|
||||||
Backend.getInstance()
|
Backend.getInstance()
|
||||||
|
|
|
@ -19,11 +19,11 @@ public class TileRemoveMixin {
|
||||||
|
|
||||||
@Shadow
|
@Shadow
|
||||||
@Nullable
|
@Nullable
|
||||||
protected World world;
|
protected World level;
|
||||||
|
|
||||||
@Inject(at = @At("TAIL"), method = "remove")
|
@Inject(at = @At("TAIL"), method = "setRemoved")
|
||||||
private void onRemove(CallbackInfo ci) {
|
private void onRemove(CallbackInfo ci) {
|
||||||
if (world instanceof ClientWorld) InstancedRenderDispatcher.getTiles(this.world)
|
if (level instanceof ClientWorld) InstancedRenderDispatcher.getTiles(this.level)
|
||||||
.remove((TileEntity) (Object) this);
|
.remove((TileEntity) (Object) this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,15 +26,15 @@ public class TileWorldHookMixin {
|
||||||
|
|
||||||
@Shadow
|
@Shadow
|
||||||
@Final
|
@Final
|
||||||
public boolean isRemote;
|
public boolean isClientSide;
|
||||||
|
|
||||||
@Shadow
|
@Shadow
|
||||||
@Final
|
@Final
|
||||||
protected Set<TileEntity> tileEntitiesToBeRemoved;
|
protected Set<TileEntity> blockEntitiesToUnload;
|
||||||
|
|
||||||
@Inject(at = @At("TAIL"), method = "addTileEntity")
|
@Inject(at = @At("TAIL"), method = "addBlockEntity")
|
||||||
private void onAddTile(TileEntity te, CallbackInfoReturnable<Boolean> cir) {
|
private void onAddTile(TileEntity te, CallbackInfoReturnable<Boolean> cir) {
|
||||||
if (isRemote) {
|
if (isClientSide) {
|
||||||
InstancedRenderDispatcher.getTiles(self)
|
InstancedRenderDispatcher.getTiles(self)
|
||||||
.queueAdd(te);
|
.queueAdd(te);
|
||||||
}
|
}
|
||||||
|
@ -45,9 +45,9 @@ public class TileWorldHookMixin {
|
||||||
*/
|
*/
|
||||||
@Inject(at = @At(value = "INVOKE", target = "Ljava/util/Set;clear()V", ordinal = 0), method = "tickBlockEntities")
|
@Inject(at = @At(value = "INVOKE", target = "Ljava/util/Set;clear()V", ordinal = 0), method = "tickBlockEntities")
|
||||||
private void onChunkUnload(CallbackInfo ci) {
|
private void onChunkUnload(CallbackInfo ci) {
|
||||||
if (isRemote) {
|
if (isClientSide) {
|
||||||
InstanceManager<TileEntity> kineticRenderer = InstancedRenderDispatcher.getTiles(self);
|
InstanceManager<TileEntity> kineticRenderer = InstancedRenderDispatcher.getTiles(self);
|
||||||
for (TileEntity tile : tileEntitiesToBeRemoved) {
|
for (TileEntity tile : blockEntitiesToUnload) {
|
||||||
kineticRenderer.remove(tile);
|
kineticRenderer.remove(tile);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,14 +19,14 @@ import net.minecraft.util.ResourceLocation;
|
||||||
public abstract class AtlasDataMixin {
|
public abstract class AtlasDataMixin {
|
||||||
|
|
||||||
@Shadow
|
@Shadow
|
||||||
public abstract ResourceLocation getId();
|
public abstract ResourceLocation location();
|
||||||
|
|
||||||
@Inject(method = "stitch", at = @At("RETURN"))
|
@Inject(method = "prepareToStitch", at = @At("RETURN"))
|
||||||
public void stealAtlasData(IResourceManager resourceManager, Stream<ResourceLocation> locationStream, IProfiler profiler, int mipMapLevels, CallbackInfoReturnable<AtlasTexture.SheetData> cir) {
|
public void stealAtlasData(IResourceManager resourceManager, Stream<ResourceLocation> locationStream, IProfiler profiler, int mipMapLevels, CallbackInfoReturnable<AtlasTexture.SheetData> cir) {
|
||||||
AtlasTexture.SheetData value = cir.getReturnValue();
|
AtlasTexture.SheetData value = cir.getReturnValue();
|
||||||
|
|
||||||
SheetDataAccessor dataAccessor = (SheetDataAccessor) value;
|
SheetDataAccessor dataAccessor = (SheetDataAccessor) value;
|
||||||
|
|
||||||
AtlasInfo.setAtlasData(getId(), dataAccessor);
|
AtlasInfo.setAtlasData(location(), dataAccessor);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,7 +33,7 @@ public abstract class LightUpdateMixin extends AbstractChunkProvider {
|
||||||
* the rendering system that it needs to redraw a chunk. It does all that work asynchronously,
|
* the rendering system that it needs to redraw a chunk. It does all that work asynchronously,
|
||||||
* and we should too.
|
* and we should too.
|
||||||
*/
|
*/
|
||||||
@Inject(at = @At("HEAD"), method = "markLightChanged")
|
@Inject(at = @At("HEAD"), method = "onLightUpdate")
|
||||||
private void onLightUpdate(LightType type, SectionPos pos, CallbackInfo ci) {
|
private void onLightUpdate(LightType type, SectionPos pos, CallbackInfo ci) {
|
||||||
ClientChunkProvider thi = ((ClientChunkProvider) (Object) this);
|
ClientChunkProvider thi = ((ClientChunkProvider) (Object) this);
|
||||||
ClientWorld world = (ClientWorld) thi.getLevel();
|
ClientWorld world = (ClientWorld) thi.getLevel();
|
||||||
|
|
|
@ -24,7 +24,7 @@ import net.minecraft.world.chunk.Chunk;
|
||||||
@Mixin(ClientPlayNetHandler.class)
|
@Mixin(ClientPlayNetHandler.class)
|
||||||
public class NetworkLightUpdateMixin {
|
public class NetworkLightUpdateMixin {
|
||||||
|
|
||||||
@Inject(at = @At("TAIL"), method = "handleUpdateLight")
|
@Inject(at = @At("TAIL"), method = "handleLightUpdatePacked")
|
||||||
private void onLightPacket(SUpdateLightPacket packet, CallbackInfo ci) {
|
private void onLightPacket(SUpdateLightPacket packet, CallbackInfo ci) {
|
||||||
RenderWork.enqueue(() -> {
|
RenderWork.enqueue(() -> {
|
||||||
ClientWorld world = Minecraft.getInstance().level;
|
ClientWorld world = Minecraft.getInstance().level;
|
||||||
|
|
Loading…
Reference in a new issue