From 0884cb61dd9174240d22edc346aeba9d3f13c61d Mon Sep 17 00:00:00 2001 From: DarkGuardsman Date: Fri, 20 Sep 2013 13:48:57 -0400 Subject: [PATCH] Added solar panel --- models/SolarPanelSingle.tcn | Bin 0 -> 782 bytes .../assets/dark/languages/en_US.properties | 15 +++- .../dark/textures/models/SolarPanel.png | Bin 0 -> 776 bytes src/dark/core/client/ClientProxy.java | 18 +++- .../core/client/models/ModelSolarPanel.java | 82 ++++++++++++++++++ .../client/renders/BlockRenderingHandler.java | 57 ++++++++++++ .../client/renders/RenderBlockSolarPanel.java | 37 ++++++++ src/dark/core/common/DarkMain.java | 5 +- .../core/common/machines/BlockSolarPanel.java | 56 ++++++++++++ .../common/machines/TileEntitySolarPanel.java | 50 +++++++++++ ...tityUser.java => BlockTileEntityInfo.java} | 2 +- .../core/registration/ModObjectRegistry.java | 35 ++++---- 12 files changed, 335 insertions(+), 22 deletions(-) create mode 100644 models/SolarPanelSingle.tcn create mode 100644 resources/assets/dark/textures/models/SolarPanel.png create mode 100644 src/dark/core/client/models/ModelSolarPanel.java create mode 100644 src/dark/core/client/renders/BlockRenderingHandler.java create mode 100644 src/dark/core/client/renders/RenderBlockSolarPanel.java create mode 100644 src/dark/core/common/machines/BlockSolarPanel.java create mode 100644 src/dark/core/common/machines/TileEntitySolarPanel.java rename src/dark/core/registration/{TileEntityUser.java => BlockTileEntityInfo.java} (94%) diff --git a/models/SolarPanelSingle.tcn b/models/SolarPanelSingle.tcn new file mode 100644 index 0000000000000000000000000000000000000000..7283f59f4a2cfbe07784040d0dbe4be7d7a480e4 GIT binary patch literal 782 zcmWIWW@Zs#U|`^2IF(}JJpaAY!XPFFh7JJ+22KVQhTQy=)EvEv+#D_j1)w4Z21W)6 zhIbwdFUW5@$B0h9oe`LS%Ru1xef782E|q*USem+@xV`F%3YC)9%9!;nZ4!41H)oO0 z^>>%wze&ksdYd5B`>jDqq5S*zpGkF_EN{ph3T3+{F5o&TefqZRU*A0VYkfK?JbLFT z*AKkg;w4w|$VwD*UT6AX%O$ZgI#r@8Kt;OqWyp@SmmgI66?DJ+l|Mb{gT{6yy|Q=hIJoV&>&6i)~DaJR8_#bQDce5-1z$Aa^IqFge zFBB)=lKg4%jz?@tnV4RC-}UZ8E5r-EYOilI+UNF`>GJKZE?JqIQqG=L-Yc@>)HF>I z$MXld!}E{-y|vp_pF*)Nt=P7LXO{Pk+Fl)H1; z{L{yzq;@ZyrMh2XLEq~Dw=cEIR{9TDuey*qYn@b>OK~aJ1tX67IgZ(kCap8edD7l_ z8c18sdn|wKjJr&x_JZ6iY}IOS-+C_YGO3zieBGWi{oR3=*6$w7;9dKE8`CYP43M9XcP{lQ@SZyF~0$h;N5Dm)7MY_KH~ti?z>ml+7qGEsfk< z{_w%+E5X|H1n(+Ok2PPp^=|#i^UIjzgnm?Rf98GQ-QL8ora#s#Mf$FHN?R4Ky+MkP#Q5-VMf) zc9?5E*W~X6x5S_Eo2D&!*==&GX2(o4lDoNx3B-&etuO{3A=w%$i-K`uWn{I zckf%oj-3(c?Hus34u!m%C4n>`B9=rZ3{zr-t(T>{oV2VlzRKi_oG*^ zfSmYDqCWVQLF(-K(!X(>ypFu#R^g>}rGC%z&VQAu|MXjh_kYm5y|OF5?wBgKPX5~; zzu(2ycmM8+uF>~u&<@=AP``q8h@UxQSCOS&6Y=BNvCaMC0XMw^!X__u<_7Q_P^V zu<^Gk6#;6fiA#$l`EV^qf%Gk~b4R>{*KX%y#iRS-87eN|4UHx3vIVCg!03jbwe*gdg literal 0 HcmV?d00001 diff --git a/src/dark/core/client/ClientProxy.java b/src/dark/core/client/ClientProxy.java index d90dde3a1..52f34b01d 100644 --- a/src/dark/core/client/ClientProxy.java +++ b/src/dark/core/client/ClientProxy.java @@ -8,15 +8,20 @@ import net.minecraft.world.World; import universalelectricity.core.vector.Vector3; import cpw.mods.fml.client.FMLClientHandler; import cpw.mods.fml.client.registry.ClientRegistry; +import cpw.mods.fml.client.registry.RenderingRegistry; import cpw.mods.fml.common.FMLCommonHandler; import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.SideOnly; +import dark.core.client.renders.BlockRenderingHandler; import dark.core.client.renders.RenderBlockWire; +import dark.core.client.renders.RenderBlockSolarPanel; import dark.core.common.CommonProxy; import dark.core.common.CoreRecipeLoader; +import dark.core.common.DarkMain; import dark.core.common.machines.TileEntityBatteryBox; import dark.core.common.machines.TileEntityCoalGenerator; import dark.core.common.machines.TileEntityElectricFurnace; +import dark.core.common.machines.TileEntitySolarPanel; import dark.core.common.transmit.TileEntityWire; import dark.core.prefab.ModPrefab; @@ -25,7 +30,7 @@ public class ClientProxy extends CommonProxy { /** Renders a laser beam from one power to another by a set color for a set time - * + * * @param world - world this laser is to be rendered in * @param position - start vector3 * @param target - end vector3 @@ -40,6 +45,13 @@ public class ClientProxy extends CommonProxy } } + @Override + public void preInit() + { + RenderingRegistry.registerBlockHandler(new BlockRenderingHandler()); + //MinecraftForge.EVENT_BUS.register(SoundHandler.INSTANCE); + } + @Override public void init() { @@ -47,6 +59,10 @@ public class ClientProxy extends CommonProxy { ClientRegistry.bindTileEntitySpecialRenderer(TileEntityWire.class, new RenderBlockWire()); } + if (DarkMain.blockSolar != null) + { + ClientRegistry.bindTileEntitySpecialRenderer(TileEntitySolarPanel.class, new RenderBlockSolarPanel()); + } } @Override diff --git a/src/dark/core/client/models/ModelSolarPanel.java b/src/dark/core/client/models/ModelSolarPanel.java new file mode 100644 index 000000000..bbca9fbee --- /dev/null +++ b/src/dark/core/client/models/ModelSolarPanel.java @@ -0,0 +1,82 @@ +// Date: 9/20/2013 12:38:02 PM +// Template version 1.1 +// Java generated by Techne +// Keep in mind that you still need to fill in some blanks +// - ZeuX + +package dark.core.client.models; + +import net.minecraft.client.model.ModelBase; +import net.minecraft.client.model.ModelRenderer; + +public class ModelSolarPanel extends ModelBase +{ + //fields + ModelRenderer base; + ModelRenderer neck; + ModelRenderer panel; + ModelRenderer brace; + ModelRenderer braceLeft; + ModelRenderer braceRight; + + public ModelSolarPanel() + { + textureWidth = 128; + textureHeight = 128; + + base = new ModelRenderer(this, 0, 0); + base.addBox(-3.5F, 0F, -3.5F, 7, 1, 7); + base.setRotationPoint(0F, 23F, 0F); + base.setTextureSize(128, 128); + base.mirror = true; + setRotation(base, 0F, 0F, 0F); + neck = new ModelRenderer(this, 57, 17); + neck.addBox(-3F, 0F, -2.5F, 6, 2, 5); + neck.setRotationPoint(0F, 21F, 0F); + neck.setTextureSize(128, 128); + neck.mirror = true; + setRotation(neck, 0F, 0F, 0F); + panel = new ModelRenderer(this, 0, 31); + panel.addBox(-7F, 0F, -7F, 14, 3, 14); + panel.setRotationPoint(0F, 15F, 0F); + panel.setTextureSize(128, 128); + panel.mirror = true; + setRotation(panel, 0F, 0F, 0F); + brace = new ModelRenderer(this, 9, 16); + brace.addBox(-8F, 0F, -3F, 16, 2, 6); + brace.setRotationPoint(0F, 19F, 0F); + brace.setTextureSize(128, 128); + brace.mirror = true; + setRotation(brace, 0F, 0F, 0F); + braceLeft = new ModelRenderer(this, 57, 0); + braceLeft.addBox(7F, 0F, -3F, 1, 3, 6); + braceLeft.setRotationPoint(0F, 16F, 0F); + braceLeft.setTextureSize(128, 128); + braceLeft.mirror = true; + setRotation(braceLeft, 0F, 0F, 0F); + braceRight = new ModelRenderer(this, 39, 0); + braceRight.addBox(-8F, 0F, -3F, 1, 3, 6); + braceRight.setRotationPoint(0F, 16F, 0F); + braceRight.setTextureSize(128, 128); + braceRight.mirror = true; + setRotation(braceRight, 0F, 0F, 0F); + } + + public void render(float f5) + { + base.render(f5); + neck.render(f5); + panel.render(f5); + brace.render(f5); + braceLeft.render(f5); + braceRight.render(f5); + } + + private void setRotation(ModelRenderer model, float x, float y, float z) + { + model.rotateAngleX = x; + model.rotateAngleY = y; + model.rotateAngleZ = z; + } + +} diff --git a/src/dark/core/client/renders/BlockRenderingHandler.java b/src/dark/core/client/renders/BlockRenderingHandler.java new file mode 100644 index 000000000..eb0fbfe5d --- /dev/null +++ b/src/dark/core/client/renders/BlockRenderingHandler.java @@ -0,0 +1,57 @@ +package dark.core.client.renders; + +import net.minecraft.block.Block; +import net.minecraft.client.renderer.RenderBlocks; +import net.minecraft.util.ResourceLocation; +import net.minecraft.world.IBlockAccess; + +import org.lwjgl.opengl.GL11; + +import cpw.mods.fml.client.FMLClientHandler; +import cpw.mods.fml.client.registry.ISimpleBlockRenderingHandler; +import cpw.mods.fml.client.registry.RenderingRegistry; +import cpw.mods.fml.relauncher.Side; +import cpw.mods.fml.relauncher.SideOnly; +import dark.core.client.models.ModelSolarPanel; +import dark.core.common.DarkMain; +import dark.core.prefab.ModPrefab; + +@SideOnly(Side.CLIENT) +public class BlockRenderingHandler implements ISimpleBlockRenderingHandler +{ + public static BlockRenderingHandler instance = new BlockRenderingHandler(); + public static final int BLOCK_RENDER_ID = RenderingRegistry.getNextAvailableRenderId(); + private static ModelSolarPanel solarPanelModel = new ModelSolarPanel(); + + @Override + public void renderInventoryBlock(Block block, int metadata, int modelID, RenderBlocks renderer) + { + GL11.glPushMatrix(); + if (DarkMain.blockSolar != null && block.blockID == DarkMain.blockSolar.blockID) + { + FMLClientHandler.instance().getClient().renderEngine.func_110577_a(new ResourceLocation(DarkMain.getInstance().DOMAIN, ModPrefab.MODEL_DIRECTORY + "solarPanel.png")); + GL11.glTranslatef(0.0F, 1.5F, 0.0F); + GL11.glRotatef(180f, 0f, 0f, 1f); + solarPanelModel.render(0.0625F); + } + GL11.glPopMatrix(); + } + + @Override + public boolean renderWorldBlock(IBlockAccess world, int x, int y, int z, Block block, int modelId, RenderBlocks renderer) + { + return false; + } + + @Override + public boolean shouldRender3DInInventory() + { + return true; + } + + @Override + public int getRenderId() + { + return BLOCK_RENDER_ID; + } +} diff --git a/src/dark/core/client/renders/RenderBlockSolarPanel.java b/src/dark/core/client/renders/RenderBlockSolarPanel.java new file mode 100644 index 000000000..09605a780 --- /dev/null +++ b/src/dark/core/client/renders/RenderBlockSolarPanel.java @@ -0,0 +1,37 @@ +package dark.core.client.renders; + +import net.minecraft.tileentity.TileEntity; +import net.minecraft.util.ResourceLocation; + +import org.lwjgl.opengl.GL11; + +import cpw.mods.fml.relauncher.Side; +import cpw.mods.fml.relauncher.SideOnly; +import dark.core.client.models.ModelSolarPanel; +import dark.core.common.DarkMain; + +@SideOnly(Side.CLIENT) +public class RenderBlockSolarPanel extends RenderTileMachine +{ + private static final ResourceLocation solarPanelTexture = new ResourceLocation(DarkMain.getInstance().DOMAIN, DarkMain.MODEL_DIRECTORY + "SolarPanel.png"); + + public static final ModelSolarPanel model = new ModelSolarPanel(); + + @Override + public void renderTileEntityAt(TileEntity tileEntity, double d, double d1, double d2, float f) + { + // Texture file + this.bindTextureByName(this.getTexture(tileEntity.getBlockType().blockID, tileEntity.getBlockMetadata())); + GL11.glPushMatrix(); + GL11.glTranslatef((float) d + 0.5F, (float) d1 + 1.5F, (float) d2 + 0.5F); + GL11.glScalef(1.0F, -1F, -1F); + model.render(0.0625F); + GL11.glPopMatrix(); + } + + @Override + public ResourceLocation getTexture(int block, int meta) + { + return solarPanelTexture; + } +} \ No newline at end of file diff --git a/src/dark/core/common/DarkMain.java b/src/dark/core/common/DarkMain.java index 2e6e0583e..7d0a4e730 100644 --- a/src/dark/core/common/DarkMain.java +++ b/src/dark/core/common/DarkMain.java @@ -48,6 +48,7 @@ import dark.core.common.items.ItemParts.Parts; import dark.core.common.items.ItemTools; import dark.core.common.items.ItemWrench; import dark.core.common.machines.BlockBasicMachine; +import dark.core.common.machines.BlockSolarPanel; import dark.core.common.transmit.BlockWire; import dark.core.network.PacketHandler; import dark.core.prefab.ModPrefab; @@ -87,7 +88,7 @@ public class DarkMain extends ModPrefab public static boolean overPressureDamage; public static BlockMulti blockMulti; - public static Block basicMachine; + public static Block basicMachine, blockSolar; @Instance(MOD_ID) private static DarkMain instance; @@ -196,6 +197,8 @@ public class DarkMain extends ModPrefab CoreRecipeLoader.blockColorSand = ModObjectRegistry.createNewBlock("DMBlockColorSand", DarkMain.MOD_ID, BlockColorSand.class, ItemBlockColored.class); CoreRecipeLoader.blockBasalt = ModObjectRegistry.createNewBlock("DMBlockBasalt", DarkMain.MOD_ID, BlockBasalt.class, ItemBlockColored.class); CoreRecipeLoader.blockGlowGlass = ModObjectRegistry.createNewBlock("DMBlockGlowGlass", DarkMain.MOD_ID, BlockColorGlowGlass.class, ItemBlockColored.class); + blockSolar = ModObjectRegistry.createNewBlock("DMBlockSolar", DarkMain.MOD_ID, BlockSolarPanel.class, ItemBlockHolder.class); + /* ITEMS */ CoreRecipeLoader.itemTool = new ItemTools(ITEM_ID_PREFIX++, DarkMain.CONFIGURATION); diff --git a/src/dark/core/common/machines/BlockSolarPanel.java b/src/dark/core/common/machines/BlockSolarPanel.java new file mode 100644 index 000000000..6dea0d15a --- /dev/null +++ b/src/dark/core/common/machines/BlockSolarPanel.java @@ -0,0 +1,56 @@ +package dark.core.common.machines; + +import net.minecraft.tileentity.TileEntity; +import net.minecraft.world.World; +import net.minecraftforge.common.Configuration; +import universalelectricity.core.UniversalElectricity; +import dark.core.client.renders.BlockRenderingHandler; +import dark.core.common.DMCreativeTab; +import dark.core.prefab.machine.BlockMachine; +import dark.core.registration.BlockConfigFile; +import dark.core.registration.ModObjectRegistry.BlockBuildData; +import dark.core.registration.BlockTileEntityInfo; + +@BlockTileEntityInfo(tileEntities = { TileEntitySolarPanel.class }, tileEntitiesNames = { "DMSolarCell" }) +public class BlockSolarPanel extends BlockMachine +{ + public static float tickRate = 10; + public static float wattPerLightValue = .012f; + + public BlockSolarPanel() + { + super(new BlockBuildData(BlockSolarPanel.class, "BlockSolarPanel", UniversalElectricity.machine)); + this.setBlockBounds(0, 0, 0, 1f, .3f, 1f); + this.setCreativeTab(DMCreativeTab.tabIndustrial); + } + + @BlockConfigFile + public void loadBlockConfig(Configuration config) + { + tickRate = config.get("settings", "PanelUpdateRate", tickRate).getInt(); + wattPerLightValue = (config.get("settings", "WattPerLightvalue", (int) wattPerLightValue * 1000, "Value * 15 equals full output").getInt() / 1000); + } + + public TileEntity createNewTileEntity(World world) + { + return new TileEntitySolarPanel(); + } + + @Override + public boolean isOpaqueCube() + { + return false; + } + + @Override + public boolean renderAsNormalBlock() + { + return false; + } + + @Override + public int getRenderType() + { + return BlockRenderingHandler.BLOCK_RENDER_ID; + } +} diff --git a/src/dark/core/common/machines/TileEntitySolarPanel.java b/src/dark/core/common/machines/TileEntitySolarPanel.java new file mode 100644 index 000000000..978caf5b4 --- /dev/null +++ b/src/dark/core/common/machines/TileEntitySolarPanel.java @@ -0,0 +1,50 @@ +package dark.core.common.machines; + +import java.util.EnumSet; + +import universalelectricity.core.electricity.ElectricityPack; + +import net.minecraft.item.ItemStack; +import net.minecraftforge.common.ForgeDirection; +import dark.core.prefab.machine.TileEntityEnergyMachine; + +public class TileEntitySolarPanel extends TileEntityEnergyMachine +{ + public TileEntitySolarPanel() + { + this.MAX_WATTS = 1; + } + + public void updateEntity() + { + super.updateEntity(); + if (this.ticks % BlockSolarPanel.tickRate == 0) + { + this.produceAllSides(); + } + + } + + public EnumSet getOutputDirections() + { + return EnumSet.of(ForgeDirection.DOWN); + } + + @Override + public void discharge(ItemStack itemStack) + { + + } + + @Override + public float getRequest(ForgeDirection direction) + { + return 0; + } + + @Override + public float receiveElectricity(ElectricityPack receive, boolean doReceive) + { + return 0; + } +} diff --git a/src/dark/core/registration/TileEntityUser.java b/src/dark/core/registration/BlockTileEntityInfo.java similarity index 94% rename from src/dark/core/registration/TileEntityUser.java rename to src/dark/core/registration/BlockTileEntityInfo.java index cc9b8ca31..ff4ff17c0 100644 --- a/src/dark/core/registration/TileEntityUser.java +++ b/src/dark/core/registration/BlockTileEntityInfo.java @@ -9,7 +9,7 @@ import net.minecraft.tileentity.TileEntity; @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) -public @interface TileEntityUser +public @interface BlockTileEntityInfo { /** Array of tile entities this tile uses. Is a parallel array in combo with tileEntitiesName */ Class[] tileEntities() default {}; diff --git a/src/dark/core/registration/ModObjectRegistry.java b/src/dark/core/registration/ModObjectRegistry.java index b63144b31..4e00252b8 100644 --- a/src/dark/core/registration/ModObjectRegistry.java +++ b/src/dark/core/registration/ModObjectRegistry.java @@ -26,7 +26,7 @@ import dark.core.prefab.helpers.Pair; import dark.core.prefab.machine.BlockMachine; /** Handler to make registering all parts of a mod's objects that are loaded into the game by forge - * + * * @author DarkGuardsman */ public class ModObjectRegistry { @@ -126,20 +126,18 @@ public class ModObjectRegistry { if (block != null) { - // Read block class annotions - for (Annotation annotian : block.getClass().getDeclaredAnnotations()) + BlockTileEntityInfo blockTileEntityInfo = block.getClass().getAnnotation(BlockTileEntityInfo.class); + if (blockTileEntityInfo != null) { - if (annotian instanceof TileEntityUser) - { - Class[] tileEntities = ((TileEntityUser) annotian).tileEntities(); - String[] tileEntitiesNames = ((TileEntityUser) annotian).tileEntitiesNames(); + System.out.println("\n\n\n\n[ModObjectRegistry] Reading tile entities for " + block.getUnlocalizedName()); + Class[] tileEntities = blockTileEntityInfo.tileEntities(); + String[] tileEntitiesNames = blockTileEntityInfo.tileEntitiesNames(); - if (tileEntities != null && tileEntities.length > 0 && tileEntitiesNames != null && tileEntitiesNames.length > 0) + if (tileEntities != null && tileEntities.length > 0 && tileEntitiesNames != null && tileEntitiesNames.length > 0) + { + for (int i = 0; i < tileEntities.length && i < tileEntitiesNames.length; i++) { - for (int i = 0; i < tileEntities.length && i < tileEntitiesNames.length; i++) - { - GameRegistry.registerTileEntityWithAlternatives(tileEntities[i], tileEntitiesNames[i], "DM" + tileEntitiesNames[i]); - } + GameRegistry.registerTileEntityWithAlternatives(tileEntities[i], tileEntitiesNames[i], "DM" + tileEntitiesNames[i]); } } } @@ -147,10 +145,14 @@ public class ModObjectRegistry // Read threw the block class looking for annotions on fields for (Method method : block.getClass().getMethods()) { + System.out.println("[ModObjectRegistry] Reading class methods " + method.toGenericString()); for (Annotation annotian : method.getDeclaredAnnotations()) { + System.out.println("[ModObjectRegistry] Reading annotion " + annotian.toString()); if (annotian instanceof BlockConfigFile) { + + System.out.println("[ModObjectRegistry] Loading config file for " + block.getUnlocalizedName()); Type[] types = method.getParameterTypes(); if (types.length == 1 && types[0] instanceof Configuration) { @@ -159,7 +161,7 @@ public class ModObjectRegistry try { method.setAccessible(true); - method.invoke(null, extraBlockConfig); + method.invoke(extraBlockConfig); } catch (IllegalAccessException e) { @@ -176,6 +178,7 @@ public class ModObjectRegistry extraBlockConfig.save(); } + break; } } } @@ -245,10 +248,6 @@ public class ModObjectRegistry { if (block != null && name != null) { - - System.out.println("Block: " + (block == null ? "null" : block.toString())); - System.out.println("Item: " + (itemClass == null ? "null" : itemClass.toString())); - System.out.println("name: " + name.toString()); GameRegistry.registerBlock(block, itemClass == null ? ItemBlock.class : itemClass, name, modID); } } @@ -304,7 +303,7 @@ public class ModObjectRegistry } /** Adds a tileEntity to be registered when this block is registered - * + * * @param name - mod name for the tileEntity, should be unique * @param class1 - new instance of the TileEntity to register */ public BlockBuildData addTileEntity(String name, Class class1)