We have movement

The test car works now though i have a lot of work still too do.
This commit is contained in:
Robert 2013-11-09 19:20:23 -05:00
parent ac9573ff83
commit 36eee0272a
4 changed files with 64 additions and 13 deletions

View file

@ -13,6 +13,7 @@ import org.lwjgl.input.Keyboard;
import org.lwjgl.input.Mouse; import org.lwjgl.input.Mouse;
import cpw.mods.fml.client.registry.KeyBindingRegistry.KeyHandler; import cpw.mods.fml.client.registry.KeyBindingRegistry.KeyHandler;
import cpw.mods.fml.common.IScheduledTickHandler;
import cpw.mods.fml.common.ITickHandler; import cpw.mods.fml.common.ITickHandler;
import cpw.mods.fml.common.TickType; import cpw.mods.fml.common.TickType;
import dark.core.network.PacketManagerKeyEvent; import dark.core.network.PacketManagerKeyEvent;
@ -20,10 +21,8 @@ import dark.core.network.PacketManagerKeyEvent;
/** This class handles keys already binded to the game so to avoid creating new key bindings /** This class handles keys already binded to the game so to avoid creating new key bindings
* *
* @author DarkGuardsman */ * @author DarkGuardsman */
public class PlayerKeyHandler implements ITickHandler public class PlayerKeyHandler implements IScheduledTickHandler
{ {
protected boolean[] keyDown;
protected boolean[] repeatings;
@Override @Override
public final void tickStart(EnumSet<TickType> type, Object... tickData) public final void tickStart(EnumSet<TickType> type, Object... tickData)
@ -62,4 +61,10 @@ public class PlayerKeyHandler implements ITickHandler
{ {
return "[CoreMachine]KeyBindingCatcher"; return "[CoreMachine]KeyBindingCatcher";
} }
@Override
public int nextTickSpacing()
{
return 2;
}
} }

View file

@ -66,7 +66,7 @@ public class PacketManagerKeyEvent implements IPacketManager
try try
{ {
int key = data.readInt(); int key = data.readInt();
for (IControlReceiver receiver : receivers) for (IControlReceiver receiver : instance().receivers)
{ {
receiver.keyTyped((EntityPlayer) player, key); receiver.keyTyped((EntityPlayer) player, key);
} }

View file

@ -106,7 +106,7 @@ public abstract class ModPrefab
MinecraftForge.EVENT_BUS.register(new FluidHelper()); MinecraftForge.EVENT_BUS.register(new FluidHelper());
MinecraftForge.EVENT_BUS.register(SaveManager.instance()); MinecraftForge.EVENT_BUS.register(SaveManager.instance());
TickRegistry.registerTickHandler(NetworkUpdateHandler.instance(), Side.SERVER); TickRegistry.registerTickHandler(NetworkUpdateHandler.instance(), Side.SERVER);
TickRegistry.registerTickHandler(new PlayerKeyHandler(), Side.CLIENT); TickRegistry.registerScheduledTickHandler(new PlayerKeyHandler(), Side.CLIENT);
UniversalElectricity.initiate(); UniversalElectricity.initiate();
Compatibility.initiate(); Compatibility.initiate();
preInit = true; preInit = true;

View file

@ -4,9 +4,11 @@ import net.minecraft.client.Minecraft;
import net.minecraft.entity.player.EntityPlayer; import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.nbt.NBTTagCompound; import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.util.AxisAlignedBB; import net.minecraft.util.AxisAlignedBB;
import net.minecraft.util.ChatMessageComponent;
import net.minecraft.util.DamageSource; import net.minecraft.util.DamageSource;
import net.minecraft.world.World; import net.minecraft.world.World;
import cpw.mods.fml.client.FMLClientHandler; import cpw.mods.fml.client.FMLClientHandler;
import dark.core.helpers.MathHelper;
import dark.core.interfaces.IControlReceiver; import dark.core.interfaces.IControlReceiver;
import dark.core.network.PacketManagerKeyEvent; import dark.core.network.PacketManagerKeyEvent;
import dark.core.prefab.EntityAdvanced; import dark.core.prefab.EntityAdvanced;
@ -38,11 +40,13 @@ public class EntityDrivable extends EntityAdvanced implements IControlReceiver
@Override @Override
public boolean keyTyped(EntityPlayer player, int keycode) public boolean keyTyped(EntityPlayer player, int keycode)
{ {
if (this.ridingEntity != null && this.ridingEntity.equals(player)) System.out.println("Key: "+keycode+" P: " + (player != null ? player.username : "null"));
if (player != null && this.riddenByEntity instanceof EntityPlayer && ((EntityPlayer) this.riddenByEntity).username.equalsIgnoreCase(player.username))
{ {
//TODO add auto forward and backwards keys like those in WoT //TODO add auto forward and backwards keys like those in WoT
if (keycode == Minecraft.getMinecraft().gameSettings.keyBindForward.keyCode) if (keycode == Minecraft.getMinecraft().gameSettings.keyBindForward.keyCode)
{ {
player.sendChatToPlayer(ChatMessageComponent.createFromText("Forward we go!"));
this.accelerate(true); this.accelerate(true);
} }
if (keycode == Minecraft.getMinecraft().gameSettings.keyBindBack.keyCode) if (keycode == Minecraft.getMinecraft().gameSettings.keyBindBack.keyCode)
@ -51,11 +55,11 @@ public class EntityDrivable extends EntityAdvanced implements IControlReceiver
} }
if (keycode == Minecraft.getMinecraft().gameSettings.keyBindLeft.keyCode) if (keycode == Minecraft.getMinecraft().gameSettings.keyBindLeft.keyCode)
{ {
this.rotationYaw += 5; this.rotationYaw += 6;
} }
if (keycode == Minecraft.getMinecraft().gameSettings.keyBindRight.keyCode) if (keycode == Minecraft.getMinecraft().gameSettings.keyBindRight.keyCode)
{ {
this.rotationYaw -= 5; this.rotationYaw -= 6;
} }
//Power brakes //Power brakes
if (keycode == Minecraft.getMinecraft().gameSettings.keyBindJump.keyCode) if (keycode == Minecraft.getMinecraft().gameSettings.keyBindJump.keyCode)
@ -92,17 +96,59 @@ public class EntityDrivable extends EntityAdvanced implements IControlReceiver
this.worldObj.spawnParticle("mobSpell", this.posX, this.posY, this.posZ, 0, 0, 0); this.worldObj.spawnParticle("mobSpell", this.posX, this.posY, this.posZ, 0, 0, 0);
} }
if (this.worldObj.isRemote && (this.riddenByEntity == null || !(this.riddenByEntity instanceof EntityPlayer) || !FMLClientHandler.instance().getClient().thePlayer.equals(this.riddenByEntity)))
{
double x, y, z;
if (this.boatPosRotationIncrements > 0)
{
x = this.posX + (this.boatX - this.posX) / this.boatPosRotationIncrements;
y = this.posY + (this.boatY - this.posY) / this.boatPosRotationIncrements;
z = this.posZ + (this.boatZ - this.posZ) / this.boatPosRotationIncrements;
this.rotationYaw = (float) (this.rotationYaw + MathHelper.wrapAngleTo180_double(this.boatYaw - this.rotationYaw) / this.boatPosRotationIncrements);
this.rotationPitch = (float) (this.rotationPitch + (this.boatPitch - this.rotationPitch) / this.boatPosRotationIncrements);
--this.boatPosRotationIncrements;
this.setPosition(x, y, z);
this.setRotation(this.rotationYaw, this.rotationPitch);
}
else
{
x = this.posX + this.motionX;
y = this.posY + this.motionY;
z = this.posZ + this.motionZ;
if (this.riddenByEntity != null)
{
this.setPosition(x, y, z);
}
if (this.onGround)
{
this.motionX *= 0.5D;
this.motionY *= 0.5D;
this.motionZ *= 0.5D;
}
this.motionX *= 0.9900000095367432D;
this.motionY *= 0.949999988079071D;
this.motionZ *= 0.9900000095367432D;
}
return;
}
if (this.isCollidedHorizontally) if (this.isCollidedHorizontally)
{ {
this.speed *= 0.9;
this.motionY = 0.1D; this.motionY = 0.1D;
} }
this.applyFriction(); if (this.worldObj.isRemote)
{
this.motionX = -(this.speed * Math.cos((this.rotationYaw - 90F) * Math.PI / 180.0D)); this.motionX = -(this.speed * Math.cos((this.rotationYaw - 90F) * Math.PI / 180.0D));
this.motionZ = -(this.speed * Math.sin((this.rotationYaw - 90F) * Math.PI / 180.0D)); this.motionZ = -(this.speed * Math.sin((this.rotationYaw - 90F) * Math.PI / 180.0D));
this.moveEntity(this.motionX, this.motionY, this.motionZ); this.moveEntity(this.motionX, this.motionY, this.motionZ);
}
this.applyFriction();
if (this.speed > this.maxSpeed) if (this.speed > this.maxSpeed)
{ {
this.speed = this.maxSpeed; this.speed = this.maxSpeed;