Tweaked some mechanical mechanics
This commit is contained in:
parent
08c0aad457
commit
0d736a612f
7 changed files with 16 additions and 17 deletions
|
@ -130,6 +130,8 @@ public class TileLevitator extends TileAdvanced implements IPacketReceiver, IPac
|
|||
{
|
||||
item.setEntityItemStack(remains);
|
||||
}
|
||||
|
||||
//TODO: Add redstone pulse?
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -65,12 +65,12 @@ public class PartGear extends PartMechanical implements IMechanical, IMultiBlock
|
|||
{
|
||||
if (angularVelocity > 0)
|
||||
{
|
||||
torque += 3;
|
||||
torque += 5;
|
||||
angularVelocity += 0.02f;
|
||||
}
|
||||
else
|
||||
{
|
||||
torque -= 3;
|
||||
torque -= 5;
|
||||
angularVelocity -= 0.02f;
|
||||
}
|
||||
|
||||
|
@ -83,12 +83,12 @@ public class PartGear extends PartMechanical implements IMechanical, IMultiBlock
|
|||
switch (tier)
|
||||
{
|
||||
default:
|
||||
torque *= 0.9f;
|
||||
angularVelocity *= 0.95f;
|
||||
torque *= 0.97f;
|
||||
angularVelocity *= 0.98f;
|
||||
break;
|
||||
case 1:
|
||||
torque *= 0.95f;
|
||||
angularVelocity *= 0.9f;
|
||||
torque *= 0.98f;
|
||||
angularVelocity *= 0.97f;
|
||||
break;
|
||||
case 2:
|
||||
torque *= 0.99f;
|
||||
|
|
|
@ -55,8 +55,8 @@ public class PartGearShaft extends PartMechanical
|
|||
if (!this.world().isRemote)
|
||||
{
|
||||
// Decelerate the gear.
|
||||
torque *= 0.95f;
|
||||
angularVelocity *= 0.95f;
|
||||
torque *= 0.99f;
|
||||
angularVelocity *= 0.99f;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -79,7 +79,7 @@ public class MechanicalNetwork extends Network<IMechanicalNetwork, IMechanical>
|
|||
|
||||
if (adjacentMech != null && adjacent != mechanical)
|
||||
{
|
||||
|
||||
//System.out.println("UPDATING: " + mechanical + " with " + adjacentMech);
|
||||
float ratio = adjacentMech.getRatio(dir.getOpposite(), mechanical) / mechanical.getRatio(dir, adjacentMech);
|
||||
long torque = mechanical.getTorque();
|
||||
|
||||
|
@ -88,21 +88,17 @@ public class MechanicalNetwork extends Network<IMechanicalNetwork, IMechanical>
|
|||
int inversion = inverseRotation ? -1 : 1;
|
||||
|
||||
if (Math.abs(torque + inversion * (adjacentMech.getTorque() / ratio * ACCELERATION)) < Math.abs(adjacentMech.getTorque() / ratio))
|
||||
{
|
||||
mechanical.setTorque((long) (torque + inversion * ((adjacentMech.getTorque() / ratio * ACCELERATION))));
|
||||
}
|
||||
|
||||
float velocity = mechanical.getAngularVelocity();
|
||||
|
||||
if (Math.abs(velocity + inversion * (adjacentMech.getAngularVelocity() * ratio * ACCELERATION)) < Math.abs(adjacentMech.getAngularVelocity() * ratio))
|
||||
{
|
||||
mechanical.setAngularVelocity(velocity + (inversion * adjacentMech.getAngularVelocity() * ratio * ACCELERATION));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean canUpdate()
|
||||
|
|
|
@ -139,7 +139,7 @@ public abstract class PartMechanical extends JCuboidPart implements JNormalOcclu
|
|||
@Override
|
||||
public void preRemove()
|
||||
{
|
||||
this.getNetwork().split(this);
|
||||
getNetwork().split(this);
|
||||
}
|
||||
|
||||
/** Packet Code. */
|
||||
|
|
|
@ -44,7 +44,7 @@ public abstract class TileMechanical extends TileAdvanced implements IMechanical
|
|||
torque *= getLoad();
|
||||
angularVelocity *= getLoad();
|
||||
|
||||
if (Math.abs(prevAngularVelocity - angularVelocity) > 0.05f)
|
||||
if (Math.abs(prevAngularVelocity - angularVelocity) > 0.01f)
|
||||
{
|
||||
prevAngularVelocity = angularVelocity;
|
||||
markPacketUpdate = true;
|
||||
|
|
|
@ -36,7 +36,7 @@ public class TileWindTurbine extends TileTurbine implements IMechanical
|
|||
*/
|
||||
if (getDirection().offsetY == 0)
|
||||
{
|
||||
maxPower = 100;
|
||||
maxPower = 500;
|
||||
getMultiBlock().get().power += getWindPower();
|
||||
}
|
||||
else
|
||||
|
@ -44,6 +44,7 @@ public class TileWindTurbine extends TileTurbine implements IMechanical
|
|||
maxPower = 1000;
|
||||
}
|
||||
|
||||
|
||||
if (!getMultiBlock().isConstructed())
|
||||
torque = defaultTorque / 6;
|
||||
else
|
||||
|
@ -66,7 +67,7 @@ public class TileWindTurbine extends TileTurbine implements IMechanical
|
|||
if (!worldObj.canBlockSeeTheSky(xCoord, yCoord + 4, zCoord))
|
||||
return 0;
|
||||
|
||||
return (long) (((((float) yCoord + 4) / 256) * maxPower) + (hasBonus ? 80 : 0)) * (worldObj.isRaining() ? 2 : 1);
|
||||
return (long) (((((float) yCoord + 4) / 256) * maxPower) + (hasBonus ? 10 : 0)) * (worldObj.isRaining() ? 2 : 1);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
Loading…
Reference in a new issue