mirror of
https://github.com/PaperMC/Paper.git
synced 2025-08-01 12:42:05 -07:00
Friction API (#6611)
This commit is contained in:
73
patches/api/Friction-API.patch
Normal file
73
patches/api/Friction-API.patch
Normal file
@@ -0,0 +1,73 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Noah van der Aa <ndvdaa@gmail.com>
|
||||||
|
Date: Wed, 15 Sep 2021 20:40:51 +0200
|
||||||
|
Subject: [PATCH] Friction API
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/io/papermc/paper/entity/Frictional.java b/src/main/java/io/papermc/paper/entity/Frictional.java
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/src/main/java/io/papermc/paper/entity/Frictional.java
|
||||||
|
@@ -0,0 +0,0 @@
|
||||||
|
+package io.papermc.paper.entity;
|
||||||
|
+
|
||||||
|
+import net.kyori.adventure.util.TriState;
|
||||||
|
+import org.bukkit.entity.Entity;
|
||||||
|
+import org.jetbrains.annotations.NotNull;
|
||||||
|
+
|
||||||
|
+/**
|
||||||
|
+ * Represents an {@link Entity} that can experience friction with the air and ground.
|
||||||
|
+ */
|
||||||
|
+public interface Frictional {
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Gets the friction state of this entity.
|
||||||
|
+ * When set to {@link TriState#TRUE}, the entity will always experience friction.
|
||||||
|
+ * When set to {@link TriState#FALSE}, the entity will never experience friction.
|
||||||
|
+ * When set to {@link TriState#NOT_SET}, the entity will fall back to Minecraft's default behaviour.
|
||||||
|
+ *
|
||||||
|
+ * @return the entity's friction state
|
||||||
|
+ */
|
||||||
|
+ @NotNull
|
||||||
|
+ TriState getFrictionState();
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Sets the friction state of this entity.
|
||||||
|
+ * When set to {@link TriState#TRUE}, the entity will always experience friction.
|
||||||
|
+ * When set to {@link TriState#FALSE}, the entity will never experience friction.
|
||||||
|
+ * When set to {@link TriState#NOT_SET}, the entity will fall back to Minecraft's default behaviour.
|
||||||
|
+ * <p>
|
||||||
|
+ * Please note that changing this value will do nothing for a player.
|
||||||
|
+ *
|
||||||
|
+ * @param state the new friction state to set for the entity
|
||||||
|
+ */
|
||||||
|
+ void setFrictionState(@NotNull TriState state);
|
||||||
|
+
|
||||||
|
+}
|
||||||
|
diff --git a/src/main/java/org/bukkit/entity/Item.java b/src/main/java/org/bukkit/entity/Item.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/entity/Item.java
|
||||||
|
+++ b/src/main/java/org/bukkit/entity/Item.java
|
||||||
|
@@ -0,0 +0,0 @@ import org.jetbrains.annotations.Nullable;
|
||||||
|
/**
|
||||||
|
* Represents a dropped item.
|
||||||
|
*/
|
||||||
|
-public interface Item extends Entity {
|
||||||
|
+public interface Item extends Entity, io.papermc.paper.entity.Frictional { // Paper
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the item stack associated with this item drop.
|
||||||
|
diff --git a/src/main/java/org/bukkit/entity/LivingEntity.java b/src/main/java/org/bukkit/entity/LivingEntity.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/entity/LivingEntity.java
|
||||||
|
+++ b/src/main/java/org/bukkit/entity/LivingEntity.java
|
||||||
|
@@ -0,0 +0,0 @@ import org.jetbrains.annotations.Nullable;
|
||||||
|
/**
|
||||||
|
* Represents a living entity, such as a monster or player
|
||||||
|
*/
|
||||||
|
-public interface LivingEntity extends Attributable, Damageable, ProjectileSource {
|
||||||
|
+public interface LivingEntity extends Attributable, Damageable, ProjectileSource, io.papermc.paper.entity.Frictional { // Paper
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the height of the living entity's eyes above its Location.
|
156
patches/server/Friction-API.patch
Normal file
156
patches/server/Friction-API.patch
Normal file
@@ -0,0 +1,156 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Noah van der Aa <ndvdaa@gmail.com>
|
||||||
|
Date: Wed, 15 Sep 2021 20:44:22 +0200
|
||||||
|
Subject: [PATCH] Friction API
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/entity/LivingEntity.java b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
||||||
|
@@ -0,0 +0,0 @@ public abstract class LivingEntity extends Entity {
|
||||||
|
public boolean bukkitPickUpLoot;
|
||||||
|
public org.bukkit.craftbukkit.entity.CraftLivingEntity getBukkitLivingEntity() { return (org.bukkit.craftbukkit.entity.CraftLivingEntity) super.getBukkitEntity(); } // Paper
|
||||||
|
public boolean silentDeath = false; // Paper - mark entity as dying silently for cancellable death event
|
||||||
|
+ public net.kyori.adventure.util.TriState frictionState = net.kyori.adventure.util.TriState.NOT_SET; // Paper
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public float getBukkitYaw() {
|
||||||
|
@@ -0,0 +0,0 @@ public abstract class LivingEntity extends Entity {
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean shouldDiscardFriction() {
|
||||||
|
- return this.discardFriction;
|
||||||
|
+ return !this.frictionState.toBooleanOrElse(!this.discardFriction); // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDiscardFriction(boolean noDrag) {
|
||||||
|
@@ -0,0 +0,0 @@ public abstract class LivingEntity extends Entity {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void addAdditionalSaveData(CompoundTag nbt) {
|
||||||
|
+ // Paper start
|
||||||
|
+ if (this.frictionState != net.kyori.adventure.util.TriState.NOT_SET) {
|
||||||
|
+ nbt.putString("Paper.FrictionState", this.frictionState.toString());
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
nbt.putFloat("Health", this.getHealth());
|
||||||
|
nbt.putShort("HurtTime", (short) this.hurtTime);
|
||||||
|
nbt.putInt("HurtByTimestamp", this.lastHurtByMobTimestamp);
|
||||||
|
@@ -0,0 +0,0 @@ public abstract class LivingEntity extends Entity {
|
||||||
|
absorptionAmount = 0;
|
||||||
|
}
|
||||||
|
this.setAbsorptionAmount(absorptionAmount);
|
||||||
|
+
|
||||||
|
+ if (nbt.contains("Paper.FrictionState")) {
|
||||||
|
+ String fs = nbt.getString("Paper.FrictionState");
|
||||||
|
+ try {
|
||||||
|
+ frictionState = net.kyori.adventure.util.TriState.valueOf(fs);
|
||||||
|
+ } catch (Exception ignored) {
|
||||||
|
+ LOGGER.error("Unknown friction state " + fs + " for " + this);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
// Paper end
|
||||||
|
if (nbt.contains("Attributes", 9) && this.level != null && !this.level.isClientSide) {
|
||||||
|
this.getAttributes().load(nbt.getList("Attributes", 10));
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/entity/item/ItemEntity.java b/src/main/java/net/minecraft/world/entity/item/ItemEntity.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/entity/item/ItemEntity.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/entity/item/ItemEntity.java
|
||||||
|
@@ -0,0 +0,0 @@ public class ItemEntity extends Entity {
|
||||||
|
private int lastTick = MinecraftServer.currentTick - 1; // CraftBukkit
|
||||||
|
public boolean canMobPickup = true; // Paper
|
||||||
|
private int despawnRate = -1; // Paper
|
||||||
|
+ public net.kyori.adventure.util.TriState frictionState = net.kyori.adventure.util.TriState.NOT_SET; // Paper
|
||||||
|
|
||||||
|
public ItemEntity(EntityType<? extends ItemEntity> type, Level world) {
|
||||||
|
super(type, world);
|
||||||
|
@@ -0,0 +0,0 @@ public class ItemEntity extends Entity {
|
||||||
|
this.move(MoverType.SELF, this.getDeltaMovement());
|
||||||
|
float f1 = 0.98F;
|
||||||
|
|
||||||
|
- if (this.onGround) {
|
||||||
|
+ // Paper start
|
||||||
|
+ if (frictionState == net.kyori.adventure.util.TriState.FALSE) {
|
||||||
|
+ f1 = 1F;
|
||||||
|
+ } else if (this.onGround) {
|
||||||
|
+ // Paper end
|
||||||
|
f1 = this.level.getBlockState(new BlockPos(this.getX(), this.getY() - 1.0D, this.getZ())).getBlock().getFriction() * 0.98F;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ public class ItemEntity extends Entity {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void addAdditionalSaveData(CompoundTag nbt) {
|
||||||
|
+ // Paper start
|
||||||
|
+ if (this.frictionState != net.kyori.adventure.util.TriState.NOT_SET) {
|
||||||
|
+ nbt.putString("Paper.FrictionState", this.frictionState.toString());
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
nbt.putShort("Health", (short) this.health);
|
||||||
|
nbt.putShort("Age", (short) this.age);
|
||||||
|
nbt.putShort("PickupDelay", (short) this.pickupDelay);
|
||||||
|
@@ -0,0 +0,0 @@ public class ItemEntity extends Entity {
|
||||||
|
this.thrower = nbt.getUUID("Thrower");
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Paper start
|
||||||
|
+ if (nbt.contains("Paper.FrictionState")) {
|
||||||
|
+ String fs = nbt.getString("Paper.FrictionState");
|
||||||
|
+ try {
|
||||||
|
+ frictionState = net.kyori.adventure.util.TriState.valueOf(fs);
|
||||||
|
+ } catch (Exception ignored) {
|
||||||
|
+ com.mojang.logging.LogUtils.getLogger().error("Unknown friction state " + fs + " for " + this);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
+
|
||||||
|
CompoundTag nbttagcompound1 = nbt.getCompound("Item");
|
||||||
|
|
||||||
|
this.setItem(ItemStack.of(nbttagcompound1));
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftItem.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftItem.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftItem.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftItem.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftItem extends CraftEntity implements Item {
|
||||||
|
item.age = willAge ? 0 : NO_AGE_TIME;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ @org.jetbrains.annotations.NotNull
|
||||||
|
+ @Override
|
||||||
|
+ public net.kyori.adventure.util.TriState getFrictionState() {
|
||||||
|
+ return this.item.frictionState;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public void setFrictionState(@org.jetbrains.annotations.NotNull net.kyori.adventure.util.TriState state) {
|
||||||
|
+ java.util.Objects.requireNonNull(state, "state may not be null");
|
||||||
|
+ this.item.frictionState = state;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
@Override
|
||||||
|
public int getHealth() {
|
||||||
|
return item.health;
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity {
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
+ @org.jetbrains.annotations.NotNull
|
||||||
|
+ @Override
|
||||||
|
+ public net.kyori.adventure.util.TriState getFrictionState() {
|
||||||
|
+ return this.getHandle().frictionState;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public void setFrictionState(@org.jetbrains.annotations.NotNull net.kyori.adventure.util.TriState state) {
|
||||||
|
+ java.util.Objects.requireNonNull(state, "state may not be null");
|
||||||
|
+ this.getHandle().frictionState = state;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
@Override
|
||||||
|
public void knockback(double strength, double directionX, double directionZ) {
|
||||||
|
Preconditions.checkArgument(strength > 0, "Knockback strength must be > 0");
|
Reference in New Issue
Block a user