Fix maintenance cover (#1496)
* New public variable init Initiated new public variable which is calculate how much damage get turbine rotor per time, its needed to compare with actual rotor durability. * Fix cover logic Rewrited due a bug maintenance cover logic which is check turbine rotor needed maintenance or not. * Added&rewrited some features for need maintenance. Added new high accuracy mod for need maintenance cover which check rotor state. Fixed old version low accuracy mod. * redo older changes removed variable * fix some shit forgot brakets * Cleanup & reformat code thanks Dimach for help with that
This commit is contained in:
parent
0beea9037c
commit
8a61e384f0
1 changed files with 69 additions and 41 deletions
|
@ -7,13 +7,16 @@ import gregtech.api.items.GT_MetaGenerated_Tool;
|
|||
import gregtech.api.metatileentity.implementations.GT_MetaTileEntity_MultiBlockBase;
|
||||
import gregtech.api.util.GT_CoverBehavior;
|
||||
import gregtech.api.util.GT_Utility;
|
||||
import gregtech.common.items.GT_MetaGenerated_Tool_01;
|
||||
import net.minecraft.entity.player.EntityPlayer;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraftforge.fluids.Fluid;
|
||||
|
||||
public class GT_Cover_NeedMaintainance extends GT_CoverBehavior {
|
||||
|
||||
private boolean isRotor(ItemStack aRotor) {
|
||||
return !(aRotor == null || !(aRotor.getItem() instanceof GT_MetaGenerated_Tool) || aRotor.getItemDamage() < 170 || aRotor.getItemDamage() > 176);
|
||||
}
|
||||
|
||||
public int doCoverThings(byte aSide, byte aInputRedstone, int aCoverID, int aCoverVariable, ICoverable aTileEntity, long aTimer) {
|
||||
boolean needsRepair = false;
|
||||
if (aTileEntity instanceof IGregTechTileEntity) {
|
||||
|
@ -23,31 +26,24 @@ public class GT_Cover_NeedMaintainance extends GT_CoverBehavior {
|
|||
GT_MetaTileEntity_MultiBlockBase multi = (GT_MetaTileEntity_MultiBlockBase) mTileEntity;
|
||||
int ideal = multi.getIdealStatus();
|
||||
int real = multi.getRepairStatus();
|
||||
if ((aCoverVariable == 0 || aCoverVariable == 1) && (ideal - real > 0)) {
|
||||
needsRepair = true;
|
||||
}
|
||||
if ((aCoverVariable == 2 || aCoverVariable == 3) && (ideal - real > 1)) {
|
||||
needsRepair = true;
|
||||
}
|
||||
if ((aCoverVariable == 4 || aCoverVariable == 5) && (ideal - real > 2)) {
|
||||
needsRepair = true;
|
||||
}
|
||||
if ((aCoverVariable == 6 || aCoverVariable == 7) && (ideal - real > 3)) {
|
||||
needsRepair = true;
|
||||
}
|
||||
if ((aCoverVariable == 8 || aCoverVariable == 9) && (ideal - real > 4)) {
|
||||
needsRepair = true;
|
||||
}
|
||||
if(aCoverVariable == 10 || aCoverVariable == 11){
|
||||
if(multi.getRealInventory()[1]==null || multi.getRealInventory()[1].getItem()!=GT_MetaGenerated_Tool_01.INSTANCE && multi.getRealInventory()[1].getItemDamage()<170){needsRepair = true;}
|
||||
else{
|
||||
ItemStack tTurbine = multi.getRealInventory()[1];
|
||||
long tMax = GT_MetaGenerated_Tool.getToolMaxDamage(tTurbine);
|
||||
long tCur = GT_MetaGenerated_Tool.getToolDamage(tTurbine);
|
||||
if(tCur < tMax*2/10)
|
||||
needsRepair = true;
|
||||
}
|
||||
|
||||
ItemStack tRotor = multi.getRealInventory()[1];
|
||||
int coverVar = aCoverVariable >>> 1;
|
||||
if (coverVar < 5) {
|
||||
if (ideal - real > coverVar)
|
||||
needsRepair = true;
|
||||
} else if (coverVar == 5 || coverVar == 6) {
|
||||
if (isRotor(tRotor)) {
|
||||
long tMax = GT_MetaGenerated_Tool.getToolMaxDamage(tRotor);
|
||||
long tCur = GT_MetaGenerated_Tool.getToolDamage(tRotor);
|
||||
if (coverVar == 5) {
|
||||
needsRepair = (tCur >= tMax * 8 / 10);
|
||||
} else {
|
||||
long mExpectedDamage = Math.round(Math.min(multi.mEUt / multi.damageFactorLow, Math.pow(multi.mEUt, multi.damageFactorHigh)));
|
||||
needsRepair = tCur + mExpectedDamage * 2 >= tMax;
|
||||
}
|
||||
} else {
|
||||
needsRepair = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -61,21 +57,53 @@ public class GT_Cover_NeedMaintainance extends GT_CoverBehavior {
|
|||
}
|
||||
|
||||
public int onCoverScrewdriverclick(byte aSide, int aCoverID, int aCoverVariable, ICoverable aTileEntity, EntityPlayer aPlayer, float aX, float aY, float aZ) {
|
||||
aCoverVariable = (aCoverVariable + (aPlayer.isSneaking()? -1 : 1)) % 12;
|
||||
if(aCoverVariable <0){aCoverVariable = 11;}
|
||||
switch(aCoverVariable) {
|
||||
case 0: GT_Utility.sendChatToPlayer(aPlayer, trans("056", "Emit if 1 Maintenance Needed")); break;
|
||||
case 1: GT_Utility.sendChatToPlayer(aPlayer, trans("057", "Emit if 1 Maintenance Needed(inverted)")); break;
|
||||
case 2: GT_Utility.sendChatToPlayer(aPlayer, trans("058", "Emit if 2 Maintenance Needed")); break;
|
||||
case 3: GT_Utility.sendChatToPlayer(aPlayer, trans("059", "Emit if 2 Maintenance Needed(inverted)")); break;
|
||||
case 4: GT_Utility.sendChatToPlayer(aPlayer, trans("060", "Emit if 3 Maintenance Needed")); break;
|
||||
case 5: GT_Utility.sendChatToPlayer(aPlayer, trans("061", "Emit if 3 Maintenance Needed(inverted)")); break;
|
||||
case 6: GT_Utility.sendChatToPlayer(aPlayer, trans("062", "Emit if 4 Maintenance Needed")); break;
|
||||
case 7: GT_Utility.sendChatToPlayer(aPlayer, trans("063", "Emit if 4 Maintenance Needed(inverted)")); break;
|
||||
case 8: GT_Utility.sendChatToPlayer(aPlayer, trans("064", "Emit if 5 Maintenance Needed")); break;
|
||||
case 9: GT_Utility.sendChatToPlayer(aPlayer, trans("065", "Emit if 5 Maintenance Needed(inverted)")); break;
|
||||
case 10: GT_Utility.sendChatToPlayer(aPlayer, trans("066", "Emit if rotor needs maintenance")); break;
|
||||
case 11: GT_Utility.sendChatToPlayer(aPlayer, trans("067", "Emit if rotor needs maintenance(inverted)")); break;
|
||||
aCoverVariable = (aCoverVariable + (aPlayer.isSneaking() ? -1 : 1)) % 14;
|
||||
if (aCoverVariable < 0) {
|
||||
aCoverVariable = 13;
|
||||
}
|
||||
switch (aCoverVariable) {
|
||||
case 0:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("056", "Emit if 1 Maintenance Needed"));
|
||||
break;
|
||||
case 1:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("057", "Emit if 1 Maintenance Needed(inverted)"));
|
||||
break;
|
||||
case 2:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("058", "Emit if 2 Maintenance Needed"));
|
||||
break;
|
||||
case 3:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("059", "Emit if 2 Maintenance Needed(inverted)"));
|
||||
break;
|
||||
case 4:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("060", "Emit if 3 Maintenance Needed"));
|
||||
break;
|
||||
case 5:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("061", "Emit if 3 Maintenance Needed(inverted)"));
|
||||
break;
|
||||
case 6:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("062", "Emit if 4 Maintenance Needed"));
|
||||
break;
|
||||
case 7:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("063", "Emit if 4 Maintenance Needed(inverted)"));
|
||||
break;
|
||||
case 8:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("064", "Emit if 5 Maintenance Needed"));
|
||||
break;
|
||||
case 9:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("065", "Emit if 5 Maintenance Needed(inverted)"));
|
||||
break;
|
||||
case 10:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("066", "Emit if rotor needs maintenance low accuracy mod"));
|
||||
break;
|
||||
case 11:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("067", "Emit if rotor needs maintenance low accuracy mod(inverted)"));
|
||||
break;
|
||||
case 12:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("068", "Emit if rotor needs maintenance high accuracy mod"));
|
||||
break;
|
||||
case 13:
|
||||
GT_Utility.sendChatToPlayer(aPlayer, trans("069", "Emit if rotor needs maintenance high accuracy mod(inverted)"));
|
||||
break;
|
||||
}
|
||||
return aCoverVariable;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue