Fix enchantment problems

This commit is contained in:
zontreck 2024-04-01 02:00:34 -07:00
parent 7697043b79
commit a9608d867c
4 changed files with 58 additions and 65 deletions

View file

@ -2,100 +2,72 @@ package dev.zontreck.otemod.effects;
import dev.zontreck.libzontreck.LibZontreck; import dev.zontreck.libzontreck.LibZontreck;
import dev.zontreck.libzontreck.util.ChatHelpers; import dev.zontreck.libzontreck.util.ChatHelpers;
import dev.zontreck.libzontreck.util.ItemUtils;
import dev.zontreck.libzontreck.util.ServerUtilities; import dev.zontreck.libzontreck.util.ServerUtilities;
import dev.zontreck.otemod.enchantments.ModEnchantments; import dev.zontreck.otemod.OTEMod;
import dev.zontreck.otemod.implementation.Messages; import dev.zontreck.otemod.implementation.Messages;
import net.minecraft.server.level.ServerPlayer; import net.minecraft.server.level.ServerPlayer;
import net.minecraft.world.effect.MobEffect; import net.minecraft.world.effect.MobEffect;
import net.minecraft.world.effect.MobEffectCategory; import net.minecraft.world.effect.MobEffectCategory;
import net.minecraft.world.entity.Entity;
import net.minecraft.world.entity.EquipmentSlot;
import net.minecraft.world.entity.LivingEntity; import net.minecraft.world.entity.LivingEntity;
import net.minecraft.world.entity.ai.attributes.AttributeMap; import net.minecraft.world.entity.ai.attributes.*;
import net.minecraft.world.entity.ai.attributes.Attributes;
import net.minecraft.world.entity.player.Abilities;
import net.minecraft.world.entity.player.Player; import net.minecraft.world.entity.player.Player;
import net.minecraft.world.item.ItemStack;
import net.minecraftforge.fml.LogicalSide; import net.minecraftforge.fml.LogicalSide;
import org.jetbrains.annotations.Nullable;
import java.util.UUID;
public class FlightEffect extends MobEffect { public class FlightEffect extends MobEffect {
int lastDuration = -1;
protected FlightEffect(MobEffectCategory pCategory, int pColor) { protected FlightEffect(MobEffectCategory pCategory, int pColor) {
super(pCategory, pColor); super(pCategory, pColor);
} }
@Override
public void applyEffectTick(LivingEntity pLivingEntity, int pAmplifier) {
super.applyEffectTick(pLivingEntity, pAmplifier);
if(LibZontreck.CURRENT_SIDE == LogicalSide.CLIENT) return;
if(pLivingEntity instanceof Player)
{
if(LibZontreck.CURRENT_SIDE == LogicalSide.SERVER)
{
ServerPlayer player = ServerUtilities.getPlayerByID(pLivingEntity.getStringUUID());
recheck(player);
}
}
}
@Override @Override
public boolean isDurationEffectTick(int pDuration, int pAmplifier) { public boolean isDurationEffectTick(int pDuration, int pAmplifier) {
return true; lastDuration=pDuration;
//OTEMod.LOGGER.info("Effect duration: " + lastDuration);
return pDuration > 0;
} }
@Override @Override
public void applyInstantenousEffect(@Nullable Entity pSource, @Nullable Entity pIndirectSource, LivingEntity pLivingEntity, int pAmplifier, double pHealth) { public void addAttributeModifiers(LivingEntity entity, AttributeMap map, int i) {
super.addAttributeModifiers(entity, map, i);
if(LibZontreck.CURRENT_SIDE == LogicalSide.CLIENT) return; if(entity instanceof ServerPlayer player)
if(pLivingEntity instanceof Player)
{ {
ServerPlayer player = ServerUtilities.getPlayerByID(pLivingEntity.getStringUUID()); if(player.getAbilities().mayfly==false)
{
player.getAbilities().mayfly=true;
player.onUpdateAbilities();
recheck(player); ChatHelpers.broadcastTo(player, ChatHelpers.macro(Messages.FLIGHT_GIVEN), player.server);
}
} }
super.applyInstantenousEffect(pSource, pIndirectSource, pLivingEntity, pAmplifier, pHealth);
} }
private static void recheck(ServerPlayer sp) private void removeFlightModifier(LivingEntity entity)
{ {
if(sp.gameMode.isCreative())return; // Don't mess with the creative mode attributes if(lastDuration == -1)
ItemStack feet = sp.getItemBySlot(EquipmentSlot.FEET);
boolean hasFlight = false;
if(ItemUtils.getEnchantmentLevel(ModEnchantments.FLIGHT_ENCHANTMENT.get(), feet)>0)hasFlight=true;
if(!hasFlight)
{ {
sp.removeEffect(ModEffects.FLIGHT.get()); return;
} }
if ( entity instanceof Player player )
Abilities playerAbilities = sp.getAbilities();
if(hasFlight)
{ {
if(playerAbilities.mayfly == false) if(ServerUtilities.isServer() && lastDuration < (5*20))
{ {
playerAbilities.mayfly=true; ServerPlayer serverPlayer = (ServerPlayer) player;
sp.onUpdateAbilities(); serverPlayer.getAbilities().mayfly = false;
serverPlayer.getAbilities().flying = false;
ChatHelpers.broadcastTo(sp, ChatHelpers.macro(Messages.FLIGHT_GIVEN), sp.server); serverPlayer.onUpdateAbilities();
}
}else {
if(playerAbilities.mayfly)
{
playerAbilities.mayfly=false; ChatHelpers.broadcastTo(serverPlayer, ChatHelpers.macro(Messages.FLIGHT_REMOVED), serverPlayer.server);
playerAbilities.flying=false;
sp.onUpdateAbilities();
ChatHelpers.broadcastTo(sp, ChatHelpers.macro(Messages.FLIGHT_REMOVED), sp.server);
} }
} }
} }
@Override
public void removeAttributeModifiers(LivingEntity entity, AttributeMap p_19470_, int p_19471_) {
super.removeAttributeModifiers(entity, p_19470_, p_19471_);
removeFlightModifier(entity);
}
} }

View file

@ -15,10 +15,10 @@ public class EnchantmentEvents
@SubscribeEvent @SubscribeEvent
public static void onServerTick(TickEvent.ServerTickEvent event) public static void onServerTick(TickEvent.ServerTickEvent event)
{ {
if(event.phase == TickEvent.Phase.START) if(event.phase == TickEvent.Phase.END)
{ {
MinecraftServer server = ServerLifecycleHooks.getCurrentServer(); MinecraftServer server = ServerLifecycleHooks.getCurrentServer();
canTick = server!=null && server.getTickCount()%20==0; canTick = server!=null;
} }
} }
@ -33,6 +33,7 @@ public class EnchantmentEvents
{ {
FlightEnchantment.runEntityTick(sp); FlightEnchantment.runEntityTick(sp);
ConsumptionMending.onEntityTick(sp); ConsumptionMending.onEntityTick(sp);
NightVisionEnchantment.runEntityTick(sp);
} }
} }
} }

View file

@ -65,7 +65,7 @@ public class FlightEnchantment extends Enchantment
{ {
if(ServerUtilities.isClient()) return; if(ServerUtilities.isClient()) return;
if(TICKS.getAndIncrement() >= (5*20)) if(TICKS.getAndIncrement() >= 20)
{ {
TICKS.set(0); TICKS.set(0);
@ -84,7 +84,17 @@ public class FlightEnchantment extends Enchantment
if(hasFlight) if(hasFlight)
{ {
MobEffectInstance inst = new MobEffectInstance(ModEffects.FLIGHT.get(), -1, 0, false, false, true); MobEffectInstance inst = new MobEffectInstance(ModEffects.FLIGHT.get(), 60*20, 0, false, false, true);
MobEffectInstance existing = sp.getEffect(ModEffects.FLIGHT.get());
if(existing!= null)
{
if(existing.getDuration() <= (30 * 20))
{
sp.addEffect(inst);
return;
}else return;
}
sp.addEffect(inst); sp.addEffect(inst);
} }

View file

@ -74,6 +74,16 @@ public class NightVisionEnchantment extends Enchantment
{ {
MobEffectInstance inst = new MobEffectInstance(MobEffects.NIGHT_VISION, 60*20, 4, false, false, true); MobEffectInstance inst = new MobEffectInstance(MobEffects.NIGHT_VISION, 60*20, 4, false, false, true);
MobEffectInstance existing = sp.getEffect(MobEffects.NIGHT_VISION);
if(existing != null)
{
if(existing.getDuration() <= (30*20))
{
sp.addEffect(inst);
return;
}else return;
}
sp.addEffect(inst); sp.addEffect(inst);
} }
} }