🎉 First commit!
This commit is contained in:
commit
4dc99283f4
42 changed files with 4068 additions and 0 deletions
98
NMS-v1_19_R1/pom.xml
Normal file
98
NMS-v1_19_R1/pom.xml
Normal file
|
@ -0,0 +1,98 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xmlns="http://maven.apache.org/POM/4.0.0"
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<parent>
|
||||
<artifactId>MapReflectionAPI</artifactId>
|
||||
<groupId>tech.sbdevelopment</groupId>
|
||||
<version>${revision}</version>
|
||||
</parent>
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
|
||||
<artifactId>MapReflectionAPI-NMS-v1_19_R1</artifactId>
|
||||
|
||||
<properties>
|
||||
<NMSVersion>1.19-R0.1-SNAPSHOT</NMSVersion>
|
||||
<jdk.version>17</jdk.version>
|
||||
</properties>
|
||||
|
||||
<build>
|
||||
<plugins>
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-compiler-plugin</artifactId>
|
||||
<version>3.9.0-SNAPSHOT</version>
|
||||
<configuration>
|
||||
<release>${jdk.version}</release>
|
||||
</configuration>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<groupId>net.md-5</groupId>
|
||||
<artifactId>specialsource-maven-plugin</artifactId>
|
||||
<version>1.2.3</version>
|
||||
<executions>
|
||||
<execution>
|
||||
<phase>package</phase>
|
||||
<goals>
|
||||
<goal>remap</goal>
|
||||
</goals>
|
||||
<id>remap-obf</id>
|
||||
<configuration>
|
||||
<srgIn>org.spigotmc:minecraft-server:${NMSVersion}:txt:maps-mojang</srgIn>
|
||||
<reverse>true</reverse>
|
||||
<remappedDependencies>org.spigotmc:spigot:${NMSVersion}:jar:remapped-mojang
|
||||
</remappedDependencies>
|
||||
<remappedArtifactAttached>true</remappedArtifactAttached>
|
||||
<remappedClassifierName>remapped-obf</remappedClassifierName>
|
||||
</configuration>
|
||||
</execution>
|
||||
<execution>
|
||||
<phase>package</phase>
|
||||
<goals>
|
||||
<goal>remap</goal>
|
||||
</goals>
|
||||
<id>remap-spigot</id>
|
||||
<configuration>
|
||||
<inputFile>
|
||||
${project.build.directory}/${project.artifactId}-${project.version}-remapped-obf.jar
|
||||
</inputFile>
|
||||
<srgIn>org.spigotmc:minecraft-server:${NMSVersion}:csrg:maps-spigot</srgIn>
|
||||
<remappedDependencies>org.spigotmc:spigot:${NMSVersion}:jar:remapped-obf
|
||||
</remappedDependencies>
|
||||
</configuration>
|
||||
</execution>
|
||||
</executions>
|
||||
</plugin>
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-deploy-plugin</artifactId>
|
||||
<version>3.0.0-M2</version>
|
||||
<configuration>
|
||||
<skip>true</skip>
|
||||
</configuration>
|
||||
</plugin>
|
||||
</plugins>
|
||||
</build>
|
||||
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>org.spigotmc</groupId>
|
||||
<artifactId>minecraft-server</artifactId>
|
||||
<version>${NMSVersion}</version>
|
||||
<scope>provided</scope>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.spigotmc</groupId>
|
||||
<artifactId>spigot</artifactId>
|
||||
<version>${NMSVersion}</version>
|
||||
<classifier>remapped-mojang</classifier>
|
||||
<scope>provided</scope>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>tech.sbdevelopment</groupId>
|
||||
<artifactId>MapReflectionAPI-API</artifactId>
|
||||
<version>1.0-SNAPSHOT</version>
|
||||
<scope>provided</scope>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
</project>
|
|
@ -0,0 +1,88 @@
|
|||
package tech.sbdevelopment.mapreflectionapi.nms;
|
||||
|
||||
import net.minecraft.network.protocol.game.PacketPlayOutMap;
|
||||
import net.minecraft.world.level.saveddata.maps.WorldMap;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.craftbukkit.v1_19_R1.entity.CraftPlayer;
|
||||
import org.bukkit.entity.Player;
|
||||
import tech.sbdevelopment.mapreflectionapi.ArrayImage;
|
||||
import tech.sbdevelopment.mapreflectionapi.MapReflectionAPI;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
public class MapSender_v1_19_R1 {
|
||||
private static final List<QueuedMap> sendQueue = new ArrayList<>();
|
||||
private static int senderID = -1;
|
||||
|
||||
public static void addToQueue(final int id, final ArrayImage content, final Player player) {
|
||||
QueuedMap toSend = new QueuedMap(id, content, player);
|
||||
if (sendQueue.contains(toSend)) return;
|
||||
sendQueue.add(toSend);
|
||||
|
||||
runSender();
|
||||
}
|
||||
|
||||
private static void runSender() {
|
||||
if (Bukkit.getScheduler().isQueued(senderID) || Bukkit.getScheduler().isCurrentlyRunning(senderID) || sendQueue.isEmpty())
|
||||
return;
|
||||
|
||||
senderID = Bukkit.getScheduler().scheduleSyncRepeatingTask(MapReflectionAPI.getInstance(), () -> {
|
||||
if (sendQueue.isEmpty()) return;
|
||||
|
||||
for (int i = 0; i < Math.min(sendQueue.size(), 10 + 1); i++) {
|
||||
QueuedMap current = sendQueue.get(0);
|
||||
if (current == null) return;
|
||||
|
||||
sendMap(current.id, current.image, current.player);
|
||||
|
||||
if (!sendQueue.isEmpty()) sendQueue.remove(0);
|
||||
}
|
||||
}, 0, 2);
|
||||
}
|
||||
|
||||
public static void sendMap(final int id0, final ArrayImage content, final Player player) {
|
||||
if (player == null || !player.isOnline()) {
|
||||
List<QueuedMap> toRemove = new ArrayList<>();
|
||||
for (QueuedMap qMap : sendQueue) {
|
||||
if (qMap == null) continue;
|
||||
|
||||
if (qMap.player == null || !qMap.player.isOnline()) {
|
||||
toRemove.add(qMap);
|
||||
}
|
||||
}
|
||||
Bukkit.getScheduler().cancelTask(senderID);
|
||||
sendQueue.removeAll(toRemove);
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
final int id = -id0;
|
||||
Bukkit.getScheduler().runTaskAsynchronously(MapReflectionAPI.getInstance(), () -> {
|
||||
try {
|
||||
WorldMap.b updateData = new WorldMap.b(
|
||||
content.minX, //X pos
|
||||
content.minY, //Y pos
|
||||
content.maxX, //X size (2nd X pos)
|
||||
content.maxY, //Y size (2nd Y pos)
|
||||
content.array //Data
|
||||
);
|
||||
|
||||
PacketPlayOutMap packet = new PacketPlayOutMap(
|
||||
id, //ID
|
||||
(byte) 0, //Scale
|
||||
false, //Show icons
|
||||
new ArrayList<>(), //Icons
|
||||
updateData
|
||||
);
|
||||
|
||||
((CraftPlayer) player).getHandle().connection.send(packet);
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
record QueuedMap(int id, ArrayImage image, Player player) {
|
||||
}
|
||||
}
|
|
@ -0,0 +1,224 @@
|
|||
package tech.sbdevelopment.mapreflectionapi.nms;
|
||||
|
||||
import net.minecraft.network.protocol.game.PacketPlayOutEntityMetadata;
|
||||
import net.minecraft.network.protocol.game.PacketPlayOutSetSlot;
|
||||
import net.minecraft.network.syncher.DataWatcher;
|
||||
import net.minecraft.network.syncher.DataWatcherRegistry;
|
||||
import net.minecraft.server.level.EntityPlayer;
|
||||
import net.minecraft.world.entity.Entity;
|
||||
import net.minecraft.world.entity.decoration.EntityItemFrame;
|
||||
import org.bukkit.*;
|
||||
import org.bukkit.craftbukkit.v1_19_R1.CraftWorld;
|
||||
import org.bukkit.craftbukkit.v1_19_R1.entity.CraftPlayer;
|
||||
import org.bukkit.craftbukkit.v1_19_R1.inventory.CraftItemStack;
|
||||
import org.bukkit.entity.ItemFrame;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.inventory.ItemStack;
|
||||
import org.bukkit.inventory.meta.ItemMeta;
|
||||
import org.bukkit.metadata.FixedMetadataValue;
|
||||
import tech.sbdevelopment.mapreflectionapi.ArrayImage;
|
||||
import tech.sbdevelopment.mapreflectionapi.MapController;
|
||||
import tech.sbdevelopment.mapreflectionapi.MapReflectionAPI;
|
||||
import tech.sbdevelopment.mapreflectionapi.MapWrapper;
|
||||
import tech.sbdevelopment.mapreflectionapi.exceptions.MapLimitExceededException;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.UUID;
|
||||
|
||||
public class MapWrapper_v1_19_R1 implements MapWrapper {
|
||||
protected ArrayImage content;
|
||||
|
||||
protected MapController controller = new MapController() {
|
||||
private final Map<UUID, Integer> viewers = new HashMap<>();
|
||||
|
||||
@Override
|
||||
public void addViewer(Player player) throws MapLimitExceededException {
|
||||
if (!isViewing(player)) {
|
||||
viewers.put(player.getUniqueId(), MapReflectionAPI.getMapManager().getNextFreeIdFor(player));
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void removeViewer(OfflinePlayer player) {
|
||||
viewers.remove(player.getUniqueId());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void clearViewers() {
|
||||
for (UUID uuid : viewers.keySet()) {
|
||||
viewers.remove(uuid);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isViewing(OfflinePlayer player) {
|
||||
if (player == null) return false;
|
||||
return viewers.containsKey(player.getUniqueId());
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getMapId(OfflinePlayer player) {
|
||||
if (isViewing(player)) {
|
||||
return viewers.get(player.getUniqueId());
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void update(ArrayImage content) {
|
||||
MapWrapper duplicate = MapReflectionAPI.getMapManager().getDuplicate(content);
|
||||
if (duplicate != null) {
|
||||
MapWrapper_v1_19_R1.this.content = duplicate.getContent();
|
||||
return;
|
||||
}
|
||||
|
||||
MapWrapper_v1_19_R1.this.content = content;
|
||||
|
||||
for (UUID id : viewers.keySet()) {
|
||||
sendContent(Bukkit.getPlayer(id));
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public ArrayImage getContent() {
|
||||
return MapWrapper_v1_19_R1.this.getContent();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void sendContent(Player player) {
|
||||
sendContent(player, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void sendContent(Player player, boolean withoutQueue) {
|
||||
if (!isViewing(player)) return;
|
||||
|
||||
int id = getMapId(player);
|
||||
if (withoutQueue) {
|
||||
MapSender_v1_19_R1.sendMap(id, MapWrapper_v1_19_R1.this.content, player);
|
||||
} else {
|
||||
MapSender_v1_19_R1.addToQueue(id, MapWrapper_v1_19_R1.this.content, player);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void showInInventory(Player player, int slot, boolean force) {
|
||||
if (!isViewing(player)) return;
|
||||
|
||||
if (player.getGameMode() == GameMode.CREATIVE && !force) return;
|
||||
|
||||
if (slot < 9) {
|
||||
slot += 36;
|
||||
} else if (slot > 35 && slot != 45) {
|
||||
slot = 8 - (slot - 36);
|
||||
}
|
||||
|
||||
CraftPlayer craftPlayer = (CraftPlayer) player;
|
||||
int windowId = craftPlayer.getHandle().inventoryMenu.containerId;
|
||||
int stateId = craftPlayer.getHandle().inventoryMenu.getStateId();
|
||||
|
||||
ItemStack stack = new ItemStack(Material.MAP, 1);
|
||||
net.minecraft.world.item.ItemStack nmsStack = CraftItemStack.asNMSCopy(stack);
|
||||
|
||||
PacketPlayOutSetSlot packet = new PacketPlayOutSetSlot(windowId, stateId, slot, nmsStack);
|
||||
((EntityPlayer) player).connection.send(packet);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void showInInventory(Player player, int slot) {
|
||||
showInInventory(player, slot, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void showInHand(Player player, boolean force) {
|
||||
if (player.getInventory().getItemInMainHand().getType() != Material.MAP && !force) return;
|
||||
showInInventory(player, player.getInventory().getHeldItemSlot(), force);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void showInHand(Player player) {
|
||||
showInHand(player, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void showInFrame(Player player, ItemFrame frame) {
|
||||
showInFrame(player, frame, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void showInFrame(Player player, ItemFrame frame, boolean force) {
|
||||
if (frame.getItem().getType() != Material.MAP && !force) return;
|
||||
showInFrame(player, frame.getEntityId());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void showInFrame(Player player, int entityId) {
|
||||
showInFrame(player, entityId, null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void showInFrame(Player player, int entityId, String debugInfo) {
|
||||
if (!isViewing(player)) return;
|
||||
|
||||
ItemStack stack = new ItemStack(Material.MAP, 1);
|
||||
if (debugInfo != null) {
|
||||
ItemMeta itemMeta = stack.getItemMeta();
|
||||
itemMeta.setDisplayName(debugInfo);
|
||||
stack.setItemMeta(itemMeta);
|
||||
}
|
||||
|
||||
Bukkit.getScheduler().runTask(MapReflectionAPI.getInstance(), () -> {
|
||||
ItemFrame frame = getItemFrameById(player.getWorld(), entityId);
|
||||
if (frame != null) {
|
||||
frame.removeMetadata("MAP_WRAPPER_REF", MapReflectionAPI.getInstance());
|
||||
frame.setMetadata("MAP_WRAPPER_REF", new FixedMetadataValue(MapReflectionAPI.getInstance(), MapWrapper_v1_19_R1.this));
|
||||
}
|
||||
|
||||
sendItemFramePacket(player, entityId, stack, getMapId(player));
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
public void clearFrame(Player player, int entityId) {
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void clearFrame(Player player, ItemFrame frame) {
|
||||
|
||||
}
|
||||
|
||||
private ItemFrame getItemFrameById(World world, int entityId) {
|
||||
CraftWorld craftWorld = (CraftWorld) world;
|
||||
|
||||
Entity entity = craftWorld.getHandle().getEntity(entityId);
|
||||
if (entity == null) return null;
|
||||
|
||||
if (entity instanceof ItemFrame) return (ItemFrame) entity;
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
private void sendItemFramePacket(Player player, int entityId, ItemStack stack, int mapId) {
|
||||
net.minecraft.world.item.ItemStack nmsStack = CraftItemStack.asNMSCopy(stack);
|
||||
nmsStack.getOrCreateTag().putInt("map", mapId);
|
||||
|
||||
DataWatcher watcher = new DataWatcher(null);
|
||||
watcher.set(DataWatcher.defineId(EntityItemFrame.class, DataWatcherRegistry.ITEM_STACK), nmsStack);
|
||||
|
||||
PacketPlayOutEntityMetadata packet = new PacketPlayOutEntityMetadata(entityId, watcher, true);
|
||||
((EntityPlayer) player).connection.send(packet);
|
||||
}
|
||||
};
|
||||
|
||||
@Override
|
||||
public MapController getController() {
|
||||
return controller;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ArrayImage getContent() {
|
||||
return content;
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue