|
23 | 23 |
|
24 | 24 | package me.shedaniel.rei.impl.client.registry.screen; |
25 | 25 |
|
26 | | -import com.mojang.blaze3d.systems.RenderSystem; |
27 | | -import com.mojang.blaze3d.vertex.PoseStack; |
28 | 26 | import dev.architectury.event.EventResult; |
29 | 27 | import dev.architectury.event.events.client.ClientGuiEvent; |
30 | 28 | import me.shedaniel.rei.api.client.gui.screen.DisplayScreen; |
@@ -97,20 +95,15 @@ public void onApplied(Sink sink) { |
97 | 95 | return; |
98 | 96 | rendered[0] = 2; |
99 | 97 | resetFocused(screen); |
100 | | - graphics.pose().pushMatrix(); |
101 | | - graphics.pose().translate(-screen.leftPos, -screen.topPos); |
102 | | - sink.lateRender(graphics, mouseX, mouseY, delta); |
103 | | - graphics.pose().popMatrix(); |
104 | | - resetFocused(screen); |
105 | 98 | }; |
106 | 99 | this.renderPost = (screen, graphics, mouseX, mouseY, delta) -> { |
107 | | - if (shouldReturn(screen) || rendered[0] == 2) |
| 100 | + if (shouldReturn(screen)) |
108 | 101 | return; |
109 | | - if (screen instanceof AbstractContainerScreen) { |
| 102 | + if (screen instanceof AbstractContainerScreen && rendered[0] < 2) { |
110 | 103 | InternalLogger.getInstance().warn("Screen " + screen.getClass().getName() + " did not render background and foreground! This might cause rendering issues!"); |
111 | 104 | } |
112 | 105 | resetFocused(screen); |
113 | | - if (rendered[0] == 0 && !(screen instanceof DisplayScreen)) { |
| 106 | + if (rendered[0] == 0 && !(screen instanceof DisplayScreen) && (!(screen instanceof AbstractContainerScreen) || rendered[0] < 2)) { |
114 | 107 | sink.render(graphics, mouseX, mouseY, delta.getRealtimeDeltaTicks()); |
115 | 108 | } |
116 | 109 | rendered[0] = 1; |
|
0 commit comments