/
TileEntityShardCompressor.java
194 lines (171 loc) · 7.23 KB
/
TileEntityShardCompressor.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
package dev.anime.gems.tile;
import com.google.common.collect.ImmutableMap;
import dev.anime.gems.Main;
import dev.anime.gems.network.SyncTEMessage;
import dev.anime.gems.proxies.ServerProxy.TimeType;
import dev.anime.gems.recipes.ProcessingRecipe;
import dev.anime.gems.recipes.ProcessingRecipes;
import dev.anime.gems.utils.EnergyStorage;
import dev.anime.gems.utils.ItemStackProperty;
import dev.anime.gems.utils.RecipeItemStackHandler;
import net.minecraft.block.state.IBlockState;
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.network.NetworkManager;
import net.minecraft.network.play.server.SPacketUpdateTileEntity;
import net.minecraft.tileentity.TileEntityFurnace;
import net.minecraft.util.EnumFacing;
import net.minecraft.util.ITickable;
import net.minecraft.util.ResourceLocation;
import net.minecraft.util.math.BlockPos;
import net.minecraft.world.World;
import net.minecraftforge.common.animation.ITimeValue;
import net.minecraftforge.common.animation.TimeValues.VariableValue;
import net.minecraftforge.common.capabilities.Capability;
import net.minecraftforge.common.model.animation.CapabilityAnimation;
import net.minecraftforge.common.model.animation.IAnimationStateMachine;
import net.minecraftforge.common.property.IExtendedBlockState;
import net.minecraftforge.energy.CapabilityEnergy;
import net.minecraftforge.fml.common.network.NetworkRegistry.TargetPoint;
import net.minecraftforge.items.CapabilityItemHandler;
public class TileEntityShardCompressor extends TileEntityBase implements ITickable {
private final EnergyStorage storage = new EnergyStorage(30000, 300, 0, false);
private int fuelTimeRemaining, fuelTimeMax, currentItemProcessTime;
public static final int FINISH_PROCESS_TIME = 300;
private ProcessingRecipe recipe;
private final IAnimationStateMachine asm;
private ITimeValue move;
public TileEntityShardCompressor() {
this.items = new RecipeItemStackHandler(3, 1, 1) {
protected void onContentsChanged(int slot) {
super.onContentsChanged(slot);
getWorld().setBlockState(getPos(), ((IExtendedBlockState) getWorld().getBlockState(pos)).withProperty(ItemStackProperty.ITEMSTACK, getStackInSlot(slot).copy()), 3);
}
};
move = Main.PROXY.createTimeValue(TimeType.VARIABLE, 0);
asm = Main.PROXY.load(new ResourceLocation(Main.MODID, "asms/block/shard_compressor.json"), ImmutableMap.of("move", move));
}
@Override
public void update() {
if (!world.isRemote) {
if ((recipe != null && recipe.matches(ProcessingRecipes.transformArray(((RecipeItemStackHandler) items).getItems()), true, false)) || (recipe = ProcessingRecipes.COMPRESSOR_RECIPES.findRecipe(((RecipeItemStackHandler) items).getItems(), false, false)) != null) {
if (fuelTimeRemaining > 0 || canBurnFuel()) {
currentItemProcessTime++;
if (currentItemProcessTime >= FINISH_PROCESS_TIME) {
items.extractItem(1, recipe.getInput(0).getAsStack().getCount(), false);
items.insertItem(2, recipe.getOutput(0).getAsStack().copy(), false);
currentItemProcessTime = 0;
}
// Make sure the client is synced to the server while the animation is going.
if (currentItemProcessTime == 200 || currentItemProcessTime == 225 || currentItemProcessTime == 250 || currentItemProcessTime == 275 || currentItemProcessTime == 300) Main.WRAPPER.sendToAllTracking(new SyncTEMessage(getPos(), getUpdateTag()), new TargetPoint(world.provider.getDimension(), pos.getX(), pos.getY(), pos.getZ(), 64));
markDirty();
}
}
fuelTimeRemaining--;
} else { // Animation update client side only.
if (asm.currentState().equals("move")) { // Simulate processing on client while animating.
if (fuelTimeRemaining > 0) {
currentItemProcessTime++;
fuelTimeRemaining--;
}
((VariableValue)move).setValue((currentItemProcessTime - 200) / 99F); // Update animation value.
}
if (currentItemProcessTime >= 200) { // Start of animation.
if (asm.currentState().equals("default")) {
asm.transition("move");
}
}
if (currentItemProcessTime == 300 && asm.currentState().equals("move")) { // End the animation and reset values to the start of the animation.
asm.transition("default");
currentItemProcessTime = 0;
((VariableValue)move).setValue(0);
}
}
}
private boolean canBurnFuel() {
if (items.getStackInSlot(0).isEmpty() && storage.getEnergyStored() < 300) return false;
int burnTime = TileEntityFurnace.getItemBurnTime(items.getStackInSlot(0));
if (burnTime == 0) {
burnTime = 300;
storage.extractInternal(900, false);
}
if (burnTime <= 0) return false;
fuelTimeRemaining += burnTime;
fuelTimeMax = burnTime;
items.extractItem(0, 1, false);
return true;
}
@Override
public boolean shouldRefresh(World world, BlockPos pos, IBlockState oldState, IBlockState newState) {
return oldState.getBlock() != newState.getBlock();
}
@Override
public boolean hasFastRenderer() {
return true;
}
@Override
public int getDataMax() {
return 3;
}
@Override
public int getData(int id) {
switch (id) {
case 0: return fuelTimeRemaining;
case 1: return currentItemProcessTime;
case 2: return fuelTimeMax;
default: return 0;
}
}
@Override
public void setData(int id, int value) {
switch (id) {
case 0: fuelTimeRemaining = value;
case 1: currentItemProcessTime = value;
case 2: fuelTimeMax = value;
}
}
@Override
public NBTTagCompound writeToNBT(NBTTagCompound compound) {
super.writeToNBT(compound);
compound.setInteger("fuelTime", fuelTimeRemaining);
compound.setInteger("fuelTimeMax", fuelTimeMax);
compound.setInteger("processTime", currentItemProcessTime);
compound.setTag("items", items.serializeNBT());
storage.writeToNBT(compound);
return compound;
}
@Override
public void readFromNBT(NBTTagCompound compound) {
super.readFromNBT(compound);
fuelTimeRemaining = compound.getInteger("fuelTime");
fuelTimeMax = compound.getInteger("fuelTimeMax");
currentItemProcessTime = compound.getInteger("processTime");
items.deserializeNBT(compound.getCompoundTag("items"));
storage.readFromNBT(compound);
}
@Override
public <T> T getCapability(Capability<T> capability, EnumFacing facing) {
if (capability == CapabilityItemHandler.ITEM_HANDLER_CAPABILITY) {
return CapabilityItemHandler.ITEM_HANDLER_CAPABILITY.cast(items);
} else if (capability == CapabilityAnimation.ANIMATION_CAPABILITY) {
return CapabilityAnimation.ANIMATION_CAPABILITY.cast(asm);
} else if (capability == CapabilityEnergy.ENERGY){
return CapabilityEnergy.ENERGY.cast(storage);
} else return super.getCapability(capability, facing);
}
@Override
public boolean hasCapability(Capability<?> capability, EnumFacing facing) {
return getCapability(capability, facing) != null || super.hasCapability(capability, facing);
}
@Override
public SPacketUpdateTileEntity getUpdatePacket() {
return new SPacketUpdateTileEntity(pos, 3, getUpdateTag());
}
@Override
public NBTTagCompound getUpdateTag() {
return writeToNBT(new NBTTagCompound());
}
@Override
public void onDataPacket(NetworkManager net, SPacketUpdateTileEntity pkt) {
handleUpdateTag(pkt.getNbtCompound());
}
}