调整电池写法

This commit is contained in:
17146 2025-03-11 18:46:42 +08:00
parent dcf4f69d01
commit 4f2824958e

View file

@ -2,13 +2,10 @@ package com.atsuishio.superbwarfare.item;
import com.atsuishio.superbwarfare.capability.energy.ItemEnergyProvider; import com.atsuishio.superbwarfare.capability.energy.ItemEnergyProvider;
import com.atsuishio.superbwarfare.client.tooltip.component.CellImageComponent; import com.atsuishio.superbwarfare.client.tooltip.component.CellImageComponent;
import com.atsuishio.superbwarfare.init.ModItems;
import net.minecraft.nbt.CompoundTag; import net.minecraft.nbt.CompoundTag;
import net.minecraft.world.entity.Entity;
import net.minecraft.world.inventory.tooltip.TooltipComponent; import net.minecraft.world.inventory.tooltip.TooltipComponent;
import net.minecraft.world.item.Item; import net.minecraft.world.item.Item;
import net.minecraft.world.item.ItemStack; import net.minecraft.world.item.ItemStack;
import net.minecraft.world.level.Level;
import net.minecraftforge.common.capabilities.ForgeCapabilities; import net.minecraftforge.common.capabilities.ForgeCapabilities;
import net.minecraftforge.common.capabilities.ICapabilityProvider; import net.minecraftforge.common.capabilities.ICapabilityProvider;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
@ -20,13 +17,12 @@ import java.util.function.Supplier;
public class BatteryItem extends Item { public class BatteryItem extends Item {
private final Supplier<Integer> energyCapacity; private final Supplier<Integer> energyCapacity;
public int maxEnergy;
public static int MAX_ENERGY = 0;
public BatteryItem(int maxEnergy, Properties properties) { public BatteryItem(int maxEnergy, Properties properties) {
super(new Properties().stacksTo(1)); super(properties.stacksTo(1));
this.maxEnergy = maxEnergy;
this.energyCapacity = () -> maxEnergy; this.energyCapacity = () -> maxEnergy;
MAX_ENERGY = maxEnergy;
} }
@Override @Override
@ -39,7 +35,7 @@ public class BatteryItem extends Item {
pStack.getCapability(ForgeCapabilities.ENERGY).ifPresent( pStack.getCapability(ForgeCapabilities.ENERGY).ifPresent(
e -> energy.set(e.getEnergyStored()) e -> energy.set(e.getEnergyStored())
); );
return energy.get() != MAX_ENERGY; return energy.get() != maxEnergy;
} }
@Override @Override
@ -49,7 +45,7 @@ public class BatteryItem extends Item {
e -> energy.set(e.getEnergyStored()) e -> energy.set(e.getEnergyStored())
); );
return Math.round((float) energy.get() * 13.0F / MAX_ENERGY); return Math.round((float) energy.get() * 13.0F / maxEnergy);
} }
@Override @Override
@ -62,19 +58,6 @@ public class BatteryItem extends Item {
return 0xFFFF00; return 0xFFFF00;
} }
@Override
public void inventoryTick(ItemStack stack, Level world, Entity entity, int slot, boolean selected) {
super.inventoryTick(stack, world, entity, slot, selected);
}
public static ItemStack getGunInstance() {
ItemStack stack = new ItemStack(ModItems.TASER.get());
stack.getCapability(ForgeCapabilities.ENERGY).ifPresent(
energy -> energy.receiveEnergy(MAX_ENERGY, false)
);
return stack;
}
@Override @Override
public @NotNull Optional<TooltipComponent> getTooltipImage(@NotNull ItemStack pStack) { public @NotNull Optional<TooltipComponent> getTooltipImage(@NotNull ItemStack pStack) {
return Optional.of(new CellImageComponent(pStack)); return Optional.of(new CellImageComponent(pStack));