增加无人机自动解绑功能

This commit is contained in:
17146 2024-07-24 22:47:30 +08:00
parent 231302de0a
commit ed538bc7ce
3 changed files with 48 additions and 46 deletions

View file

@ -46,6 +46,7 @@ import software.bernie.geckolib.core.object.PlayState;
import software.bernie.geckolib.util.GeckoLibUtil; import software.bernie.geckolib.util.GeckoLibUtil;
import java.util.Objects; import java.util.Objects;
import java.util.UUID;
public class DroneEntity extends PathfinderMob implements GeoEntity { public class DroneEntity extends PathfinderMob implements GeoEntity {
public static final EntityDataAccessor<String> ANIMATION = SynchedEntityData.defineId(DroneEntity.class, EntityDataSerializers.STRING); public static final EntityDataAccessor<String> ANIMATION = SynchedEntityData.defineId(DroneEntity.class, EntityDataSerializers.STRING);
@ -138,65 +139,61 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
super.baseTick(); super.baseTick();
if (this.getPersistentData().getBoolean("left")) { if (this.getPersistentData().getBoolean("left")) {
moveX = -1.5f; this.moveX = -1.5f;
} }
if (this.getPersistentData().getBoolean("right")) { if (this.getPersistentData().getBoolean("right")) {
moveX = 1.5f; this.moveX = 1.5f;
} }
if (!this.getPersistentData().getBoolean("left") && !this.getPersistentData().getBoolean("right")) { if (!this.getPersistentData().getBoolean("left") && !this.getPersistentData().getBoolean("right")) {
if (moveX >= 0) { if (this.moveX >= 0) {
moveX = Mth.clamp(moveX - 0.3f,0,1); this.moveX = Mth.clamp(this.moveX - 0.3f, 0, 1);
} else { } else {
moveX = Mth.clamp(moveX + 0.3f,-1,0); this.moveX = Mth.clamp(this.moveX + 0.3f, -1, 0);
} }
} }
if (this.getPersistentData().getBoolean("forward")) { if (this.getPersistentData().getBoolean("forward")) {
moveZ = -1.5f; this.moveZ = -1.5f;
} }
if (this.getPersistentData().getBoolean("backward")) { if (this.getPersistentData().getBoolean("backward")) {
moveZ = 1.5f; this.moveZ = 1.5f;
} }
if (!this.getPersistentData().getBoolean("forward") && !this.getPersistentData().getBoolean("backward")) { if (!this.getPersistentData().getBoolean("forward") && !this.getPersistentData().getBoolean("backward")) {
if (moveZ >= 0) { if (this.moveZ >= 0) {
moveZ = Mth.clamp(moveZ - 0.3f,0,1); this.moveZ = Mth.clamp(this.moveZ - 0.3f, 0, 1);
} else { } else {
moveZ = Mth.clamp(moveZ + 0.3f,-1,0); this.moveZ = Mth.clamp(this.moveZ + 0.3f, -1, 0);
} }
} }
if (this.getPersistentData().getBoolean("up")) { if (this.getPersistentData().getBoolean("up")) {
moveY = -1.5f; this.moveY = -1.5f;
} }
if (this.getPersistentData().getBoolean("down")) { if (this.getPersistentData().getBoolean("down")) {
moveY = 1.5f; this.moveY = 1.5f;
} }
if (!this.getPersistentData().getBoolean("up") && !this.getPersistentData().getBoolean("down")) { if (!this.getPersistentData().getBoolean("up") && !this.getPersistentData().getBoolean("down")) {
if (moveY >= 0) { if (this.moveY >= 0) {
moveY = Mth.clamp(moveY - 0.3f,0,1); this.moveY = Mth.clamp(this.moveY - 0.3f, 0, 1);
} else { } else {
moveY = Mth.clamp(moveY + 0.3f,-1,0); this.moveY = Mth.clamp(this.moveY + 0.3f, -1, 0);
} }
} }
LivingEntity control = this.level().getEntitiesOfClass(Player.class, this.getBoundingBox().inflate(512)) LivingEntity control = this.level().getEntitiesOfClass(Player.class, this.getBoundingBox().inflate(512))
.stream().filter(e -> e.getStringUUID().equals(this.entityData.get(CONTROLLER))).findFirst().orElse(null); .stream().filter(e -> e.getStringUUID().equals(this.entityData.get(CONTROLLER))).findFirst().orElse(null);
if (this.getPersistentData().getBoolean("left") this.move = this.getPersistentData().getBoolean("left")
|| this.getPersistentData().getBoolean("right") || this.getPersistentData().getBoolean("right")
|| this.getPersistentData().getBoolean("forward") || this.getPersistentData().getBoolean("forward")
|| this.getPersistentData().getBoolean("backward") || this.getPersistentData().getBoolean("backward")
|| this.getPersistentData().getBoolean("up") || this.getPersistentData().getBoolean("up")
|| this.getPersistentData().getBoolean("down")) { || this.getPersistentData().getBoolean("down");
move = true;
} else {
move = false;
}
if (move || !this.onGround()) { if (this.move || !this.onGround()) {
this.level().playSound(null, this.getOnPos(), TargetModSounds.DRONE_SOUND.get(), SoundSource.AMBIENT, 3, 1); this.level().playSound(null, this.getOnPos(), TargetModSounds.DRONE_SOUND.get(), SoundSource.AMBIENT, 3, 1);
if (control != null) { if (control != null) {
ItemStack stack = control.getMainHandItem(); ItemStack stack = control.getMainHandItem();
@ -207,30 +204,28 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
} }
Vec3 vec = this.getDeltaMovement(); Vec3 vec = this.getDeltaMovement();
if (this.getDeltaMovement().horizontalDistanceSqr() < 1) { if (this.getDeltaMovement().horizontalDistanceSqr() < 1) {
if (move) { if (this.move) {
this.setDeltaMovement(vec.multiply(1.04, 1, 1.04)); this.setDeltaMovement(vec.multiply(1.04, 1, 1.04));
} }
} }
if (this.getPersistentData().getBoolean("firing")) { if (this.getPersistentData().getBoolean("firing")) {
if (control instanceof Player player) { if (control instanceof Player player) {
DroneDrop(player); droneDrop(player);
} }
this.getPersistentData().putBoolean("firing",false); this.getPersistentData().putBoolean("firing", false);
} }
this.refreshDimensions(); this.refreshDimensions();
} }
private void DroneDrop(Player player) { private void droneDrop(Player player) {
Level level = player.level(); Level level = player.level();
if (!level.isClientSide()) { if (!level.isClientSide()) {
DroneGrenadeEntity droneGrenadeEntity = new DroneGrenadeEntity(player, level); DroneGrenadeEntity droneGrenadeEntity = new DroneGrenadeEntity(player, level);
droneGrenadeEntity.setPos(this.getX(), this.getY(), this.getZ()); droneGrenadeEntity.setPos(this.getX(), this.getY(), this.getZ());
droneGrenadeEntity.shoot(0, -1, 0, 0,0.5f); droneGrenadeEntity.shoot(0, -1, 0, 0, 0.5f);
level.addFreshEntity(droneGrenadeEntity); level.addFreshEntity(droneGrenadeEntity);
} }
} }
@ -278,7 +273,7 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
} }
} }
} }
} else if (stack.isEmpty()&& player.isCrouching()) { } else if (stack.isEmpty() && player.isCrouching()) {
if (!this.level().isClientSide()) this.discard(); if (!this.level().isClientSide()) this.discard();
ItemHandlerHelper.giveItemToPlayer(player, new ItemStack(TargetModItems.DRONE_SPAWN_EGG.get())); ItemHandlerHelper.giveItemToPlayer(player, new ItemStack(TargetModItems.DRONE_SPAWN_EGG.get()));
} }
@ -296,35 +291,44 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
if (stack.getOrCreateTag().getBoolean("Using")) { if (stack.getOrCreateTag().getBoolean("Using")) {
this.setYRot(control.getYRot() + 180); this.setYRot(control.getYRot() + 180);
this.yRotO = this.getYRot(); this.yRotO = this.getYRot();
this.setXRot(Mth.clamp(control.getXRot(),-25,95)); this.setXRot(Mth.clamp(control.getXRot(), -25, 95));
this.setRot(this.getYRot(), this.getXRot()); this.setRot(this.getYRot(), this.getXRot());
this.yBodyRot = control.getYRot() + 180; this.yBodyRot = control.getYRot() + 180;
this.yHeadRot = control.getYRot() + 180; this.yHeadRot = control.getYRot() + 180;
this.setMaxUpStep(1.0F); this.setMaxUpStep(1.0F);
this.setSpeed(4 * (float)this.getAttributeValue(Attributes.MOVEMENT_SPEED)); this.setSpeed(4 * (float) this.getAttributeValue(Attributes.MOVEMENT_SPEED));
float forward = -moveZ; float forward = -moveZ;
float upDown = -moveY; float upDown = -moveY;
float strafe = -moveX; float strafe = -moveX;
super.travel(new Vec3(2 * strafe, 2 * upDown, 2 * forward)); super.travel(new Vec3(2 * strafe, 2 * upDown, 2 * forward));
Vec3 vec3 = this.getDeltaMovement(); Vec3 vec3 = this.getDeltaMovement();
if (!move) { if (!this.move) {
this.setDeltaMovement(vec3.multiply(0.9, 0.8, 0.9)); this.setDeltaMovement(vec3.multiply(0.9, 0.8, 0.9));
} else { } else {
this.setDeltaMovement(vec3.multiply(1.05, 0.99, 1.05)); this.setDeltaMovement(vec3.multiply(1.05, 0.99, 1.05));
} }
return; return;
} }
} }
this.setMaxUpStep(0.5F); this.setMaxUpStep(0.5F);
super.travel(dir); super.travel(dir);
} }
@Override @Override
public void die(DamageSource source) { public void die(DamageSource source) {
super.die(source); super.die(source);
String id = this.entityData.get(CONTROLLER);
Player player = this.level().getPlayerByUUID(UUID.fromString(id));
if (player != null) {
player.getInventory().items.stream().filter(stack -> stack.getItem() == TargetModItems.MONITOR.get())
.forEach(stack -> {
if (stack.getOrCreateTag().getString(Monitor.LINKED_DRONE).equals(this.getStringUUID())) {
Monitor.disLink(stack);
}
});
}
} }
@Override @Override
@ -393,7 +397,6 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
if (level() instanceof ServerLevel) { if (level() instanceof ServerLevel) {
level().explode(null, this.getX(), this.getY(), this.getZ(), 0.1F, Level.ExplosionInteraction.NONE); level().explode(null, this.getX(), this.getY(), this.getZ(), 0.1F, Level.ExplosionInteraction.NONE);
} }
this.dropExperience();
} }
this.setDeltaMovement(new Vec3(this.getDeltaMovement().x(), this.getDeltaMovement().y() - 0.02, this.getDeltaMovement().z())); this.setDeltaMovement(new Vec3(this.getDeltaMovement().x(), this.getDeltaMovement().y() - 0.02, this.getDeltaMovement().z()));
} }

View file

@ -42,13 +42,15 @@ public class Monitor extends Item {
return super.use(world, player, hand); return super.use(world, player, hand);
} }
Minecraft mc = Minecraft.getInstance(); if (world.isClientSide) {
if (!stack.getOrCreateTag().getBoolean("Using")) { Minecraft mc = Minecraft.getInstance();
stack.getOrCreateTag().putBoolean("Using", true); if (!stack.getOrCreateTag().getBoolean("Using")) {
mc.options.setCameraType(CameraType.THIRD_PERSON_BACK); mc.options.setCameraType(CameraType.THIRD_PERSON_BACK);
} else {
mc.options.setCameraType(CameraType.FIRST_PERSON);
}
} else { } else {
stack.getOrCreateTag().putBoolean("Using", false); stack.getOrCreateTag().putBoolean("Using", !stack.getOrCreateTag().getBoolean("Using"));
mc.options.setCameraType(CameraType.FIRST_PERSON);
} }
DroneEntity drone = player.level().getEntitiesOfClass(DroneEntity.class, player.getBoundingBox().inflate(512)) DroneEntity drone = player.level().getEntitiesOfClass(DroneEntity.class, player.getBoundingBox().inflate(512))

View file

@ -2,7 +2,6 @@ package net.mcreator.target.mixins;
import net.mcreator.target.entity.DroneEntity; import net.mcreator.target.entity.DroneEntity;
import net.mcreator.target.init.TargetModItems; import net.mcreator.target.init.TargetModItems;
import net.mcreator.target.init.TargetModTags;
import net.minecraft.client.Camera; import net.minecraft.client.Camera;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
import net.minecraft.util.Mth; import net.minecraft.util.Mth;
@ -29,7 +28,6 @@ public abstract class MixinCamera {
at = @At(value = "INVOKE", target = "Lnet/minecraft/client/Camera;setRotation(FF)V", ordinal = 0), at = @At(value = "INVOKE", target = "Lnet/minecraft/client/Camera;setRotation(FF)V", ordinal = 0),
method = "setup(Lnet/minecraft/world/level/BlockGetter;Lnet/minecraft/world/entity/Entity;ZZF)V", method = "setup(Lnet/minecraft/world/level/BlockGetter;Lnet/minecraft/world/entity/Entity;ZZF)V",
cancellable = true) cancellable = true)
private void onSetup(BlockGetter level, Entity entity, boolean detached, boolean mirrored, float partialTicks, CallbackInfo info) { private void onSetup(BlockGetter level, Entity entity, boolean detached, boolean mirrored, float partialTicks, CallbackInfo info) {
Minecraft mc = Minecraft.getInstance(); Minecraft mc = Minecraft.getInstance();
Player player = mc.player; Player player = mc.player;
@ -38,7 +36,6 @@ public abstract class MixinCamera {
ItemStack stack = player.getMainHandItem(); ItemStack stack = player.getMainHandItem();
if (stack.is(TargetModItems.MONITOR.get()) && stack.getOrCreateTag().getBoolean("Using") && stack.getOrCreateTag().getBoolean("Linked")) { if (stack.is(TargetModItems.MONITOR.get()) && stack.getOrCreateTag().getBoolean("Using") && stack.getOrCreateTag().getBoolean("Linked")) {
DroneEntity drone = player.level().getEntitiesOfClass(DroneEntity.class, player.getBoundingBox().inflate(512)) DroneEntity drone = player.level().getEntitiesOfClass(DroneEntity.class, player.getBoundingBox().inflate(512))
.stream().filter(e -> e.getStringUUID().equals(stack.getOrCreateTag().getString("LinkedDrone"))).findFirst().orElse(null); .stream().filter(e -> e.getStringUUID().equals(stack.getOrCreateTag().getString("LinkedDrone"))).findFirst().orElse(null);