From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: MrHua269 Date: Sun, 17 Mar 2024 00:00:45 +0000 Subject: [PATCH] Leaves Replay Mod API diff --git a/src/main/java/org/bukkit/Bukkit.java b/src/main/java/org/bukkit/Bukkit.java index 4d6de4f2c67b1f122768806443766bd20c5ae617..b5155ffe86c490252fd0fcd1a00581e09808eeee 100644 --- a/src/main/java/org/bukkit/Bukkit.java +++ b/src/main/java/org/bukkit/Bukkit.java @@ -2886,4 +2886,10 @@ public final class Bukkit { public static Server.Spigot spigot() { return server.spigot(); } + + // Leaves start - Photographer API + public static @NotNull top.leavesmc.leaves.entity.PhotographerManager getPhotographerManager() { + return server.getPhotographerManager(); + } + // Leaves end - Photographer API } diff --git a/src/main/java/org/bukkit/Server.java b/src/main/java/org/bukkit/Server.java index d46f932b595495816ea038cf161bc7f2d85f177e..7d8a9bab880656e34d8c4dceb4dea3b0c1ced4c8 100644 --- a/src/main/java/org/bukkit/Server.java +++ b/src/main/java/org/bukkit/Server.java @@ -2518,4 +2518,8 @@ public interface Server extends PluginMessageRecipient, net.kyori.adventure.audi */ public boolean isGlobalTickThread(); // Folia end - region threading API + + // Leaves start - Photographer API + @NotNull top.leavesmc.leaves.entity.PhotographerManager getPhotographerManager(); + // Leaves end - Photographer API } diff --git a/src/main/java/top/leavesmc/leaves/entity/Photographer.java b/src/main/java/top/leavesmc/leaves/entity/Photographer.java new file mode 100644 index 0000000000000000000000000000000000000000..bfa6fe2a0ca095170aa5e073251402cf83a53ba0 --- /dev/null +++ b/src/main/java/top/leavesmc/leaves/entity/Photographer.java @@ -0,0 +1,27 @@ +package top.leavesmc.leaves.entity; + +import org.bukkit.entity.Player; +import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; + +import java.io.File; + +public interface Photographer extends Player { + + @NotNull + public String getId(); + + public void setRecordFile(@NotNull File file); + + public void stopRecording(); + + public void stopRecording(boolean async); + + public void stopRecording(boolean async, boolean save); + + public void pauseRecording(); + + public void resumeRecording(); + + public void setFollowPlayer(@Nullable Player player); +} diff --git a/src/main/java/top/leavesmc/leaves/entity/PhotographerManager.java b/src/main/java/top/leavesmc/leaves/entity/PhotographerManager.java new file mode 100644 index 0000000000000000000000000000000000000000..2889a4835edea4254a3d35fc7861983644a1dc4b --- /dev/null +++ b/src/main/java/top/leavesmc/leaves/entity/PhotographerManager.java @@ -0,0 +1,32 @@ +package top.leavesmc.leaves.entity; + +import org.bukkit.Location; +import org.bukkit.util.Consumer; +import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; +import top.leavesmc.leaves.replay.BukkitRecorderOption; + +import java.util.Collection; +import java.util.UUID; + +public interface PhotographerManager { + @Nullable + public Photographer getPhotographer(@NotNull UUID uuid); + + @Nullable + public Photographer getPhotographer(@NotNull String id); + + @Nullable + public Photographer createPhotographer(@NotNull String id, @NotNull Location location); + + @Nullable + public Photographer createPhotographer(@NotNull String id, @NotNull Location location, @NotNull BukkitRecorderOption recorderOption); + + public void removePhotographer(@NotNull String id); + + public void removePhotographer(@NotNull UUID uuid); + + public void removeAllPhotographers(); + + public Collection getPhotographers(); +} diff --git a/src/main/java/top/leavesmc/leaves/replay/BukkitRecorderOption.java b/src/main/java/top/leavesmc/leaves/replay/BukkitRecorderOption.java new file mode 100644 index 0000000000000000000000000000000000000000..3df4a6055b91c28e273d6fb2697b608778f40a9c --- /dev/null +++ b/src/main/java/top/leavesmc/leaves/replay/BukkitRecorderOption.java @@ -0,0 +1,18 @@ +package top.leavesmc.leaves.replay; + +public class BukkitRecorderOption { + + // public int recordDistance = -1; + public String serverName = "Leaves"; + public BukkitRecordWeather forceWeather = BukkitRecordWeather.NULL; + public int forceDayTime = -1; + public boolean ignoreChat = false; + // public boolean ignoreItem = false; + + public enum BukkitRecordWeather { + CLEAR, + RAIN, + THUNDER, + NULL + } +}