mirror of
https://github.com/Creators-of-Create/Create.git
synced 2024-12-31 17:36:43 +01:00
Mortal Compat
- Commented a teleport hook not yet included in recommended forge
This commit is contained in:
parent
10b0bdbfcf
commit
83a3faa871
1 changed files with 21 additions and 15 deletions
|
@ -36,11 +36,10 @@ import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.math.BlockRayTraceResult;
|
import net.minecraft.util.math.BlockRayTraceResult;
|
||||||
import net.minecraft.util.math.EntityRayTraceResult;
|
import net.minecraft.util.math.EntityRayTraceResult;
|
||||||
import net.minecraft.util.math.MathHelper;
|
import net.minecraft.util.math.MathHelper;
|
||||||
|
import net.minecraft.util.math.vector.Vector3d;
|
||||||
import net.minecraft.world.IWorld;
|
import net.minecraft.world.IWorld;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraftforge.common.IPlantable;
|
import net.minecraftforge.common.IPlantable;
|
||||||
import net.minecraftforge.event.ForgeEventFactory;
|
|
||||||
import net.minecraftforge.event.entity.living.EntityTeleportEvent;
|
|
||||||
import net.minecraftforge.registries.IRegistryDelegate;
|
import net.minecraftforge.registries.IRegistryDelegate;
|
||||||
|
|
||||||
public class PotatoCannonProjectileTypes {
|
public class PotatoCannonProjectileTypes {
|
||||||
|
@ -116,7 +115,7 @@ public class PotatoCannonProjectileTypes {
|
||||||
.velocity(1.20f)
|
.velocity(1.20f)
|
||||||
.knockback(0.05f)
|
.knockback(0.05f)
|
||||||
.renderTumbling()
|
.renderTumbling()
|
||||||
.onEntityHit(chorusTeleport(20))
|
.onEntityHitRecoveryCancelable(chorusTeleport(20))
|
||||||
.registerAndAssign(Items.CHORUS_FRUIT),
|
.registerAndAssign(Items.CHORUS_FRUIT),
|
||||||
|
|
||||||
APPLE = create("apple").damage(5)
|
APPLE = create("apple").damage(5)
|
||||||
|
@ -142,7 +141,7 @@ public class PotatoCannonProjectileTypes {
|
||||||
.knockback(0.05f)
|
.knockback(0.05f)
|
||||||
.renderTumbling()
|
.renderTumbling()
|
||||||
.soundPitch(1.1f)
|
.soundPitch(1.1f)
|
||||||
.onEntityHit(foodEffects(Foods.GOLDEN_APPLE))
|
.onEntityHitRecoveryCancelable(foodEffects(Foods.GOLDEN_APPLE))
|
||||||
.registerAndAssign(Items.GOLDEN_APPLE),
|
.registerAndAssign(Items.GOLDEN_APPLE),
|
||||||
|
|
||||||
ENCHANTED_GOLDEN_APPLE = create("enchanted_golden_apple").damage(1)
|
ENCHANTED_GOLDEN_APPLE = create("enchanted_golden_apple").damage(1)
|
||||||
|
@ -151,7 +150,7 @@ public class PotatoCannonProjectileTypes {
|
||||||
.knockback(0.05f)
|
.knockback(0.05f)
|
||||||
.renderTumbling()
|
.renderTumbling()
|
||||||
.soundPitch(1.1f)
|
.soundPitch(1.1f)
|
||||||
.onEntityHit(foodEffects(Foods.ENCHANTED_GOLDEN_APPLE))
|
.onEntityHitRecoveryCancelable(foodEffects(Foods.ENCHANTED_GOLDEN_APPLE))
|
||||||
.registerAndAssign(Items.ENCHANTED_GOLDEN_APPLE),
|
.registerAndAssign(Items.ENCHANTED_GOLDEN_APPLE),
|
||||||
|
|
||||||
BEETROOT = create("beetroot").damage(2)
|
BEETROOT = create("beetroot").damage(2)
|
||||||
|
@ -313,7 +312,7 @@ public class PotatoCannonProjectileTypes {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Consumer<EntityRayTraceResult> foodEffects(Food food) {
|
private static Predicate<EntityRayTraceResult> foodEffects(Food food) {
|
||||||
return ray -> {
|
return ray -> {
|
||||||
Entity entity = ray.getEntity();
|
Entity entity = ray.getEntity();
|
||||||
if (entity instanceof LivingEntity) {
|
if (entity instanceof LivingEntity) {
|
||||||
|
@ -322,6 +321,7 @@ public class PotatoCannonProjectileTypes {
|
||||||
((LivingEntity) entity).addPotionEffect(effect.getFirst());
|
((LivingEntity) entity).addPotionEffect(effect.getFirst());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return true;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -377,14 +377,14 @@ public class PotatoCannonProjectileTypes {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Consumer<EntityRayTraceResult> chorusTeleport(double teleportDiameter) {
|
private static Predicate<EntityRayTraceResult> chorusTeleport(double teleportDiameter) {
|
||||||
return ray -> {
|
return ray -> {
|
||||||
Entity entity = ray.getEntity();
|
Entity entity = ray.getEntity();
|
||||||
World world = entity.getEntityWorld();
|
World world = entity.getEntityWorld();
|
||||||
if (world.isRemote)
|
if (world.isRemote)
|
||||||
return;
|
return true;
|
||||||
if (!(entity instanceof LivingEntity))
|
if (!(entity instanceof LivingEntity))
|
||||||
return;
|
return false;
|
||||||
LivingEntity livingEntity = (LivingEntity) entity;
|
LivingEntity livingEntity = (LivingEntity) entity;
|
||||||
|
|
||||||
double entityX = livingEntity.getX();
|
double entityX = livingEntity.getX();
|
||||||
|
@ -396,20 +396,26 @@ public class PotatoCannonProjectileTypes {
|
||||||
double teleportY = MathHelper.clamp(entityY + (livingEntity.getRNG().nextInt((int) teleportDiameter) - (int) (teleportDiameter / 2)), 0.0D, world.getDimensionHeight() - 1);
|
double teleportY = MathHelper.clamp(entityY + (livingEntity.getRNG().nextInt((int) teleportDiameter) - (int) (teleportDiameter / 2)), 0.0D, world.getDimensionHeight() - 1);
|
||||||
double teleportZ = entityZ + (livingEntity.getRNG().nextDouble() - 0.5D) * teleportDiameter;
|
double teleportZ = entityZ + (livingEntity.getRNG().nextDouble() - 0.5D) * teleportDiameter;
|
||||||
|
|
||||||
EntityTeleportEvent.ChorusFruit event = ForgeEventFactory.onChorusFruitTeleport(livingEntity, teleportX, teleportY, teleportZ);
|
/* Usable as soon as lowest supported forge > 36.1.3 */
|
||||||
if (event.isCanceled())
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (livingEntity.attemptTeleport(event.getTargetX(), event.getTargetY(), event.getTargetZ(), true)) {
|
// EntityTeleportEvent.ChorusFruit event = ForgeEventFactory.onChorusFruitTeleport(livingEntity, teleportX, teleportY, teleportZ);
|
||||||
|
// if (event.isCanceled())
|
||||||
|
// return;
|
||||||
|
// if (livingEntity.attemptTeleport(event.getTargetX(), event.getTargetY(), event.getTargetZ(), true)) {
|
||||||
|
|
||||||
|
if (livingEntity.attemptTeleport(teleportX, teleportY, teleportZ, true)) {
|
||||||
if (livingEntity.isPassenger())
|
if (livingEntity.isPassenger())
|
||||||
livingEntity.stopRiding();
|
livingEntity.stopRiding();
|
||||||
|
|
||||||
SoundEvent soundevent = livingEntity instanceof FoxEntity ? SoundEvents.ENTITY_FOX_TELEPORT : SoundEvents.ITEM_CHORUS_FRUIT_TELEPORT;
|
SoundEvent soundevent = livingEntity instanceof FoxEntity ? SoundEvents.ENTITY_FOX_TELEPORT : SoundEvents.ITEM_CHORUS_FRUIT_TELEPORT;
|
||||||
world.playSound(null, entityX, entityY, entityZ, soundevent, SoundCategory.PLAYERS, 1.0F, 1.0F);
|
world.playSound(null, entityX, entityY, entityZ, soundevent, SoundCategory.PLAYERS, 1.0F, 1.0F);
|
||||||
livingEntity.playSound(soundevent, 1.0F, 1.0F);
|
livingEntity.playSound(soundevent, 1.0F, 1.0F);
|
||||||
break;
|
livingEntity.setMotion(Vector3d.ZERO);
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue