From 2919094cbf880f852b2349192a48c344ba82d3b2 Mon Sep 17 00:00:00 2001 From: HbmMods Date: Thu, 15 Mar 2018 22:34:01 +0100 Subject: [PATCH] cheapo texture + recipe, potatos --- assets/hbm/lang/de_DE.lang | 6 +++ assets/hbm/lang/en_US.lang | 6 +++ assets/hbm/textures/blocks/turret_cheapo.png | Bin 0 -> 290 bytes assets/hbm/textures/items/battery_potato.png | Bin 0 -> 466 bytes assets/hbm/textures/items/battery_potatos.png | Bin 0 -> 529 bytes .../hbm/textures/items/turret_cheapo_ammo.png | Bin 0 -> 286 bytes .../textures/models/turret_cheapo_head.png | Bin 5031 -> 6078 bytes com/hbm/blocks/ModBlocks.java | 4 +- com/hbm/blocks/bomb/NukeBoy.java | 2 +- com/hbm/blocks/bomb/NukeCustom.java | 6 +-- com/hbm/blocks/bomb/NukeGadget.java | 2 +- com/hbm/blocks/bomb/NukeMan.java | 2 +- com/hbm/blocks/bomb/NukeMike.java | 4 +- com/hbm/blocks/bomb/NukeTsar.java | 4 +- com/hbm/blocks/bomb/TurretCheapo.java | 9 ++-- com/hbm/blocks/machine/MachineRadar.java | 8 ++++ .../effect/EntityNukeCloudNoShroom.java | 2 +- .../entity/effect/EntityNukeCloudSmall.java | 11 ++--- .../entity/grenade/EntityGrenadeNuclear.java | 6 +-- com/hbm/entity/missile/EntityMIRV.java | 2 +- com/hbm/entity/missile/EntityMissileMirv.java | 2 +- .../entity/missile/EntityMissileNuclear.java | 3 +- com/hbm/entity/mob/EntityNuclearCreeper.java | 2 +- com/hbm/inventory/MachineRecipes.java | 10 ++++ com/hbm/inventory/gui/GUIMachineRadar.java | 43 +++++++++++++++++- com/hbm/items/ModItems.java | 9 ++++ com/hbm/items/tool/ItemAssemblyTemplate.java | 3 ++ com/hbm/items/tool/ItemTurretBiometry.java | 4 +- com/hbm/items/tool/ItemTurretChip.java | 4 +- com/hbm/lib/Library.java | 10 ++++ com/hbm/lib/RefStrings.java | 2 +- com/hbm/main/CraftingManager.java | 6 +++ com/hbm/main/MainRegistry.java | 13 ++++++ com/hbm/packet/TERadarPacket.java | 8 +++- com/hbm/render/entity/RenderSmallNukeAlt.java | 2 +- com/hbm/render/entity/RenderSmallNukeMK3.java | 5 +- .../bomb/TileEntityTurretCheapo.java | 2 - .../machine/TileEntityMachineRadar.java | 26 +++++------ 38 files changed, 170 insertions(+), 58 deletions(-) create mode 100644 assets/hbm/textures/blocks/turret_cheapo.png create mode 100644 assets/hbm/textures/items/battery_potato.png create mode 100644 assets/hbm/textures/items/battery_potatos.png create mode 100644 assets/hbm/textures/items/turret_cheapo_ammo.png diff --git a/assets/hbm/lang/de_DE.lang b/assets/hbm/lang/de_DE.lang index 207cb21b9..703799b82 100644 --- a/assets/hbm/lang/de_DE.lang +++ b/assets/hbm/lang/de_DE.lang @@ -199,11 +199,13 @@ tile.turret_flamer.name=Flammenwerfergeschütz tile.turret_tau.name=Tauonengeschütz tile.turret_spitfire.name=Geschütz für das ich noch keinen Namen habe [WIP] tile.turret_cwis.name=Phalanx Mk-15 CIWS +tile.turret_cheapo.name=Billigsdorfer Gatling-Geschütz tile.machine_radar.name=Radar container.radar=Radar item.turret_control.name=Geschützsteuerung item.turret_chip.name=Geschütz-KI-Chip +item.turret_biometry.name=Geschütz-Telemetriekarte tile.bomb_multi.name=Mehrzweckbombe tile.rejuvinator.name=Regenerationsmaschine @@ -652,6 +654,9 @@ item.battery_creative.name=Unendliche Batterie item.battery_su.name=Einwegbatterie item.battery_su_l.name=Große Einwegbatterie +item.battery_potato.name=Katoffelbatterie +item.battery_potatos.name=PotatOS + item.battery_red_cell.name=Redstone-Energiezelle item.battery_advanced_cell.name=Fortgeschrittene Energiezelle item.battery_lithium_cell.name=Lithium-Ionen-Energiezelle @@ -1059,6 +1064,7 @@ item.turret_flamer_ammo.name=Flammenwerfergeschütz-Tanks item.turret_tau_ammo.name=Tauonengeschütz-Uranmunition item.turret_spitfire_ammo.name=AA-Geschoss item.turret_cwis_ammo.name=CIWS 20mm Munitionstrommel +item.turret_cheapo_ammo.name=6x24 Billigsdorfer-Munition item.clip_revolver_iron.name=Box voll Eisenkugeln item.clip_revolver.name=.357 Magnum Patronen diff --git a/assets/hbm/lang/en_US.lang b/assets/hbm/lang/en_US.lang index b31a36503..0eac93781 100644 --- a/assets/hbm/lang/en_US.lang +++ b/assets/hbm/lang/en_US.lang @@ -211,11 +211,13 @@ tile.turret_flamer.name=Flamethrower Turret tile.turret_tau.name=Tauon Turret tile.turret_spitfire.name=Turret I have no name for right now [WIP] tile.turret_cwis.name=Phalanx Mk-15 CIWS +tile.turret_cheapo.name=Cheapo Gatling Sentry tile.machine_radar.name=Radar container.radar=Radar item.turret_control.name=Turret Controller item.turret_chip.name=Turret AI-Chip +item.turret_biometry.name=Turret Telemetry Card tile.crate.name=Supply Crate tile.marker_structure.name=Multiblock Structure Marker @@ -655,6 +657,9 @@ item.battery_creative.name=Infinite Battery item.battery_su.name=SU-Battery item.battery_su_l.name=Large SU-Battery +item.battery_potato.name=Potato Battery +item.battery_potatos.name=PotatOS + item.battery_red_cell.name=Redstone Power Cell item.battery_advanced_cell.name=Advanced Power Cell item.battery_lithium_cell.name=Lithium-Ion Power Cell @@ -1062,6 +1067,7 @@ item.turret_flamer_ammo.name=Flamer Turret Fuel Tanks item.turret_tau_ammo.name=Tau Turret Uranium Ammo item.turret_spitfire_ammo.name=AA-Shell item.turret_cwis_ammo.name=CIWS 20mm Ammo Drum +item.turret_cheapo_ammo.name=6x24 Cheapo Turret Ammunition item.clip_revolver_iron.name=Box of Iron Rounds item.clip_revolver.name=Box of .357 Rounds diff --git a/assets/hbm/textures/blocks/turret_cheapo.png b/assets/hbm/textures/blocks/turret_cheapo.png new file mode 100644 index 0000000000000000000000000000000000000000..b47cd705ec722df4b1abbd99a18e8d47ca0e4b18 GIT binary patch literal 290 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`EX7WqAsj$Z!;#VfUOt~yzLfpHTw3pkt#^NIFXVZhDB%-1O>V*a>SP8zX@<&qkLT=OHQkuuxy-7r zjv2fStJ(~GgM;kveSg!p-cu`-_p>;IAg90J#3gce`}fW}mlElA*@SI@2G@L!JI(XX zG4x!tKhnm3FzWT{Ri9p;VZBl+s~45M-o-4N>9dV}YRzRszb^qz%Z2}z?V6giQPyx_ m?(G)g^2M)r?cZ9=X+JeD`^|J0g*!k`GI+ZBxvXz%0OEppCD@9X`M3nc&c-MmW%zFKHVBoY8*=GtU16tTd} zW}5D)oaZZ3TOl5g%khpI{Gt_r$})r1#WaB z6BaskP3;t(Z@E0%=lbNxW>iuPSJ$^-6bfuD&j8RhG(j*F;raf`)^)xQ=`sM&A0GjT z^^ai~ujtubd}Za%snLC(vCSZ#*SI@aLMip~bh(39KCrcO3}B7#lv13Sqdpw2P|!6N zR`vi03*CY*PIHW=@VE>zn`xr49x6%|Ui9}}s0{@y*a@1l6*eZTBtT815#Zad#S7(f z1ehH_p4Z0-pG^a}VAm!(HJZYcNR-RYO!NbKvcB!BZTyqo0HzAEW#N?ZW&i*H07*qo IM6N<$f?D6tCjbBd literal 0 HcmV?d00001 diff --git a/assets/hbm/textures/items/battery_potatos.png b/assets/hbm/textures/items/battery_potatos.png new file mode 100644 index 0000000000000000000000000000000000000000..17ba30b8004212b00e1b07221fdd807644629dc6 GIT binary patch literal 529 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 Ef*E1-mH+?% literal 5031 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 diff --git a/com/hbm/blocks/ModBlocks.java b/com/hbm/blocks/ModBlocks.java index a023d5a40..eac4ab358 100644 --- a/com/hbm/blocks/ModBlocks.java +++ b/com/hbm/blocks/ModBlocks.java @@ -654,7 +654,7 @@ public class ModBlocks { machine_generator = new MachineGenerator(Material.iron).setBlockName("machine_generator").setHardness(5.0F).setResistance(10.0F).setCreativeTab(MainRegistry.tabBlock); machine_industrial_generator = new MachineIGenerator(Material.iron).setBlockName("machine_industrial_generator").setHardness(5.0F).setResistance(10.0F).setCreativeTab(MainRegistry.tabBlock).setBlockTextureName(RefStrings.MODID + ":industrial_generator"); machine_cyclotron = new MachineCyclotron(Material.iron).setBlockName("machine_cyclotron").setHardness(5.0F).setResistance(10.0F).setCreativeTab(MainRegistry.tabBlock).setBlockTextureName(RefStrings.MODID + ":cyclotron"); - machine_radgen = new MachineRadGen(Material.iron).setBlockName("machine_radgen").setHardness(5.0F).setResistance(10.0F).setCreativeTab(MainRegistry.tabBlock).setBlockTextureName(RefStrings.MODID + ":radgen"); + machine_radgen = new MachineRadGen(Material.iron).setBlockName("machine_radgen").setHardness(5.0F).setResistance(10.0F).setCreativeTab(MainRegistry.tabBlock).setBlockTextureName(RefStrings.MODID + ":code"); machine_electric_furnace_off = new MachineElectricFurnace(false).setBlockName("machine_electric_furnace_off").setHardness(5.0F).setResistance(10.0F).setCreativeTab(MainRegistry.tabBlock); machine_electric_furnace_on = new MachineElectricFurnace(true).setBlockName("machine_electric_furnace_on").setHardness(5.0F).setLightLevel(1.0F).setResistance(10.0F); @@ -755,7 +755,7 @@ public class ModBlocks { turret_rocket = new TurretRocket(Material.iron).setBlockName("turret_rocket").setHardness(5.0F).setResistance(10.0F).setCreativeTab(MainRegistry.tabNuke).setBlockTextureName(RefStrings.MODID + ":turret_rocket"); turret_flamer = new TurretFlamer(Material.iron).setBlockName("turret_flamer").setHardness(5.0F).setResistance(10.0F).setCreativeTab(MainRegistry.tabNuke).setBlockTextureName(RefStrings.MODID + ":turret_flamer"); turret_tau = new TurretTau(Material.iron).setBlockName("turret_tau").setHardness(5.0F).setResistance(10.0F).setCreativeTab(MainRegistry.tabNuke).setBlockTextureName(RefStrings.MODID + ":turret_tau"); - turret_spitfire = new TurretSpitfire(Material.iron).setBlockName("turret_spitfire").setHardness(5.0F).setResistance(10.0F).setCreativeTab(MainRegistry.tabNuke).setBlockTextureName(RefStrings.MODID + ":turret_spitfire"); + turret_spitfire = new TurretSpitfire(Material.iron).setBlockName("turret_spitfire").setHardness(5.0F).setResistance(10.0F).setCreativeTab(MainRegistry.tabNuke).setBlockTextureName(RefStrings.MODID + ":code"); turret_cwis = new TurretCIWS(Material.iron).setBlockName("turret_cwis").setHardness(5.0F).setResistance(10.0F).setCreativeTab(MainRegistry.tabNuke).setBlockTextureName(RefStrings.MODID + ":turret_cwis"); turret_cheapo = new TurretCheapo(Material.iron).setBlockName("turret_cheapo").setHardness(5.0F).setResistance(10.0F).setCreativeTab(MainRegistry.tabNuke).setBlockTextureName(RefStrings.MODID + ":turret_cheapo"); diff --git a/com/hbm/blocks/bomb/NukeBoy.java b/com/hbm/blocks/bomb/NukeBoy.java index e83abbe6e..08d7b6e2e 100644 --- a/com/hbm/blocks/bomb/NukeBoy.java +++ b/com/hbm/blocks/bomb/NukeBoy.java @@ -152,7 +152,7 @@ public class NukeBoy extends BlockContainer implements IBomb { // ExplosionNukeAdvanced.mush(world, x, y, z); if (MainRegistry.enableNukeClouds) { - EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000); + EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000, MainRegistry.boyRadius * 0.005F); entity2.posX = x; entity2.posY = y; entity2.posZ = z; diff --git a/com/hbm/blocks/bomb/NukeCustom.java b/com/hbm/blocks/bomb/NukeCustom.java index 28967d98a..bf2bdcab6 100644 --- a/com/hbm/blocks/bomb/NukeCustom.java +++ b/com/hbm/blocks/bomb/NukeCustom.java @@ -199,7 +199,7 @@ public class NukeCustom extends BlockContainer implements IBomb { ExplosionParticleB.spawnMush(world, x, y - ((int)amat / 10), z); } else if(amat < 200) { if(MainRegistry.enableNukeClouds) { - EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000); + EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000, amat * 0.005F); entity2.posX = x; entity2.posY = y - (amat/10); entity2.posZ = z; @@ -249,7 +249,7 @@ public class NukeCustom extends BlockContainer implements IBomb { ExplosionParticle.spawnMush(world, x, y - ((int)hydro / 10), z); } else if(hydro < 200) { if(MainRegistry.enableNukeClouds) { - EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000); + EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000, hydro * 0.005F); entity2.posX = x; entity2.posY = y - (hydro/10); entity2.posZ = z; @@ -298,7 +298,7 @@ public class NukeCustom extends BlockContainer implements IBomb { ExplosionParticle.spawnMush(world, x, y - ((int)nuke / 10), z); } else if(nuke < 200) { if(MainRegistry.enableNukeClouds) { - EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000); + EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000, nuke * 0.005F); entity2.posX = x; entity2.posY = y - (nuke/10); entity2.posZ = z; diff --git a/com/hbm/blocks/bomb/NukeGadget.java b/com/hbm/blocks/bomb/NukeGadget.java index 32427a361..08d20ae5c 100644 --- a/com/hbm/blocks/bomb/NukeGadget.java +++ b/com/hbm/blocks/bomb/NukeGadget.java @@ -165,7 +165,7 @@ public class NukeGadget extends BlockContainer implements IBomb { // ExplosionNukeAdvanced.mush(world, x, y, z); if (MainRegistry.enableNukeClouds) { - EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000); + EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000, MainRegistry.gadgetRadius * 0.005F); entity2.posX = x; entity2.posY = y; entity2.posZ = z; diff --git a/com/hbm/blocks/bomb/NukeMan.java b/com/hbm/blocks/bomb/NukeMan.java index 4c1ce9327..a95becd36 100644 --- a/com/hbm/blocks/bomb/NukeMan.java +++ b/com/hbm/blocks/bomb/NukeMan.java @@ -179,7 +179,7 @@ public class NukeMan extends BlockContainer implements IBomb { //ExplosionNukeAdvanced.mush(world, x, y, z); if (MainRegistry.enableNukeClouds) { - EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000); + EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000, MainRegistry.manRadius * 0.005F); entity2.posX = x; entity2.posY = y; entity2.posZ = z; diff --git a/com/hbm/blocks/bomb/NukeMike.java b/com/hbm/blocks/bomb/NukeMike.java index a627d3496..e957c0a2c 100644 --- a/com/hbm/blocks/bomb/NukeMike.java +++ b/com/hbm/blocks/bomb/NukeMike.java @@ -146,13 +146,13 @@ public class NukeMike extends BlockContainer implements IBomb { if (MainRegistry.enableNukeClouds) { if (r < 200) { - EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000); + EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000, r * 0.005F); entity2.posX = x; entity2.posY = y; entity2.posZ = z; world.spawnEntityInWorld(entity2); } else { - EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000); + EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000, r * 0.005F); entity2.posX = x; entity2.posY = y; entity2.posZ = z; diff --git a/com/hbm/blocks/bomb/NukeTsar.java b/com/hbm/blocks/bomb/NukeTsar.java index dfc969c83..1b0efa047 100644 --- a/com/hbm/blocks/bomb/NukeTsar.java +++ b/com/hbm/blocks/bomb/NukeTsar.java @@ -152,9 +152,9 @@ public class NukeTsar extends BlockContainer implements IBomb { //world.spawnParticle("hugeexplosion", x, y, z, 0, 0, 0); world.playSoundEffect(x, y, z, "random.explode", 1.0f, world.rand.nextFloat() * 0.1F + 0.9F); - world.spawnEntityInWorld(EntityNukeExplosionMK4.statFac(world, MainRegistry.tsarRadius, x + 0.5, y + 0.5, z + 0.5)); + world.spawnEntityInWorld(EntityNukeExplosionMK4.statFac(world, r, x + 0.5, y + 0.5, z + 0.5)); - EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000); + EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(world, 1000, r * 0.005F); entity2.posX = x; entity2.posY = y; entity2.posZ = z; diff --git a/com/hbm/blocks/bomb/TurretCheapo.java b/com/hbm/blocks/bomb/TurretCheapo.java index d63a7e633..2c0223415 100644 --- a/com/hbm/blocks/bomb/TurretCheapo.java +++ b/com/hbm/blocks/bomb/TurretCheapo.java @@ -38,7 +38,7 @@ public class TurretCheapo extends TurretBase { if(te.spin < 35) te.spin += 5; - if(te.spin > 25 && i % 4 == 0) { + if(te.spin > 25 && i % 2 == 0) { Vec3 vector = Vec3.createVectorHelper( -Math.sin(yaw / 180.0F * (float) Math.PI) * Math.cos(pitch / 180.0F * (float) Math.PI), -Math.sin(pitch / 180.0F * (float) Math.PI), @@ -56,7 +56,7 @@ public class TurretCheapo extends TurretBase { bullet.motionY = vector.yCoord * 3; bullet.motionZ = vector.zCoord * 3; - bullet.damage = rand.nextInt(11) + 10; + bullet.damage = rand.nextInt(11) + 5; world.spawnEntityInWorld(bullet); } @@ -72,7 +72,10 @@ public class TurretCheapo extends TurretBase { @Override public void executeReleaseAction(World world, int i, double yaw, double pitch, int x, int y, int z) { - world.playSoundEffect(x, y, z, "hbm:weapon.spindown", 1.0F, 1.0F); + TileEntityTurretCheapo te = (TileEntityTurretCheapo)world.getTileEntity(x, y, z); + + if(te.spin > 10) + world.playSoundEffect(x, y, z, "hbm:weapon.spindown", 1.0F, 1.0F); } } diff --git a/com/hbm/blocks/machine/MachineRadar.java b/com/hbm/blocks/machine/MachineRadar.java index 2af67732b..44efa35ac 100644 --- a/com/hbm/blocks/machine/MachineRadar.java +++ b/com/hbm/blocks/machine/MachineRadar.java @@ -12,6 +12,7 @@ import net.minecraft.block.BlockContainer; import net.minecraft.block.material.Material; import net.minecraft.entity.player.EntityPlayer; import net.minecraft.tileentity.TileEntity; +import net.minecraft.util.ChatComponentText; import net.minecraft.world.IBlockAccess; import net.minecraft.world.World; @@ -43,6 +44,13 @@ public class MachineRadar extends BlockContainer { @Override public boolean onBlockActivated(World world, int x, int y, int z, EntityPlayer player, int side, float hitX, float hitY, float hitZ) { + + if(y < MainRegistry.radarAltitude) { + if(world.isRemote) + player.addChatMessage(new ChatComponentText("[Radar] Error: Radar altitude not sufficient.")); + return true; + } + if(world.isRemote) { return true; diff --git a/com/hbm/entity/effect/EntityNukeCloudNoShroom.java b/com/hbm/entity/effect/EntityNukeCloudNoShroom.java index 3a069cbb1..03a70b810 100644 --- a/com/hbm/entity/effect/EntityNukeCloudNoShroom.java +++ b/com/hbm/entity/effect/EntityNukeCloudNoShroom.java @@ -9,7 +9,7 @@ public class EntityNukeCloudNoShroom extends EntityNukeCloudSmall { } public EntityNukeCloudNoShroom(World p_i1582_1_, int maxAge) { - super(p_i1582_1_, maxAge); + super(p_i1582_1_, maxAge, 1.0F); } } diff --git a/com/hbm/entity/effect/EntityNukeCloudSmall.java b/com/hbm/entity/effect/EntityNukeCloudSmall.java index 77fd17428..6937cc07c 100644 --- a/com/hbm/entity/effect/EntityNukeCloudSmall.java +++ b/com/hbm/entity/effect/EntityNukeCloudSmall.java @@ -11,7 +11,6 @@ public class EntityNukeCloudSmall extends Entity { public int maxAge = 1000; public int age; - public float scale = 1; public EntityNukeCloudSmall(World p_i1582_1_) { super(p_i1582_1_); @@ -34,11 +33,12 @@ public class EntityNukeCloudSmall extends Entity { return 1.0F; } - public EntityNukeCloudSmall(World p_i1582_1_, int maxAge) { + public EntityNukeCloudSmall(World p_i1582_1_, int maxAge, float scale) { super(p_i1582_1_); this.setSize(20, 40); this.isImmuneToFire = true; this.maxAge = maxAge; + this.dataWatcher.updateObject(18, scale); } @Override @@ -55,28 +55,27 @@ public class EntityNukeCloudSmall extends Entity { this.dataWatcher.updateObject(16, (short)maxAge); this.dataWatcher.updateObject(17, (short)age); - this.dataWatcher.updateObject(18, (float)scale); } @Override protected void entityInit() { this.dataWatcher.addObject(16, (short)maxAge); this.dataWatcher.addObject(17, (short)age); - this.dataWatcher.addObject(18, (float)scale); + this.dataWatcher.addObject(18, 1.0F); } @Override protected void readEntityFromNBT(NBTTagCompound p_70037_1_) { maxAge = p_70037_1_.getShort("maxAge"); age = p_70037_1_.getShort("age"); - scale = p_70037_1_.getShort("scale"); + this.dataWatcher.updateObject(18, p_70037_1_.getFloat("scale")); } @Override protected void writeEntityToNBT(NBTTagCompound p_70014_1_) { p_70014_1_.setShort("maxAge", (short)maxAge); p_70014_1_.setShort("age", (short)age); - p_70014_1_.setFloat("scale", (float)scale); + p_70014_1_.setFloat("scale", this.dataWatcher.getWatchableObjectFloat(18)); } diff --git a/com/hbm/entity/grenade/EntityGrenadeNuclear.java b/com/hbm/entity/grenade/EntityGrenadeNuclear.java index a9394a5bd..731ebac3f 100644 --- a/com/hbm/entity/grenade/EntityGrenadeNuclear.java +++ b/com/hbm/entity/grenade/EntityGrenadeNuclear.java @@ -43,12 +43,12 @@ public class EntityGrenadeNuclear extends EntityGrenadeBase entity0.speed = 25; entity0.coefficient = 10.0F;*/ - this.worldObj.spawnEntityInWorld(EntityNukeExplosionMK4.statFac(worldObj, MainRegistry.nukaRadius * 2, posX, posY, posZ)); + this.worldObj.spawnEntityInWorld(EntityNukeExplosionMK4.statFac(worldObj, MainRegistry.nukaRadius, posX, posY, posZ)); if(rand.nextInt(100) == 0) { - ExplosionParticleB.spawnMush(this.worldObj, (int)this.posX, (int)this.posY - 2, (int)this.posZ); + ExplosionParticleB.spawnMush(this.worldObj, (int)this.posX, (int)this.posY, (int)this.posZ); } else { - ExplosionParticle.spawnMush(this.worldObj, (int)this.posX, (int)this.posY - 2, (int)this.posZ); + ExplosionParticle.spawnMush(this.worldObj, (int)this.posX, (int)this.posY, (int)this.posZ); } } } diff --git a/com/hbm/entity/missile/EntityMIRV.java b/com/hbm/entity/missile/EntityMIRV.java index 7fda3018f..aee856ac0 100644 --- a/com/hbm/entity/missile/EntityMIRV.java +++ b/com/hbm/entity/missile/EntityMIRV.java @@ -42,7 +42,7 @@ public class EntityMIRV extends EntityThrowable { { worldObj.spawnEntityInWorld(EntityNukeExplosionMK4.statFac(worldObj, MainRegistry.mirvRadius, posX, posY, posZ)); - EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(this.worldObj, 1000); + EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(this.worldObj, 1000, MainRegistry.mirvRadius * 0.005F); entity2.posX = this.posX; entity2.posY = this.posY; entity2.posZ = this.posZ; diff --git a/com/hbm/entity/missile/EntityMissileMirv.java b/com/hbm/entity/missile/EntityMissileMirv.java index 72f6c6c73..eec502081 100644 --- a/com/hbm/entity/missile/EntityMissileMirv.java +++ b/com/hbm/entity/missile/EntityMissileMirv.java @@ -32,7 +32,7 @@ public class EntityMissileMirv extends EntityMissileBaseAdvanced { worldObj.spawnEntityInWorld(EntityNukeExplosionMK4.statFac(worldObj, MainRegistry.missileRadius, posX, posY, posZ)); - EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(this.worldObj, 1000); + EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(this.worldObj, 1000, MainRegistry.missileRadius * 0.005F); entity2.posX = this.posX; entity2.posY = this.posY - 9; entity2.posZ = this.posZ; diff --git a/com/hbm/entity/missile/EntityMissileNuclear.java b/com/hbm/entity/missile/EntityMissileNuclear.java index 2d930c809..4156ba3eb 100644 --- a/com/hbm/entity/missile/EntityMissileNuclear.java +++ b/com/hbm/entity/missile/EntityMissileNuclear.java @@ -37,11 +37,10 @@ public class EntityMissileNuclear extends EntityMissileBaseAdvanced { this.worldObj.spawnEntityInWorld(EntityNukeExplosionMK4.statFac(worldObj, MainRegistry.missileRadius, posX, posY, posZ)); - EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(this.worldObj, 1000); + EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(this.worldObj, 1000, MainRegistry.missileRadius * 0.005F); entity2.posX = this.posX; entity2.posY = this.posY/* - 9*/; entity2.posZ = this.posZ; - entity2.scale = 2F; entity2.getDataWatcher().updateObject(18, 2F); this.worldObj.spawnEntityInWorld(entity2); } diff --git a/com/hbm/entity/mob/EntityNuclearCreeper.java b/com/hbm/entity/mob/EntityNuclearCreeper.java index e7be3413e..9868d9ec2 100644 --- a/com/hbm/entity/mob/EntityNuclearCreeper.java +++ b/com/hbm/entity/mob/EntityNuclearCreeper.java @@ -458,7 +458,7 @@ public class EntityNuclearCreeper extends EntityMob { if(this.getPowered()) { - EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(this.worldObj, 1000); + EntityNukeCloudSmall entity2 = new EntityNukeCloudSmall(this.worldObj, 1000, explosionRadius * 0.005F); entity2.posX = this.posX; entity2.posY = this.posY; entity2.posZ = this.posZ; diff --git a/com/hbm/inventory/MachineRecipes.java b/com/hbm/inventory/MachineRecipes.java index 9f75f095d..5f165839f 100644 --- a/com/hbm/inventory/MachineRecipes.java +++ b/com/hbm/inventory/MachineRecipes.java @@ -2688,6 +2688,13 @@ public class MachineRecipes { list.add(new ItemStack(ModItems.circuit_gold, 5)); list.add(new ItemStack(ModItems.magnetron, 3)); break; + case TURRET_CHEAPO: + list.add(new ItemStack(ModItems.ingot_steel, 4)); + list.add(new ItemStack(ModItems.plate_iron, 4)); + list.add(new ItemStack(ModItems.pipes_steel, 3)); + list.add(new ItemStack(ModItems.motor, 3)); + list.add(new ItemStack(ModItems.circuit_red_copper, 3)); + break; case HUNTER_CHOPPER: list.add(new ItemStack(ModItems.chopper_blades, 5)); list.add(new ItemStack(ModItems.chopper_gun, 1)); @@ -3577,6 +3584,9 @@ public class MachineRecipes { case TURRET_CIWS: output = new ItemStack(ModBlocks.turret_cwis, 1); break; + case TURRET_CHEAPO: + output = new ItemStack(ModBlocks.turret_cheapo, 1); + break; case HUNTER_CHOPPER: output = new ItemStack(ModItems.chopper, 1); break; diff --git a/com/hbm/inventory/gui/GUIMachineRadar.java b/com/hbm/inventory/gui/GUIMachineRadar.java index 1c74bca59..c5920230f 100644 --- a/com/hbm/inventory/gui/GUIMachineRadar.java +++ b/com/hbm/inventory/gui/GUIMachineRadar.java @@ -1,5 +1,7 @@ package com.hbm.inventory.gui; +import java.util.Arrays; + import org.lwjgl.opengl.GL11; import com.hbm.inventory.FluidTank; @@ -33,6 +35,43 @@ public class GUIMachineRadar extends GuiInfoContainer { super.drawScreen(mouseX, mouseY, f); this.drawElectricityInfo(this, mouseX, mouseY, guiLeft + 8, guiTop + 221, 200, 7, diFurnace.power, diFurnace.maxPower); + + if(!diFurnace.nearbyMissiles.isEmpty()) { + for(int[] m : diFurnace.nearbyMissiles) { + int x = guiLeft + (int)((m[0] - diFurnace.xCoord) / ((double)MainRegistry.radarRange * 2 + 1) * (200D - 8D)) + 108; + int z = guiTop + (int)((m[1] - diFurnace.zCoord) / ((double)MainRegistry.radarRange * 2 + 1) * (200D - 8D)) + 117; + + if(mouseX + 4 > x && mouseX - 4 < x && + mouseY + 4 > z && mouseY - 4 < z) { + + + String[] text = new String[] { "Error." }; + + if(m[2] == 0) + text = new String[] { "Tier 1 Missile", m[0] + " / " + m[1], "Alt.: " + m[3] }; + if(m[2] == 1) + text = new String[] { "Tier 2 Missile", m[0] + " / " + m[1], "Alt.: " + m[3] }; + if(m[2] == 2) + text = new String[] { "Tier 3 Missile", m[0] + " / " + m[1], "Alt.: " + m[3] }; + if(m[2] == 3) + text = new String[] { "Tier 4 Missile", m[0] + " / " + m[1], "Alt.: " + m[3] }; + if(m[2] == 4) + text = new String[] { "Anti Ballistic Missile", m[0] + " / " + m[1], "Alt.: " + m[3] }; + if(m[2] == 5) + text = new String[] { "Airborne Entity", m[0] + " / " + m[1], "Alt.: " + m[3] }; + if(m[2] == 6) + text = new String[] { "Stinger Missile", m[0] + " / " + m[1], "Alt.: " + m[3] }; + if(m[2] == 7) + text = new String[] { "Sky Stinger Missile", m[0] + " / " + m[1], "Alt.: " + m[3] }; + if(m[2] == 8) + text = new String[] { "Unknown Force", m[0] + " / " + m[1], "Alt.: " + m[3] }; + + this.func_146283_a(Arrays.asList(text), x, z); + + return; + } + } + } } @Override @@ -55,8 +94,8 @@ public class GUIMachineRadar extends GuiInfoContainer { if(!diFurnace.nearbyMissiles.isEmpty()) { for(int[] m : diFurnace.nearbyMissiles) { - int x = (int)((m[0] - diFurnace.xCoord) / ((double)TileEntityMachineRadar.range * 2 + 1) * (200D - 8D)) - 4; - int z = (int)((m[1] - diFurnace.zCoord) / ((double)TileEntityMachineRadar.range * 2 + 1) * (200D - 8D)) - 4; + int x = (int)((m[0] - diFurnace.xCoord) / ((double)MainRegistry.radarRange * 2 + 1) * (200D - 8D)) - 4; + int z = (int)((m[1] - diFurnace.zCoord) / ((double)MainRegistry.radarRange * 2 + 1) * (200D - 8D)) - 4; int t = m[2]; drawTexturedModalRect(guiLeft + 108 + x, guiTop + 117 + z, 216, 8 * t, 8, 8); diff --git a/com/hbm/items/ModItems.java b/com/hbm/items/ModItems.java index 27627689b..d08238d95 100644 --- a/com/hbm/items/ModItems.java +++ b/com/hbm/items/ModItems.java @@ -830,6 +830,8 @@ public class ModItems { public static Item battery_su; public static Item battery_su_l; + public static Item battery_potato; + public static Item battery_potatos; public static Item fusion_core; public static Item fusion_core_infinite; public static Item energy_core; @@ -1087,6 +1089,7 @@ public class ModItems { public static Item turret_tau_ammo; public static Item turret_spitfire_ammo; public static Item turret_cwis_ammo; + public static Item turret_cheapo_ammo; public static Item bucket_mud; public static Item bucket_acid; @@ -1936,6 +1939,8 @@ public class ModItems { battery_spark_cell_6 = new ItemBattery(1000000 * 6).setUnlocalizedName("battery_spark_cell_6").setMaxStackSize(1).setCreativeTab(MainRegistry.tabParts).setTextureName(RefStrings.MODID + ":battery_spark_cell_6"); battery_spark_cell_25 = new ItemBattery(1000000 * 25).setUnlocalizedName("battery_spark_cell_25").setMaxStackSize(1).setCreativeTab(MainRegistry.tabParts).setTextureName(RefStrings.MODID + ":battery_spark_cell_25"); + battery_potato = new ItemBattery(1).setUnlocalizedName("battery_potato").setMaxStackSize(1).setCreativeTab(MainRegistry.tabParts).setTextureName(RefStrings.MODID + ":battery_potato"); + battery_potatos = new ItemBattery(50).setUnlocalizedName("battery_potatos").setMaxStackSize(1).setCreativeTab(MainRegistry.tabParts).setTextureName(RefStrings.MODID + ":battery_potatos"); battery_su = new ItemBattery(15).setUnlocalizedName("battery_su").setMaxStackSize(1).setCreativeTab(MainRegistry.tabParts).setTextureName(RefStrings.MODID + ":battery_su"); battery_su_l = new ItemBattery(35).setUnlocalizedName("battery_su_l").setMaxStackSize(1).setCreativeTab(MainRegistry.tabParts).setTextureName(RefStrings.MODID + ":battery_su_l"); fusion_core = new ItemBattery(200000).setUnlocalizedName("fusion_core").setMaxStackSize(1).setCreativeTab(MainRegistry.tabParts).setTextureName(RefStrings.MODID + ":fusion_core"); @@ -2066,6 +2071,7 @@ public class ModItems { turret_tau_ammo = new ItemTurretAmmo(ModBlocks.turret_tau, 100).setUnlocalizedName("turret_tau_ammo").setCreativeTab(MainRegistry.tabNuke).setTextureName(RefStrings.MODID + ":turret_tau_ammo"); turret_spitfire_ammo = new ItemTurretAmmo(ModBlocks.turret_spitfire, 2).setUnlocalizedName("turret_spitfire_ammo").setCreativeTab(MainRegistry.tabNuke).setTextureName(RefStrings.MODID + ":turret_spitfire_ammo"); turret_cwis_ammo = new ItemTurretAmmo(ModBlocks.turret_cwis, 250).setUnlocalizedName("turret_cwis_ammo").setCreativeTab(MainRegistry.tabNuke).setTextureName(RefStrings.MODID + ":turret_cwis_ammo"); + turret_cheapo_ammo = new ItemTurretAmmo(ModBlocks.turret_cheapo, 100).setUnlocalizedName("turret_cheapo_ammo").setCreativeTab(MainRegistry.tabNuke).setTextureName(RefStrings.MODID + ":turret_cheapo_ammo"); template_folder = new ItemTemplateFolder().setUnlocalizedName("template_folder").setMaxStackSize(1).setCreativeTab(MainRegistry.tabMachine).setTextureName(RefStrings.MODID + ":template_folder"); assembly_template = new ItemAssemblyTemplate().setUnlocalizedName("assembly_template").setMaxStackSize(1).setCreativeTab(MainRegistry.tabMachine).setTextureName(RefStrings.MODID + ":assembly_template"); @@ -2754,6 +2760,8 @@ public class ModItems { GameRegistry.registerItem(battery_creative, battery_creative.getUnlocalizedName()); GameRegistry.registerItem(battery_su, battery_su.getUnlocalizedName()); GameRegistry.registerItem(battery_su_l, battery_su_l.getUnlocalizedName()); + GameRegistry.registerItem(battery_potato, battery_potato.getUnlocalizedName()); + GameRegistry.registerItem(battery_potatos, battery_potatos.getUnlocalizedName()); GameRegistry.registerItem(fusion_core, fusion_core.getUnlocalizedName()); GameRegistry.registerItem(energy_core, energy_core.getUnlocalizedName()); GameRegistry.registerItem(fusion_core_infinite, fusion_core_infinite.getUnlocalizedName()); @@ -3127,6 +3135,7 @@ public class ModItems { GameRegistry.registerItem(turret_tau_ammo, turret_tau_ammo.getUnlocalizedName()); GameRegistry.registerItem(turret_spitfire_ammo, turret_spitfire_ammo.getUnlocalizedName()); GameRegistry.registerItem(turret_cwis_ammo, turret_cwis_ammo.getUnlocalizedName()); + GameRegistry.registerItem(turret_cheapo_ammo, turret_cheapo_ammo.getUnlocalizedName()); //-C-l-i-p-s- Magazines GameRegistry.registerItem(clip_revolver_iron, clip_revolver_iron.getUnlocalizedName()); diff --git a/com/hbm/items/tool/ItemAssemblyTemplate.java b/com/hbm/items/tool/ItemAssemblyTemplate.java index 341c86849..2f1aa02cd 100644 --- a/com/hbm/items/tool/ItemAssemblyTemplate.java +++ b/com/hbm/items/tool/ItemAssemblyTemplate.java @@ -181,6 +181,7 @@ public class ItemAssemblyTemplate extends Item { TURRET_TAU, TURRET_SPITFIRE, TURRET_CIWS, + TURRET_CHEAPO, MISSILE_HE_1, MISSILE_FIRE_1, MISSILE_CLUSTER_1, @@ -626,6 +627,8 @@ public class ItemAssemblyTemplate extends Item { return 350; case TURRET_CIWS: return 400; + case TURRET_CHEAPO: + return 200; case HUNTER_CHOPPER: return 300; case MISSILE_HE_1: diff --git a/com/hbm/items/tool/ItemTurretBiometry.java b/com/hbm/items/tool/ItemTurretBiometry.java index 5d9d9dae5..ccf3badd9 100644 --- a/com/hbm/items/tool/ItemTurretBiometry.java +++ b/com/hbm/items/tool/ItemTurretBiometry.java @@ -33,9 +33,9 @@ public class ItemTurretBiometry extends Item { } if(i == -1) - i = 255; + i = 511; - if(i == 256) + if(i == 512) i = 0; setFreq(stack, i); diff --git a/com/hbm/items/tool/ItemTurretChip.java b/com/hbm/items/tool/ItemTurretChip.java index 6dbc92289..f1bcd9b25 100644 --- a/com/hbm/items/tool/ItemTurretChip.java +++ b/com/hbm/items/tool/ItemTurretChip.java @@ -56,9 +56,9 @@ public class ItemTurretChip extends Item { } if(i == -1) - i = 255; + i = 511; - if(i == 256) + if(i == 512) i = 0; setFreq(stack, i); diff --git a/com/hbm/lib/Library.java b/com/hbm/lib/Library.java index ec5713f21..cc48b9a0d 100644 --- a/com/hbm/lib/Library.java +++ b/com/hbm/lib/Library.java @@ -758,6 +758,16 @@ public class Library { power += 100; ((ItemBattery)slots[index].getItem()).dischargeBattery(slots[index], 1); } + if(power + 100 <= maxPower && slots[index] != null && slots[index].getItem() == ModItems.battery_potato && ItemBattery.getCharge(slots[index]) > 0) + { + power += 100; + ((ItemBattery)slots[index].getItem()).dischargeBattery(slots[index], 1); + } + if(power + 100 <= maxPower && slots[index] != null && slots[index].getItem() == ModItems.battery_potatos && ItemBattery.getCharge(slots[index]) > 0) + { + power += 100; + ((ItemBattery)slots[index].getItem()).dischargeBattery(slots[index], 1); + } if(power + 100 <= maxPower && slots[index] != null && slots[index].getItem() == ModItems.battery_generic && ItemBattery.getCharge(slots[index]) > 0) { diff --git a/com/hbm/lib/RefStrings.java b/com/hbm/lib/RefStrings.java index 7d327afbe..dfca3126d 100644 --- a/com/hbm/lib/RefStrings.java +++ b/com/hbm/lib/RefStrings.java @@ -3,7 +3,7 @@ package com.hbm.lib; public class RefStrings { public static final String MODID = "hbm"; public static final String NAME = "Hbm's Nuclear Tech Mod"; - public static final String VERSION = "1.0.27 BETA (Blep)"; + public static final String VERSION = "1.0.27 BETA (Sputnik)"; //HBM's Beta Naming Convention: //V T (X-Y-Z) //V -> next release version diff --git a/com/hbm/main/CraftingManager.java b/com/hbm/main/CraftingManager.java index 4dd290f2e..de0daacfc 100644 --- a/com/hbm/main/CraftingManager.java +++ b/com/hbm/main/CraftingManager.java @@ -728,6 +728,7 @@ public class CraftingManager { GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.turret_tau_ammo, 1), new Object[] { "AAA", "AUA", "AAA", 'A', ModItems.gun_xvl1456_ammo, 'U', "blockUranium" })); GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.turret_spitfire_ammo, 1), new Object[] { "CP ", "PTP", " PR", 'P', "plateSteel", 'C', ModItems.circuit_copper, 'T', Blocks.tnt, 'R', "dustRedstone" })); GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.turret_cwis_ammo, 1), new Object[] { "LLL", "GGG", "IGI", 'L', "plateLead", 'I', "plateIron", 'G', Items.gunpowder })); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.turret_cheapo_ammo, 1), new Object[] { "ILI", "IGI", "ICI", 'L', "plateLead", 'I', "plateSteel", 'C', "plateCopper", 'G', Items.gunpowder })); GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.grenade_generic, 4), new Object[] { "RS ", "ITI", " I ", 'I', "plateIron", 'R', ModItems.wire_red_copper, 'S', "plateSteel", 'T', Item.getItemFromBlock(Blocks.tnt) })); GameRegistry.addRecipe(new ItemStack(ModItems.grenade_strong, 2), new Object[] { " G ", "SGS", " S ", 'G', ModItems.grenade_generic, 'S', Items.gunpowder }); @@ -765,6 +766,8 @@ public class CraftingManager { GameRegistry.addShapelessRecipe(new ItemStack(ModItems.tem_flakes, 1, 1), new Object[] { Items.gold_nugget, Items.gold_nugget, Items.gold_nugget, Items.paper }); GameRegistry.addShapelessRecipe(new ItemStack(ModItems.tem_flakes, 1, 2), new Object[] { Items.gold_ingot, Items.gold_ingot, Items.gold_nugget, Items.gold_nugget, Items.paper }); GameRegistry.addShapelessRecipe(new ItemStack(ModItems.glowing_stew, 1), new Object[] { Items.bowl, Item.getItemFromBlock(ModBlocks.mush), Item.getItemFromBlock(ModBlocks.mush) }); + GameRegistry.addShapelessRecipe(new ItemStack(ModItems.med_ipecac, 1), new Object[] { Items.glass_bottle, Items.nether_wart }); + GameRegistry.addShapelessRecipe(new ItemStack(ModItems.med_ptsd, 1), new Object[] { ModItems.med_ipecac }); GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.can_empty, 1), new Object[] { "P", "P", 'P', "plateAluminum" })); GameRegistry.addShapelessRecipe(new ItemStack(ModItems.can_smart, 1), new Object[] { ModItems.can_empty, Items.potionitem, Items.sugar, ModItems.niter }); @@ -900,6 +903,8 @@ public class CraftingManager { GameRegistry.addRecipe(new ShapedOreRecipe(ItemBattery.getFullBattery(ModItems.battery_su_l), new Object[] { " W ", "RPR", "CPC", 'W', ModItems.wire_aluminium, 'P', Items.paper, 'R', "dustRedstone", 'C', "dustCoal" })); GameRegistry.addRecipe(new ShapedOreRecipe(ItemBattery.getFullBattery(ModItems.battery_su_l), new Object[] { " W ", "CPC", "RPR", 'W', ModItems.wire_copper, 'P', Items.paper, 'R', "dustRedstone", 'C', "dustCoal" })); GameRegistry.addRecipe(new ShapedOreRecipe(ItemBattery.getFullBattery(ModItems.battery_su_l), new Object[] { " W ", "RPR", "CPC", 'W', ModItems.wire_copper, 'P', Items.paper, 'R', "dustRedstone", 'C', "dustCoal" })); + GameRegistry.addShapelessRecipe(ItemBattery.getFullBattery(ModItems.battery_potato), new Object[] { Items.potato, ModItems.wire_aluminium, ModItems.wire_copper }); + GameRegistry.addRecipe(new ShapelessOreRecipe(ItemBattery.getFullBattery(ModItems.battery_potatos), new Object[] { ItemBattery.getFullBattery(ModItems.battery_potato), ModItems.turret_chip, "dustRedstone" })); GameRegistry.addRecipe(new ItemStack(ModItems.schrabidium_helmet, 1), new Object[] { "EEE", "E E", 'E', ModItems.ingot_schrabidium }); GameRegistry.addRecipe(new ItemStack(ModItems.schrabidium_plate, 1), new Object[] { "E E", "EEE", "EEE", 'E', ModItems.ingot_schrabidium }); @@ -1019,6 +1024,7 @@ public class CraftingManager { GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.linker, 1), new Object[] { "I I", "ICI", "GGG", 'I', "plateIron", 'G', "plateGold", 'C', ModItems.circuit_gold })); GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.oil_detector, 1), new Object[] { "W I", "WCI", "PPP", 'W', ModItems.wire_gold, 'I', "ingotCopper", 'C', ModItems.circuit_red_copper, 'P', "plateSteel" })); GameRegistry.addRecipe(new ItemStack(ModItems.turret_chip, 1), new Object[] { "WWW", "CPC", "WWW", 'W', ModItems.wire_gold, 'P', ModItems.ingot_polymer, 'C', ModItems.circuit_gold, }); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.turret_biometry, 1), new Object[] { "CC ", "GGS", "III", 'C', ModItems.circuit_copper, 'S', "plateSteel", 'G', ModItems.circuit_gold, 'I', "plateLead" })); GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.survey_scanner, 1), new Object[] { "SWS", " G ", "PCP", 'W', ModItems.wire_gold, 'P', ModItems.ingot_polymer, 'C', ModItems.circuit_gold, 'S', "plateSteel", 'G', "ingotGold" })); GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(ModItems.geiger_counter, 1), new Object[] { "GPP", "WCS", "WBB", 'W', ModItems.wire_gold, 'P', ModItems.ingot_polymer, 'C', ModItems.circuit_copper, 'G', "ingotGold", 'S', "plateSteel", 'B', ModItems.ingot_beryllium })); diff --git a/com/hbm/main/MainRegistry.java b/com/hbm/main/MainRegistry.java index 06035378a..d0ecdf78a 100644 --- a/com/hbm/main/MainRegistry.java +++ b/com/hbm/main/MainRegistry.java @@ -424,6 +424,9 @@ public class MainRegistry public static int meteorShowerChance = 20 * 60 * 3; public static int meteorShowerDuration = 6000; public static int limitExplosionLifespan = 0; + public static int radarRange = 1000; + public static int radarBuffer = 30; + public static int radarAltitude = 55; public static int generalOverride = 0; public static int polaroidID = 1; @@ -1343,6 +1346,16 @@ public class MainRegistry Property propBlastSpeed = config.get(Configuration.CATEGORY_GENERAL, "6.01_blastSpeed", 1024); propBlastSpeed.comment = "Base speed of all detonations (Blocks / tick)"; blastSpeed = propBlastSpeed.getInt(); + + Property propRadarRange = config.get(Configuration.CATEGORY_GENERAL, "7.00_radarRange", 1000); + propRadarRange.comment = "Range of the radar, 50 will result in 100x100 block area covered"; + radarRange = propRadarRange.getInt(); + Property propRadarBuffer = config.get(Configuration.CATEGORY_GENERAL, "7.00_radarBuffer", 30); + propRadarBuffer.comment = "How high entities have to be above the radar to be detected"; + radarBuffer = propRadarBuffer.getInt(); + Property propRadarAltitude = config.get(Configuration.CATEGORY_GENERAL, "7.00_radarAltitude", 55); + propRadarAltitude.comment = "Y height required for the radar to work"; + radarAltitude = propRadarAltitude.getInt(); config.save(); } diff --git a/com/hbm/packet/TERadarPacket.java b/com/hbm/packet/TERadarPacket.java index 3e364cdce..4036a4214 100644 --- a/com/hbm/packet/TERadarPacket.java +++ b/com/hbm/packet/TERadarPacket.java @@ -21,18 +21,20 @@ public class TERadarPacket implements IMessage { int conX; int conY; int conZ; + int alt; public TERadarPacket() { } - public TERadarPacket(int x, int y, int z, int conX, int conY, int conZ) { + public TERadarPacket(int x, int y, int z, int conX, int conY, int conZ, int alt) { this.x = x; this.y = y; this.z = z; this.conX = conX; this.conY = conY; this.conZ = conZ; + this.alt = alt; } @Override @@ -43,6 +45,7 @@ public class TERadarPacket implements IMessage { conX = buf.readInt(); conY = buf.readInt(); conZ = buf.readInt(); + alt = buf.readInt(); } @Override @@ -53,6 +56,7 @@ public class TERadarPacket implements IMessage { buf.writeInt(conX); buf.writeInt(conY); buf.writeInt(conZ); + buf.writeInt(alt); } public static class Handler implements IMessageHandler { @@ -66,7 +70,7 @@ public class TERadarPacket implements IMessage { if (te != null && te instanceof TileEntityMachineRadar) { TileEntityMachineRadar radar = (TileEntityMachineRadar) te; - radar.nearbyMissiles.add(new int[]{m.conX, m.conY, m.conZ}); + radar.nearbyMissiles.add(new int[]{m.conX, m.conY, m.conZ, m.alt}); } } catch (Exception x) { } diff --git a/com/hbm/render/entity/RenderSmallNukeAlt.java b/com/hbm/render/entity/RenderSmallNukeAlt.java index f950f1da6..58f821fa6 100644 --- a/com/hbm/render/entity/RenderSmallNukeAlt.java +++ b/com/hbm/render/entity/RenderSmallNukeAlt.java @@ -81,7 +81,7 @@ public class RenderSmallNukeAlt extends Render { { scale += 0.02; }*/ - GL11.glScalef(p_76986_1_.scale, 1.0F, p_76986_1_.scale); + //GL11.glScalef(p_76986_1_.scale, 1.0F, p_76986_1_.scale); GL11.glScalef(50F, 25.0F, 50F); bindTexture(ringBigTexture); diff --git a/com/hbm/render/entity/RenderSmallNukeMK3.java b/com/hbm/render/entity/RenderSmallNukeMK3.java index f68c1bb94..4850ee469 100644 --- a/com/hbm/render/entity/RenderSmallNukeMK3.java +++ b/com/hbm/render/entity/RenderSmallNukeMK3.java @@ -81,8 +81,9 @@ public class RenderSmallNukeMK3 extends Render { GL11.glTranslatef((float)posX, (float)posY + 0.25F, (float)posZ); GL11.glDisable(GL11.GL_LIGHTING); GL11.glEnable(GL11.GL_CULL_FACE); - - GL11.glScalef(cloud.scale, cloud.scale, cloud.scale); + + float size = cloud.getDataWatcher().getWatchableObjectFloat(18); + GL11.glScalef(size, size, size); int age = cloud.age; int shockScale = age * 4; diff --git a/com/hbm/tileentity/bomb/TileEntityTurretCheapo.java b/com/hbm/tileentity/bomb/TileEntityTurretCheapo.java index 99e9a41be..e385d26cb 100644 --- a/com/hbm/tileentity/bomb/TileEntityTurretCheapo.java +++ b/com/hbm/tileentity/bomb/TileEntityTurretCheapo.java @@ -15,8 +15,6 @@ public class TileEntityTurretCheapo extends TileEntityTurretBase { super.updateEntity(); - this.ammo = 100; - if(!worldObj.isRemote) { if(spin > 0) diff --git a/com/hbm/tileentity/machine/TileEntityMachineRadar.java b/com/hbm/tileentity/machine/TileEntityMachineRadar.java index a85a69840..58ece45cc 100644 --- a/com/hbm/tileentity/machine/TileEntityMachineRadar.java +++ b/com/hbm/tileentity/machine/TileEntityMachineRadar.java @@ -26,8 +26,6 @@ public class TileEntityMachineRadar extends TileEntity implements IConsumer { public static List allMissiles = new ArrayList(); public List nearbyMissiles = new ArrayList(); - - public static int range = 1000; public long power = 0; public static final int maxPower = 100000; @@ -74,7 +72,7 @@ public class TileEntityMachineRadar extends TileEntity implements IConsumer { nearbyMissiles.clear(); - List list = worldObj.getEntitiesWithinAABBExcludingEntity(null, AxisAlignedBB.getBoundingBox(xCoord + 0.5 - range, 0, zCoord + 0.5 - range, xCoord + 0.5 + range, 5000, zCoord + 0.5 + range)); + List list = worldObj.getEntitiesWithinAABBExcludingEntity(null, AxisAlignedBB.getBoundingBox(xCoord + 0.5 - MainRegistry.radarRange, 0, zCoord + 0.5 - MainRegistry.radarRange, xCoord + 0.5 + MainRegistry.radarRange, 5000, zCoord + 0.5 + MainRegistry.radarRange)); for(Entity e : list) { /*if(e instanceof EntityMissileBaseAdvanced) { @@ -82,29 +80,29 @@ public class TileEntityMachineRadar extends TileEntity implements IConsumer { nearbyMissiles.add(new int[] { (int)mis.posX, (int)mis.posZ, mis.getMissileType() }); }*/ - if(e instanceof EntityRocketHoming) { + if(e instanceof EntityRocketHoming && e.posY >= yCoord + MainRegistry.radarBuffer) { EntityRocketHoming rocket = (EntityRocketHoming)e; if(rocket.getIsCritical()) - nearbyMissiles.add(new int[] { (int)e.posX, (int)e.posZ, 7 }); + nearbyMissiles.add(new int[] { (int)e.posX, (int)e.posZ, 7, (int)e.posY }); else - nearbyMissiles.add(new int[] { (int)e.posX, (int)e.posZ, 6 }); + nearbyMissiles.add(new int[] { (int)e.posX, (int)e.posZ, 6, (int)e.posY }); continue; } - if(!(e instanceof EntityMissileBaseAdvanced) && e.width * e.width * e.height >= 0.5D && e.posY >= yCoord + 30) { - nearbyMissiles.add(new int[] { (int)e.posX, (int)e.posZ, 5 }); + if(!(e instanceof EntityMissileBaseAdvanced) && e.width * e.width * e.height >= 0.5D && e.posY >= yCoord + MainRegistry.radarBuffer) { + nearbyMissiles.add(new int[] { (int)e.posX, (int)e.posZ, 5, (int)e.posY }); } } for(Entity e : allMissiles) { - if(e != null && !e.isDead) + if(e != null && !e.isDead && e.posY >= yCoord + MainRegistry.radarBuffer) if(e instanceof EntityMissileBaseAdvanced) { - if(e.posX < xCoord + range && e.posX > xCoord - range && - e.posZ < zCoord + range && e.posZ > zCoord - range) { + if(e.posX < xCoord + MainRegistry.radarRange && e.posX > xCoord - MainRegistry.radarRange && + e.posZ < zCoord + MainRegistry.radarRange && e.posZ > zCoord - MainRegistry.radarRange) { EntityMissileBaseAdvanced mis = (EntityMissileBaseAdvanced)e; - nearbyMissiles.add(new int[] { (int)mis.posX, (int)mis.posZ, mis.getMissileType() }); + nearbyMissiles.add(new int[] { (int)mis.posX, (int)mis.posZ, mis.getMissileType(), (int)mis.posY }); } } } @@ -114,7 +112,7 @@ public class TileEntityMachineRadar extends TileEntity implements IConsumer { if(!nearbyMissiles.isEmpty()) { - double maxRange = range * Math.sqrt(2D); + double maxRange = MainRegistry.radarRange * Math.sqrt(2D); int power = 0; @@ -139,7 +137,7 @@ public class TileEntityMachineRadar extends TileEntity implements IConsumer { PacketDispatcher.wrapper.sendToAll(new TERadarDestructorPacket(xCoord, yCoord, zCoord)); for(int[] e : this.nearbyMissiles) { - PacketDispatcher.wrapper.sendToAll(new TERadarPacket(xCoord, yCoord, zCoord, e[0], e[1], e[2])); + PacketDispatcher.wrapper.sendToAll(new TERadarPacket(xCoord, yCoord, zCoord, e[0], e[1], e[2], e[3])); } }