package makamys.lodmod; import net.minecraft.client.Minecraft; import net.minecraft.client.gui.FontRenderer; import net.minecraft.client.gui.ScaledResolution; import net.minecraft.client.renderer.entity.RenderManager; import net.minecraft.potion.Potion; import net.minecraftforge.client.event.EntityViewRenderEvent; import net.minecraftforge.client.event.RenderGameOverlayEvent; import net.minecraftforge.client.event.RenderGameOverlayEvent.ElementType; import net.minecraftforge.common.MinecraftForge; import net.minecraftforge.common.config.Configuration; import net.minecraftforge.event.world.ChunkEvent; import net.minecraftforge.event.world.WorldEvent; import java.io.File; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.lwjgl.opengl.GL11; import cpw.mods.fml.common.FMLCommonHandler; import cpw.mods.fml.common.Mod; import cpw.mods.fml.common.Mod.EventHandler; import cpw.mods.fml.common.event.FMLInitializationEvent; import cpw.mods.fml.common.event.FMLPreInitializationEvent; import cpw.mods.fml.common.eventhandler.SubscribeEvent; import cpw.mods.fml.common.gameevent.TickEvent; import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.SideOnly; import makamys.lodmod.renderer.LODRenderer; import makamys.lodmod.util.SpriteUtil; @Mod(modid = LODMod.MODID, version = LODMod.VERSION) public class LODMod { public static final String MODID = "lodmod"; public static final String VERSION = "0.0"; public static final Logger LOGGER = LogManager.getLogger("lodmod"); public static LODRenderer renderer; public static int chunkLoadsPerTick; private File configFile; @EventHandler public void preInit(FMLPreInitializationEvent event) { configFile = event.getSuggestedConfigurationFile(); reloadConfig(); } private void reloadConfig() { Configuration config = new Configuration(configFile); config.load(); chunkLoadsPerTick = config.get("Options", "chunkLoadsPerTick", 64).getInt(); if(config.hasChanged()) { config.save(); } } @EventHandler public void init(FMLInitializationEvent event) { FMLCommonHandler.instance().bus().register(this); MinecraftForge.EVENT_BUS.register(this); } @SubscribeEvent public void onWorldLoad(WorldEvent.Load event) { if(!event.world.isRemote) return; SpriteUtil.init(); if(renderer != null) { LOGGER.warn("Renderer didn't get destroyed last time"); renderer.destroy(); } reloadConfig(); renderer = new LODRenderer(); } @SubscribeEvent public void onWorldUnload(WorldEvent.Unload event) { if(!event.world.isRemote) return; if(renderer != null) { renderer.destroy(); renderer = null; } } @SubscribeEvent public void onChunkLoad(ChunkEvent.Load event) { if(!event.world.isRemote) return; if(isActive()) { renderer.onChunkLoad(event); } } public static boolean isActive() { return renderer != null && renderer.hasInited; } @SubscribeEvent public void onWorldUnload(TickEvent.ServerTickEvent event) { if(event.phase == TickEvent.Phase.START) { if(isActive()) { renderer.serverTick(); } } } @SubscribeEvent public void onRenderOverlay(RenderGameOverlayEvent event) { FontRenderer fontRenderer = RenderManager.instance.getFontRenderer(); if(isActive() && event.type == ElementType.TEXT && fontRenderer != null && Minecraft.getMinecraft().gameSettings.showDebugInfo) { Minecraft mc = Minecraft.getMinecraft(); ScaledResolution scaledresolution = new ScaledResolution(mc, mc.displayWidth, mc.displayHeight); int w = scaledresolution.getScaledWidth(); int h = scaledresolution.getScaledHeight(); int yOffset = 0; for(String s : renderer.getDebugText()) { fontRenderer.drawStringWithShadow(s, w - fontRenderer.getStringWidth(s) - 10, 80 + yOffset, 0xFFFFFF); yOffset += 10; } } } @SubscribeEvent public void onRenderFog(EntityViewRenderEvent.RenderFogEvent event) { if(isActive()) { if(event.fogMode >= 0 && !Minecraft.getMinecraft().theWorld.provider.doesXZShowFog((int)event.entity.posX, (int)event.entity.posZ)) { GL11.glFogf(GL11.GL_FOG_START, event.farPlaneDistance * 0.2f); GL11.glFogf(GL11.GL_FOG_END, event.farPlaneDistance); } } } }