修改遥控器的描述实现方式
This commit is contained in:
parent
5a9e9349a3
commit
15c8e25301
3 changed files with 23 additions and 15 deletions
|
@ -54,6 +54,8 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
|
||||||
private boolean swinging;
|
private boolean swinging;
|
||||||
private boolean lastloop;
|
private boolean lastloop;
|
||||||
private boolean linked = false;
|
private boolean linked = false;
|
||||||
|
private String controller;
|
||||||
|
|
||||||
private long lastSwing;
|
private long lastSwing;
|
||||||
|
|
||||||
public String animationprocedure = "empty";
|
public String animationprocedure = "empty";
|
||||||
|
@ -110,11 +112,17 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
|
||||||
@Override
|
@Override
|
||||||
public void addAdditionalSaveData(CompoundTag compound) {
|
public void addAdditionalSaveData(CompoundTag compound) {
|
||||||
super.addAdditionalSaveData(compound);
|
super.addAdditionalSaveData(compound);
|
||||||
|
|
||||||
|
compound.putBoolean("Linked", this.linked);
|
||||||
|
compound.putString("Controller", this.controller);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void readAdditionalSaveData(CompoundTag compound) {
|
public void readAdditionalSaveData(CompoundTag compound) {
|
||||||
super.readAdditionalSaveData(compound);
|
super.readAdditionalSaveData(compound);
|
||||||
|
|
||||||
|
this.linked = compound.getBoolean("Linked");
|
||||||
|
this.controller = compound.getString("Controller");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -136,10 +144,10 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
|
||||||
return InteractionResult.sidedSuccess(this.level().isClientSide());
|
return InteractionResult.sidedSuccess(this.level().isClientSide());
|
||||||
}
|
}
|
||||||
|
|
||||||
this.getPersistentData().putString("controller", player.getStringUUID());
|
|
||||||
this.linked = true;
|
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);
|
player.displayClientMessage(Component.translatable("des.target.monitor.linked").withStyle(ChatFormatting.GREEN), true);
|
||||||
|
|
||||||
if (player instanceof ServerPlayer serverPlayer) {
|
if (player instanceof ServerPlayer serverPlayer) {
|
||||||
|
@ -155,12 +163,12 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
|
||||||
return InteractionResult.sidedSuccess(this.level().isClientSide());
|
return InteractionResult.sidedSuccess(this.level().isClientSide());
|
||||||
}
|
}
|
||||||
|
|
||||||
this.getPersistentData().putString("controller", "none");
|
this.controller = "none";
|
||||||
|
|
||||||
this.linked = false;
|
this.linked = false;
|
||||||
Monitor.disLink(stack);
|
|
||||||
|
|
||||||
|
Monitor.disLink(stack);
|
||||||
player.displayClientMessage(Component.translatable("des.target.monitor.unlinked").withStyle(ChatFormatting.RED), true);
|
player.displayClientMessage(Component.translatable("des.target.monitor.unlinked").withStyle(ChatFormatting.RED), true);
|
||||||
|
|
||||||
if (player instanceof ServerPlayer serverPlayer) {
|
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);
|
serverPlayer.level().playSound(null, serverPlayer.getOnPos(), Objects.requireNonNull(ForgeRegistries.SOUND_EVENTS.getValue(new ResourceLocation("entity.arrow.hit_player"))), SoundSource.PLAYERS, 0.5F, 1);
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,18 +18,18 @@ public class Monitor extends Item {
|
||||||
super(new Properties().stacksTo(1));
|
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.setBoolean(itemstack, LINKED, true);
|
||||||
ItemNBTTool.setInt(itemstack, LINKED_DRONE, id);
|
itemstack.getOrCreateTag().putString(LINKED_DRONE, id);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void disLink(ItemStack itemstack) {
|
public static void disLink(ItemStack itemstack) {
|
||||||
ItemNBTTool.setBoolean(itemstack, LINKED, false);
|
ItemNBTTool.setBoolean(itemstack, LINKED, false);
|
||||||
ItemNBTTool.setInt(itemstack, LINKED_DRONE, -1);
|
itemstack.getOrCreateTag().putString(LINKED_DRONE, "none");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void appendHoverText(ItemStack stack, Level world, List<Component> list, TooltipFlag flag) {
|
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));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,6 @@ import net.minecraft.ChatFormatting;
|
||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.Minecraft;
|
||||||
import net.minecraft.client.gui.screens.Screen;
|
import net.minecraft.client.gui.screens.Screen;
|
||||||
import net.minecraft.network.chat.Component;
|
import net.minecraft.network.chat.Component;
|
||||||
import net.minecraft.world.entity.Entity;
|
|
||||||
import net.minecraft.world.entity.player.Player;
|
import net.minecraft.world.entity.player.Player;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.ItemStack;
|
||||||
import net.minecraftforge.common.capabilities.ForgeCapabilities;
|
import net.minecraftforge.common.capabilities.ForgeCapabilities;
|
||||||
|
@ -119,16 +118,17 @@ public class TooltipTool {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void addMonitorTips(List<Component> tooltip, int id) {
|
public static void addMonitorTips(List<Component> tooltip, String id) {
|
||||||
if (id == -1) return;
|
if (id.equals("none")) return;
|
||||||
|
|
||||||
Player player = Minecraft.getInstance().player;
|
Player player = Minecraft.getInstance().player;
|
||||||
if (player == null) return;
|
if (player == null) return;
|
||||||
|
|
||||||
Entity entity = player.level().getEntity(id);
|
DroneEntity entity = player.level().getEntitiesOfClass(DroneEntity.class, player.getBoundingBox().inflate(256))
|
||||||
if (entity == null) return;
|
.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(""));
|
tooltip.add(Component.literal(""));
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue