增加无人机自动解绑功能

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 java.util.Objects;
import java.util.UUID;
public class DroneEntity extends PathfinderMob implements GeoEntity {
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();
if (this.getPersistentData().getBoolean("left")) {
moveX = -1.5f;
this.moveX = -1.5f;
}
if (this.getPersistentData().getBoolean("right")) {
moveX = 1.5f;
this.moveX = 1.5f;
}
if (!this.getPersistentData().getBoolean("left") && !this.getPersistentData().getBoolean("right")) {
if (moveX >= 0) {
moveX = Mth.clamp(moveX - 0.3f,0,1);
if (this.moveX >= 0) {
this.moveX = Mth.clamp(this.moveX - 0.3f, 0, 1);
} else {
moveX = Mth.clamp(moveX + 0.3f,-1,0);
this.moveX = Mth.clamp(this.moveX + 0.3f, -1, 0);
}
}
if (this.getPersistentData().getBoolean("forward")) {
moveZ = -1.5f;
this.moveZ = -1.5f;
}
if (this.getPersistentData().getBoolean("backward")) {
moveZ = 1.5f;
this.moveZ = 1.5f;
}
if (!this.getPersistentData().getBoolean("forward") && !this.getPersistentData().getBoolean("backward")) {
if (moveZ >= 0) {
moveZ = Mth.clamp(moveZ - 0.3f,0,1);
if (this.moveZ >= 0) {
this.moveZ = Mth.clamp(this.moveZ - 0.3f, 0, 1);
} else {
moveZ = Mth.clamp(moveZ + 0.3f,-1,0);
this.moveZ = Mth.clamp(this.moveZ + 0.3f, -1, 0);
}
}
if (this.getPersistentData().getBoolean("up")) {
moveY = -1.5f;
this.moveY = -1.5f;
}
if (this.getPersistentData().getBoolean("down")) {
moveY = 1.5f;
this.moveY = 1.5f;
}
if (!this.getPersistentData().getBoolean("up") && !this.getPersistentData().getBoolean("down")) {
if (moveY >= 0) {
moveY = Mth.clamp(moveY - 0.3f,0,1);
if (this.moveY >= 0) {
this.moveY = Mth.clamp(this.moveY - 0.3f, 0, 1);
} 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))
.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("forward")
|| this.getPersistentData().getBoolean("backward")
|| this.getPersistentData().getBoolean("up")
|| this.getPersistentData().getBoolean("down")) {
move = true;
} else {
move = false;
}
|| this.getPersistentData().getBoolean("down");
if (move || !this.onGround()) {
if (this.move || !this.onGround()) {
this.level().playSound(null, this.getOnPos(), TargetModSounds.DRONE_SOUND.get(), SoundSource.AMBIENT, 3, 1);
if (control != null) {
ItemStack stack = control.getMainHandItem();
@ -207,16 +204,15 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
}
Vec3 vec = this.getDeltaMovement();
if (this.getDeltaMovement().horizontalDistanceSqr() < 1) {
if (move) {
if (this.move) {
this.setDeltaMovement(vec.multiply(1.04, 1, 1.04));
}
}
if (this.getPersistentData().getBoolean("firing")) {
if (control instanceof Player player) {
DroneDrop(player);
droneDrop(player);
}
this.getPersistentData().putBoolean("firing", false);
}
@ -224,8 +220,7 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
this.refreshDimensions();
}
private void DroneDrop(Player player) {
private void droneDrop(Player player) {
Level level = player.level();
if (!level.isClientSide()) {
DroneGrenadeEntity droneGrenadeEntity = new DroneGrenadeEntity(player, level);
@ -307,24 +302,33 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
float strafe = -moveX;
super.travel(new Vec3(2 * strafe, 2 * upDown, 2 * forward));
Vec3 vec3 = this.getDeltaMovement();
if (!move) {
if (!this.move) {
this.setDeltaMovement(vec3.multiply(0.9, 0.8, 0.9));
} else {
this.setDeltaMovement(vec3.multiply(1.05, 0.99, 1.05));
}
return;
}
}
this.setMaxUpStep(0.5F);
super.travel(dir);
}
@Override
public void die(DamageSource 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
@ -393,7 +397,6 @@ public class DroneEntity extends PathfinderMob implements GeoEntity {
if (level() instanceof ServerLevel) {
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()));
}

View file

@ -42,14 +42,16 @@ public class Monitor extends Item {
return super.use(world, player, hand);
}
if (world.isClientSide) {
Minecraft mc = Minecraft.getInstance();
if (!stack.getOrCreateTag().getBoolean("Using")) {
stack.getOrCreateTag().putBoolean("Using", true);
mc.options.setCameraType(CameraType.THIRD_PERSON_BACK);
} else {
stack.getOrCreateTag().putBoolean("Using", false);
mc.options.setCameraType(CameraType.FIRST_PERSON);
}
} else {
stack.getOrCreateTag().putBoolean("Using", !stack.getOrCreateTag().getBoolean("Using"));
}
DroneEntity drone = player.level().getEntitiesOfClass(DroneEntity.class, player.getBoundingBox().inflate(512))
.stream().filter(e -> e.getStringUUID().equals(stack.getOrCreateTag().getString("LinkedDrone"))).findFirst().orElse(null);

View file

@ -2,7 +2,6 @@ package net.mcreator.target.mixins;
import net.mcreator.target.entity.DroneEntity;
import net.mcreator.target.init.TargetModItems;
import net.mcreator.target.init.TargetModTags;
import net.minecraft.client.Camera;
import net.minecraft.client.Minecraft;
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),
method = "setup(Lnet/minecraft/world/level/BlockGetter;Lnet/minecraft/world/entity/Entity;ZZF)V",
cancellable = true)
private void onSetup(BlockGetter level, Entity entity, boolean detached, boolean mirrored, float partialTicks, CallbackInfo info) {
Minecraft mc = Minecraft.getInstance();
Player player = mc.player;
@ -38,7 +36,6 @@ public abstract class MixinCamera {
ItemStack stack = player.getMainHandItem();
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))
.stream().filter(e -> e.getStringUUID().equals(stack.getOrCreateTag().getString("LinkedDrone"))).findFirst().orElse(null);