Rendering looks cool :)
This commit is contained in:
parent
ed2a5233ae
commit
350ad4c22e
5 changed files with 79 additions and 50 deletions
|
@ -125,7 +125,7 @@ public class RenderPartTransmitter implements IIconRegister
|
||||||
public void renderContents(PartMechanicalPipe pipe, Vector3 pos)
|
public void renderContents(PartMechanicalPipe pipe, Vector3 pos)
|
||||||
{
|
{
|
||||||
Fluid fluid = pipe.getTransmitterNetwork().refFluid;
|
Fluid fluid = pipe.getTransmitterNetwork().refFluid;
|
||||||
float scale = pipe.getTransmitterNetwork().fluidScale;
|
float scale = pipe.currentScale;
|
||||||
|
|
||||||
if(scale > 0 && fluid != null)
|
if(scale > 0 && fluid != null)
|
||||||
{
|
{
|
||||||
|
@ -359,7 +359,7 @@ public class RenderPartTransmitter implements IIconRegister
|
||||||
public void renderGasSide(ForgeDirection side, PartPressurizedTube tube)
|
public void renderGasSide(ForgeDirection side, PartPressurizedTube tube)
|
||||||
{
|
{
|
||||||
boolean connected = PartTransmitter.connectionMapContainsSide(tube.getAllCurrentConnections(), side);
|
boolean connected = PartTransmitter.connectionMapContainsSide(tube.getAllCurrentConnections(), side);
|
||||||
renderTransparency(tube.getTransmitterNetwork().refGas.getIcon(), tube.getModelForSide(side, true), new ColourRGBA(1.0, 1.0, 1.0, tube.getTransmitterNetwork().gasScale));
|
renderTransparency(tube.getTransmitterNetwork().refGas.getIcon(), tube.getModelForSide(side, true), new ColourRGBA(1.0, 1.0, 1.0, tube.currentScale));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void renderPart(Icon icon, CCModel cc, double x, double y, double z)
|
public void renderPart(Icon icon, CCModel cc, double x, double y, double z)
|
||||||
|
|
|
@ -3,6 +3,7 @@ package mekanism.common.multipart;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import mekanism.api.gas.Gas;
|
||||||
import mekanism.api.transmitters.ITransmitter;
|
import mekanism.api.transmitters.ITransmitter;
|
||||||
import mekanism.api.transmitters.TransmissionType;
|
import mekanism.api.transmitters.TransmissionType;
|
||||||
import mekanism.client.render.PartTransmitterIcons;
|
import mekanism.client.render.PartTransmitterIcons;
|
||||||
|
@ -32,9 +33,61 @@ public class PartMechanicalPipe extends PartTransmitter<FluidNetwork> implements
|
||||||
|
|
||||||
public static PartTransmitterIcons pipeIcons;
|
public static PartTransmitterIcons pipeIcons;
|
||||||
|
|
||||||
|
public float currentScale;
|
||||||
|
|
||||||
public FluidStack cacheFluid;
|
public FluidStack cacheFluid;
|
||||||
public FluidStack lastWrite;
|
public FluidStack lastWrite;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void update()
|
||||||
|
{
|
||||||
|
if(!world().isRemote)
|
||||||
|
{
|
||||||
|
if(cacheFluid != null)
|
||||||
|
{
|
||||||
|
if(getTransmitterNetwork().fluidStored == null)
|
||||||
|
{
|
||||||
|
getTransmitterNetwork().fluidStored = cacheFluid;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
getTransmitterNetwork().fluidStored.amount += cacheFluid.amount;
|
||||||
|
}
|
||||||
|
|
||||||
|
cacheFluid = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(isActive)
|
||||||
|
{
|
||||||
|
IFluidHandler[] connectedAcceptors = PipeUtils.getConnectedAcceptors(tile());
|
||||||
|
|
||||||
|
for(IFluidHandler container : connectedAcceptors)
|
||||||
|
{
|
||||||
|
ForgeDirection side = ForgeDirection.getOrientation(Arrays.asList(connectedAcceptors).indexOf(container));
|
||||||
|
|
||||||
|
if(container != null)
|
||||||
|
{
|
||||||
|
FluidStack received = container.drain(side, 100, false);
|
||||||
|
|
||||||
|
if(received != null && received.amount != 0)
|
||||||
|
{
|
||||||
|
container.drain(side.getOpposite(), getTransmitterNetwork().emit(received, true), true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
float targetScale = getTransmitterNetwork().fluidScale;
|
||||||
|
|
||||||
|
if(Math.abs(currentScale - targetScale) > 0.01)
|
||||||
|
{
|
||||||
|
currentScale = (9 * currentScale + targetScale) / 10;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
super.update();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onChunkUnload()
|
public void onChunkUnload()
|
||||||
{
|
{
|
||||||
|
@ -221,48 +274,6 @@ public class PartMechanicalPipe extends PartTransmitter<FluidNetwork> implements
|
||||||
return new FluidTankInfo[] {dummyTank.getInfo()};
|
return new FluidTankInfo[] {dummyTank.getInfo()};
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void update()
|
|
||||||
{
|
|
||||||
if(!world().isRemote)
|
|
||||||
{
|
|
||||||
if(cacheFluid != null)
|
|
||||||
{
|
|
||||||
if(getTransmitterNetwork().fluidStored == null)
|
|
||||||
{
|
|
||||||
getTransmitterNetwork().fluidStored = cacheFluid;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
getTransmitterNetwork().fluidStored.amount += cacheFluid.amount;
|
|
||||||
}
|
|
||||||
|
|
||||||
cacheFluid = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(isActive)
|
|
||||||
{
|
|
||||||
IFluidHandler[] connectedAcceptors = PipeUtils.getConnectedAcceptors(tile());
|
|
||||||
|
|
||||||
for(IFluidHandler container : connectedAcceptors)
|
|
||||||
{
|
|
||||||
ForgeDirection side = ForgeDirection.getOrientation(Arrays.asList(connectedAcceptors).indexOf(container));
|
|
||||||
|
|
||||||
if(container != null)
|
|
||||||
{
|
|
||||||
FluidStack received = container.drain(side, 100, false);
|
|
||||||
|
|
||||||
if(received != null && received.amount != 0)
|
|
||||||
{
|
|
||||||
container.drain(side.getOpposite(), getTransmitterNetwork().emit(received, true), true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
super.update();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getTransmitterNetworkSize()
|
public int getTransmitterNetworkSize()
|
||||||
{
|
{
|
||||||
|
|
|
@ -23,14 +23,14 @@ public class PartPressurizedTube extends PartTransmitter<GasNetwork>
|
||||||
{
|
{
|
||||||
public static PartTransmitterIcons tubeIcons;
|
public static PartTransmitterIcons tubeIcons;
|
||||||
|
|
||||||
|
public float currentScale;
|
||||||
|
|
||||||
public GasStack cacheGas;
|
public GasStack cacheGas;
|
||||||
public GasStack lastWrite;
|
public GasStack lastWrite;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void update()
|
public void update()
|
||||||
{
|
{
|
||||||
super.update();
|
|
||||||
|
|
||||||
if(!world().isRemote)
|
if(!world().isRemote)
|
||||||
{
|
{
|
||||||
if(cacheGas != null)
|
if(cacheGas != null)
|
||||||
|
@ -46,6 +46,16 @@ public class PartPressurizedTube extends PartTransmitter<GasNetwork>
|
||||||
cacheGas = null;
|
cacheGas = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
float targetScale = getTransmitterNetwork().gasScale;
|
||||||
|
|
||||||
|
if(Math.abs(currentScale - targetScale) > 0.01)
|
||||||
|
{
|
||||||
|
currentScale = (9 * currentScale + targetScale) / 10;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
super.update();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -103,8 +103,12 @@ public class PacketTransmitterUpdate implements IMekanismPacket
|
||||||
scale = dataStream.readFloat();
|
scale = dataStream.readFloat();
|
||||||
|
|
||||||
if(tileEntity != null)
|
if(tileEntity != null)
|
||||||
|
{
|
||||||
|
if(gasType != null)
|
||||||
{
|
{
|
||||||
((ITransmitter<GasNetwork>)tileEntity).getTransmitterNetwork().refGas = gasType;
|
((ITransmitter<GasNetwork>)tileEntity).getTransmitterNetwork().refGas = gasType;
|
||||||
|
}
|
||||||
|
|
||||||
((ITransmitter<GasNetwork>)tileEntity).getTransmitterNetwork().didTransfer = didGasTransfer;
|
((ITransmitter<GasNetwork>)tileEntity).getTransmitterNetwork().didTransfer = didGasTransfer;
|
||||||
((ITransmitter<GasNetwork>)tileEntity).getTransmitterNetwork().definedScale = scale;
|
((ITransmitter<GasNetwork>)tileEntity).getTransmitterNetwork().definedScale = scale;
|
||||||
}
|
}
|
||||||
|
@ -119,8 +123,12 @@ public class PacketTransmitterUpdate implements IMekanismPacket
|
||||||
scale = dataStream.readFloat();
|
scale = dataStream.readFloat();
|
||||||
|
|
||||||
if(tileEntity != null)
|
if(tileEntity != null)
|
||||||
|
{
|
||||||
|
if(fluidType != null)
|
||||||
{
|
{
|
||||||
((ITransmitter<FluidNetwork>)tileEntity).getTransmitterNetwork().refFluid = fluidType;
|
((ITransmitter<FluidNetwork>)tileEntity).getTransmitterNetwork().refFluid = fluidType;
|
||||||
|
}
|
||||||
|
|
||||||
((ITransmitter<FluidNetwork>)tileEntity).getTransmitterNetwork().didTransfer = didFluidTransfer;
|
((ITransmitter<FluidNetwork>)tileEntity).getTransmitterNetwork().didTransfer = didFluidTransfer;
|
||||||
((ITransmitter<FluidNetwork>)tileEntity).getTransmitterNetwork().definedScale = scale;
|
((ITransmitter<FluidNetwork>)tileEntity).getTransmitterNetwork().definedScale = scale;
|
||||||
}
|
}
|
||||||
|
|
|
@ -459,7 +459,7 @@ public class TileEntityElectricPump extends TileEntityElectricBlock implements I
|
||||||
return new FluidTankInfo[] {fluidTank.getInfo()};
|
return new FluidTankInfo[] {fluidTank.getInfo()};
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return new FluidTankInfo[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Add table
Reference in a new issue