geforkt von Mirrors/Paper
96d5e6ca48
Currently includes generated key holder classes for types used in the Registry Modification API
54 Zeilen
2.0 KiB
Diff
54 Zeilen
2.0 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: SoSeDiK <mrsosedik@gmail.com>
|
|
Date: Wed, 11 Jan 2023 20:59:02 +0200
|
|
Subject: [PATCH] Expand Pose API
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/entity/Entity.java b/src/main/java/org/bukkit/entity/Entity.java
|
|
index 2177eb74ab50b30b100aa8f35fc1d99b860ea7fd..d340ddcf6924cc834455de3acbbac91ab9c66e39 100644
|
|
--- a/src/main/java/org/bukkit/entity/Entity.java
|
|
+++ b/src/main/java/org/bukkit/entity/Entity.java
|
|
@@ -796,6 +796,42 @@ public interface Entity extends Metadatable, CommandSender, Nameable, Persistent
|
|
* @param sneak true if the entity should be sneaking
|
|
*/
|
|
void setSneaking(boolean sneak);
|
|
+
|
|
+ /**
|
|
+ * Sets the entity's current {@link Pose}.
|
|
+ *
|
|
+ * <p>Note: While poses affect some things like hitboxes, they do not change the entity's state
|
|
+ * (e.g. having {@link Pose#SNEAKING} does not guarantee {@link #isSneaking()} being {@code true}).
|
|
+ *
|
|
+ * <p>If applied to the {@link Player}, they might see a different pose client-side.
|
|
+ *
|
|
+ * @param pose a new {@link Pose}
|
|
+ * @see #setPose(Pose, boolean)
|
|
+ */
|
|
+ default void setPose(@NotNull Pose pose) {
|
|
+ setPose(pose, false);
|
|
+ }
|
|
+
|
|
+ /**
|
|
+ * Sets the entity's current {@link Pose}.
|
|
+ *
|
|
+ * <p>Note: While poses affect some things like hitboxes, they do not change the entity's state
|
|
+ * (e.g. having {@link Pose#SNEAKING} does not guarantee {@link #isSneaking()} being {@code true}).
|
|
+ *
|
|
+ * <p>If applied to the {@link Player}, they might see a different pose client-side.
|
|
+ *
|
|
+ * @param pose a new {@link Pose}
|
|
+ * @param fixed whether the new {@link Pose} should stay until manually changed
|
|
+ */
|
|
+ void setPose(@NotNull Pose pose, boolean fixed);
|
|
+
|
|
+ /**
|
|
+ * Checks whether the entity has a fixed {@link Pose}
|
|
+ *
|
|
+ * @see #setPose(Pose, boolean)
|
|
+ * @return whether the entity has a fixed {@link Pose}
|
|
+ */
|
|
+ boolean hasFixedPose();
|
|
// Paper end
|
|
|
|
/**
|