Compare commits
2 Commits
e2115397fe
...
c4b7f6e78e
Author | SHA1 | Date | |
---|---|---|---|
c4b7f6e78e | |||
aac28a4704 |
@ -134,7 +134,7 @@ object AndroidResearchManager : SimpleJsonResourceReloadListener(GsonBuilder().s
|
||||
}
|
||||
|
||||
context.enqueueWork {
|
||||
minecraft.player?.matteryPlayer?.reloadResearch(MINECRAFT_SERVER.registryAccess())
|
||||
context.player().matteryPlayer.reloadResearch(context.player().registryAccess())
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -331,10 +331,12 @@ object MatteryGUI {
|
||||
fun onLayerRenderEvent(event: RenderGuiLayerEvent.Pre) {
|
||||
val gui = minecraft.gui
|
||||
|
||||
if (event.name == VanillaGuiLayers.FOOD_LEVEL || event.name == VanillaGuiLayers.AIR_LEVEL) {
|
||||
renderFoodAndAir(event, gui)
|
||||
} else if (event.name == VanillaGuiLayers.PLAYER_HEALTH) {
|
||||
renderPlayerHealth(event, gui)
|
||||
if (minecraft.gameMode?.canHurtPlayer() == true && !minecraft.options.hideGui) {
|
||||
if (event.name == VanillaGuiLayers.FOOD_LEVEL || event.name == VanillaGuiLayers.AIR_LEVEL) {
|
||||
renderFoodAndAir(event, gui)
|
||||
} else if (event.name == VanillaGuiLayers.PLAYER_HEALTH) {
|
||||
renderPlayerHealth(event, gui)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -101,6 +101,7 @@ import ru.dbotthepony.mc.otm.core.writeComponent
|
||||
import ru.dbotthepony.mc.otm.core.writeItemType
|
||||
import ru.dbotthepony.mc.otm.matter.MatterManager.Finder
|
||||
import ru.dbotthepony.mc.otm.milliTime
|
||||
import ru.dbotthepony.mc.otm.onceServer
|
||||
import ru.dbotthepony.mc.otm.registry.MDeferredRegister
|
||||
import ru.dbotthepony.mc.otm.registry.RegistryDelegate
|
||||
import ru.dbotthepony.mc.otm.secondTime
|
||||
@ -1771,8 +1772,16 @@ object MatterManager {
|
||||
|
||||
LOGGER.debug("Encoding matter registry packets took ${time.millis}ms, (${totalSize} bytes total, $compressedSize bytes compressed)")
|
||||
|
||||
for (chunk in chunks) {
|
||||
distributor.invoke(chunk)
|
||||
/**
|
||||
* Delay sending by one server tick;
|
||||
* this way client is guaranteed to be in "PLAY" state, with local player present.
|
||||
* This hack is required because we manually compressing and splitting packet between multiple payloads,
|
||||
* hence it is impossible to "read" parsed data from network directly, using provided RegistryFriendlyByteBuf.
|
||||
*/
|
||||
onceServer {
|
||||
for (chunk in chunks) {
|
||||
distributor.invoke(chunk)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user