修改遥控器的描述实现方式

This commit is contained in:
17146 2024-07-24 03:51:59 +08:00
parent 5a9e9349a3
commit 15c8e25301
3 changed files with 23 additions and 15 deletions

View file

@ -54,6 +54,8 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
private boolean swinging;
private boolean lastloop;
private boolean linked = false;
private String controller;
private long lastSwing;
public String animationprocedure = "empty";
@ -110,11 +112,17 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
@Override
public void addAdditionalSaveData(CompoundTag compound) {
super.addAdditionalSaveData(compound);
compound.putBoolean("Linked", this.linked);
compound.putString("Controller", this.controller);
}
@Override
public void readAdditionalSaveData(CompoundTag compound) {
super.readAdditionalSaveData(compound);
this.linked = compound.getBoolean("Linked");
this.controller = compound.getString("Controller");
}
@Override
@ -136,10 +144,10 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
return InteractionResult.sidedSuccess(this.level().isClientSide());
}
this.getPersistentData().putString("controller", player.getStringUUID());
this.linked = true;
this.controller = player.getStringUUID();
Monitor.link(stack, this.getId());
Monitor.link(stack, this.getStringUUID());
player.displayClientMessage(Component.translatable("des.target.monitor.linked").withStyle(ChatFormatting.GREEN), true);
if (player instanceof ServerPlayer serverPlayer) {
@ -155,12 +163,12 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
return InteractionResult.sidedSuccess(this.level().isClientSide());
}
this.getPersistentData().putString("controller", "none");
this.controller = "none";
this.linked = false;
Monitor.disLink(stack);
Monitor.disLink(stack);
player.displayClientMessage(Component.translatable("des.target.monitor.unlinked").withStyle(ChatFormatting.RED), true);
if (player instanceof ServerPlayer serverPlayer) {
serverPlayer.level().playSound(null, serverPlayer.getOnPos(), Objects.requireNonNull(ForgeRegistries.SOUND_EVENTS.getValue(new ResourceLocation("entity.arrow.hit_player"))), SoundSource.PLAYERS, 0.5F, 1);
}

View file

@ -18,18 +18,18 @@ public class Monitor extends Item {
super(new Properties().stacksTo(1));
}
public static void link(ItemStack itemstack, int id) {
public static void link(ItemStack itemstack, String id) {
ItemNBTTool.setBoolean(itemstack, LINKED, true);
ItemNBTTool.setInt(itemstack, LINKED_DRONE, id);
itemstack.getOrCreateTag().putString(LINKED_DRONE, id);
}
public static void disLink(ItemStack itemstack) {
ItemNBTTool.setBoolean(itemstack, LINKED, false);
ItemNBTTool.setInt(itemstack, LINKED_DRONE, -1);
itemstack.getOrCreateTag().putString(LINKED_DRONE, "none");
}
@Override
public void appendHoverText(ItemStack stack, Level world, List<Component> list, TooltipFlag flag) {
TooltipTool.addMonitorTips(list, ItemNBTTool.getInt(stack, LINKED_DRONE, -1));
TooltipTool.addMonitorTips(list, stack.getOrCreateTag().getString(LINKED_DRONE));
}
}

View file

@ -5,7 +5,6 @@ import net.minecraft.ChatFormatting;
import net.minecraft.client.Minecraft;
import net.minecraft.client.gui.screens.Screen;
import net.minecraft.network.chat.Component;
import net.minecraft.world.entity.Entity;
import net.minecraft.world.entity.player.Player;
import net.minecraft.world.item.ItemStack;
import net.minecraftforge.common.capabilities.ForgeCapabilities;
@ -119,16 +118,17 @@ public class TooltipTool {
);
}
public static void addMonitorTips(List<Component> tooltip, int id) {
if (id == -1) return;
public static void addMonitorTips(List<Component> tooltip, String id) {
if (id.equals("none")) return;
Player player = Minecraft.getInstance().player;
if (player == null) return;
Entity entity = player.level().getEntity(id);
if (entity == null) return;
DroneEntity entity = player.level().getEntitiesOfClass(DroneEntity.class, player.getBoundingBox().inflate(256))
.stream().filter(e -> e.getStringUUID().equals(id)).findFirst().orElse(null);
if (!(entity instanceof DroneEntity)) return;
tooltip.add(Component.literal("" + entity));
if (entity == null) return;
tooltip.add(Component.literal(""));