package edx.electrical.generator import cpw.mods.fml.relauncher.{Side, SideOnly} import edx.core.Reference import edx.mechanical.mech.grid.NodeMechanical import net.minecraft.block.material.Material import net.minecraft.entity.EntityLivingBase import net.minecraft.entity.player.EntityPlayer import net.minecraft.item.ItemStack import net.minecraft.nbt.NBTTagCompound import net.minecraft.util.{ChatComponentText, ResourceLocation} import net.minecraftforge.client.model.AdvancedModelLoader import net.minecraftforge.common.util.ForgeDirection import org.lwjgl.opengl.GL11 import resonant.lib.grid.core.TSpatialNodeProvider import resonant.lib.prefab.tile.spatial.SpatialTile import resonant.lib.prefab.tile.traits.{TElectric, TRotatable} import resonant.lib.render.RenderUtility import resonant.lib.transform.vector.Vector3 import scala.collection.convert.wrapAll._ /** * A kinetic energy to electrical energy converter. * * @author Calclavia */ object TileMotor { @SideOnly(Side.CLIENT) val model = AdvancedModelLoader.loadModel(new ResourceLocation(Reference.domain, Reference.modelPath + "motor.tcn")) @SideOnly(Side.CLIENT) val texture = new ResourceLocation(Reference.domain, Reference.modelPath + "motor.png") } class TileMotor extends SpatialTile(Material.iron) with TElectric with TSpatialNodeProvider with TRotatable { var mechNode = new NodeMechanical(this) { override def canConnect(from: ForgeDirection): Boolean = { connectionMask = 1 << getDirection.getOpposite.ordinal return super.canConnect(from) } } private var gearRatio = 0 textureName = "material_wood_surface" normalRender = false isOpaqueCube = false nodes.add(electricNode) nodes.add(mechNode) electricNode.resistance = 100 electricNode.positiveTerminals.addAll(Seq(ForgeDirection.UP, ForgeDirection.SOUTH, ForgeDirection.EAST)) electricNode.negativeTerminals.addAll(Seq(ForgeDirection.DOWN, ForgeDirection.NORTH, ForgeDirection.WEST)) def toggleGearRatio() = (gearRatio + 1) % 3 /** * Called when the block is placed by a living entity * @param entityLiving - entity who placed the block * @param itemStack - ItemStack the entity used to place the block */ override def onPlaced(entityLiving: EntityLivingBase, itemStack: ItemStack) { super.onPlaced(entityLiving, itemStack) if (!world.isRemote) mechNode.reconstruct() } override def update() { super.update() /* //TODO: Debug with free energy if (mechNode.power > dcNode.power) { //Produce electricity dcNode.setVoltage(mechNode.power) //TODO: Resist mech energy } // else if (dcNode.power > mechNode.power) else*/ { //Produce mechanical energy val mechRatio = Math.pow(10, gearRatio) val power = electricNode.power val negate = if (electricNode.voltage > 0) 1 else -1 mechNode.rotate(negate * power * mechRatio, negate * power / mechRatio) //TODO: Resist DC energy } } @SideOnly(Side.CLIENT) override def renderDynamic(pos: Vector3, frame: Float, pass: Int): Unit = { GL11.glPushMatrix() GL11.glTranslatef(pos.x.toFloat + 0.5f, pos.y.toFloat + 0.5f, pos.z.toFloat + 0.5f) GL11.glRotatef(90, 0, 1, 0) RenderUtility.rotateBlockBasedOnDirection(getDirection) RenderUtility.bind(TileMotor.texture) TileMotor.model.renderAll() GL11.glPopMatrix() } override def readFromNBT(nbt: NBTTagCompound) { super.readFromNBT(nbt) gearRatio = nbt.getByte("gear") } override def writeToNBT(nbt: NBTTagCompound) { super.writeToNBT(nbt) nbt.setByte("gear", gearRatio.toByte) } override def toString: String = "[TileMotor]" + x + "x " + y + "y " + z + "z " override protected def configure(player: EntityPlayer, side: Int, hit: Vector3): Boolean = { if (!world.isRemote) { gearRatio = (gearRatio + 1) % 3 player.addChatComponentMessage(new ChatComponentText("Toggled gear ratio: " + gearRatio)) } return true } }