This repository has been archived by the owner on Dec 7, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 47
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
bb63436
commit 5819cbf
Showing
10 changed files
with
336 additions
and
44 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
46 changes: 46 additions & 0 deletions
46
src/main/java/in/twizmwaz/cardinal/event/PlayerSettingChangeEvent.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
package in.twizmwaz.cardinal.event; | ||
|
||
import in.twizmwaz.cardinal.settings.Setting; | ||
import in.twizmwaz.cardinal.settings.SettingValue; | ||
import org.bukkit.entity.Player; | ||
import org.bukkit.event.HandlerList; | ||
import org.bukkit.event.player.PlayerEvent; | ||
|
||
public class PlayerSettingChangeEvent extends PlayerEvent { | ||
|
||
private static final HandlerList handlers = new HandlerList(); | ||
|
||
private final Setting setting; | ||
private final SettingValue newValue; | ||
private final SettingValue oldValue; | ||
|
||
public PlayerSettingChangeEvent(Player player, Setting setting, SettingValue oldValue, SettingValue newValue) { | ||
super(player); | ||
|
||
this.setting = setting; | ||
this.newValue = newValue; | ||
this.oldValue = oldValue; | ||
} | ||
|
||
public static HandlerList getHandlerList() { | ||
return handlers; | ||
} | ||
|
||
@Override | ||
public HandlerList getHandlers() { | ||
return handlers; | ||
} | ||
|
||
public Setting getSetting() { | ||
return setting; | ||
} | ||
|
||
public SettingValue getOldValue() { | ||
return oldValue; | ||
} | ||
|
||
public SettingValue getNewValue() { | ||
return newValue; | ||
} | ||
|
||
} |
24 changes: 0 additions & 24 deletions
24
src/main/java/in/twizmwaz/cardinal/event/PlayerVisibilityChangeEvent.java
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
251 changes: 251 additions & 0 deletions
251
src/main/java/in/twizmwaz/cardinal/module/modules/longTntRender/LongTntRender.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,251 @@ | ||
package in.twizmwaz.cardinal.module.modules.longTntRender; | ||
|
||
import com.mojang.authlib.GameProfile; | ||
import in.twizmwaz.cardinal.event.PlayerSettingChangeEvent; | ||
import in.twizmwaz.cardinal.module.TaskedModule; | ||
import in.twizmwaz.cardinal.settings.Setting; | ||
import in.twizmwaz.cardinal.settings.Settings; | ||
import net.minecraft.server.v1_8_R3.DataWatcher; | ||
import net.minecraft.server.v1_8_R3.IChatBaseComponent; | ||
import net.minecraft.server.v1_8_R3.Packet; | ||
import net.minecraft.server.v1_8_R3.PacketPlayOutEntityDestroy; | ||
import net.minecraft.server.v1_8_R3.PacketPlayOutEntityEquipment; | ||
import net.minecraft.server.v1_8_R3.PacketPlayOutEntityTeleport; | ||
import net.minecraft.server.v1_8_R3.PacketPlayOutNamedEntitySpawn; | ||
import net.minecraft.server.v1_8_R3.PacketPlayOutPlayerInfo; | ||
import net.minecraft.server.v1_8_R3.PacketPlayOutScoreboardTeam; | ||
import net.minecraft.server.v1_8_R3.WorldSettings; | ||
import org.bukkit.Effect; | ||
import org.bukkit.Location; | ||
import org.bukkit.Material; | ||
import org.bukkit.craftbukkit.v1_8_R3.entity.CraftPlayer; | ||
import org.bukkit.craftbukkit.v1_8_R3.inventory.CraftItemStack; | ||
import org.bukkit.entity.Player; | ||
import org.bukkit.entity.TNTPrimed; | ||
import org.bukkit.event.EventHandler; | ||
import org.bukkit.event.HandlerList; | ||
import org.bukkit.event.entity.EntityExplodeEvent; | ||
import org.bukkit.event.entity.ExplosionPrimeEvent; | ||
import org.bukkit.event.player.PlayerJoinEvent; | ||
import org.bukkit.event.player.PlayerQuitEvent; | ||
import org.bukkit.inventory.ItemStack; | ||
|
||
import java.lang.reflect.Field; | ||
import java.util.ArrayList; | ||
import java.util.Collections; | ||
import java.util.HashMap; | ||
import java.util.List; | ||
import java.util.Map; | ||
import java.util.UUID; | ||
|
||
public class LongTntRender implements TaskedModule { | ||
|
||
public HashMap<TNTPrimed, GameProfile> entityIDs = new HashMap<>(); | ||
public HashMap<TNTPrimed, List<Player>> viewers = new HashMap<>(); | ||
public List<Integer> usedIDs = new ArrayList<>(); | ||
public List<TNTPrimed> toAdd = new ArrayList<>(); | ||
|
||
private List<Player> settings = new ArrayList<>(); | ||
|
||
public Setting setting = Settings.getSettingByName("TntRendering"); | ||
|
||
@Override | ||
public void unload() { | ||
HandlerList.unregisterAll(this); | ||
} | ||
|
||
@Override | ||
public void run() { | ||
for (int i = 0; i < toAdd.size(); i++) { | ||
TNTPrimed tnt = toAdd.get(0); | ||
broadcastPacket(teamPacket(tnt, true)); | ||
broadcastPacket(tabListPacket(tnt, true)); | ||
toAdd.remove(0); | ||
} | ||
Map<TNTPrimed, Integer> entityIDs2 = (Map<TNTPrimed, Integer>)entityIDs.clone(); | ||
for (Map.Entry<TNTPrimed, Integer> entry : entityIDs2.entrySet()) { | ||
TNTPrimed tnt = entry.getKey(); | ||
Location loc = tnt.getLocation(); | ||
if (tnt.isDead()) { | ||
broadcastPacket(tabListPacket(tnt, false)); | ||
broadcastPacket(teamPacket(tnt, false)); | ||
broadcastPacket(removeFakePlayerPacket(tnt)); | ||
usedIDs.remove(usedIDs.indexOf(Integer.parseInt(getProfileFor(tnt).getName()))); | ||
viewers.remove(tnt); | ||
entityIDs.remove(tnt); | ||
} else { | ||
for (Player player : settings) { | ||
if (loc.distance(player.getLocation()) >= 63.0f) { | ||
if (viewers.get(tnt).contains(player)) { | ||
sendPacket(player, movePacket(tnt)); | ||
} else { | ||
createFakePlayerPacket(player, tnt); | ||
viewers.get(tnt).add(player); | ||
} | ||
} else { | ||
if (viewers.get(tnt).contains(player)) { | ||
sendPacket(player, removeFakePlayerPacket(tnt)); | ||
viewers.get(tnt).remove(player); | ||
} | ||
} | ||
} | ||
} | ||
} | ||
} | ||
|
||
@EventHandler | ||
public void onPlayerJoin(PlayerJoinEvent event) { | ||
if (!setting.getValueByPlayer(event.getPlayer()).getValue().equals("none")) { | ||
settings.add(event.getPlayer()); | ||
} | ||
} | ||
|
||
@EventHandler | ||
public void onSettingChange(PlayerSettingChangeEvent event) { | ||
if (!event.getSetting().equals(setting)) return; | ||
Player player = event.getPlayer(); | ||
String newValue = event.getNewValue().getValue(); | ||
if(newValue.equals("none")) { | ||
for (TNTPrimed tnt : entityIDs.keySet()) { | ||
sendPacket(player, tabListPacket(tnt, false)); | ||
sendPacket(player, teamPacket(tnt, false)); | ||
sendPacket(player, removeFakePlayerPacket(tnt)); | ||
if (viewers.get(tnt).contains(player)) viewers.get(tnt).remove(player); | ||
} | ||
if (settings.contains(player)) settings.remove(player); | ||
} else { | ||
settings.add(player); | ||
for (TNTPrimed tnt : entityIDs.keySet()) { | ||
sendPacket(player, tabListPacket(tnt, true)); | ||
sendPacket(player, teamPacket(tnt, true)); | ||
} | ||
} | ||
} | ||
|
||
@EventHandler | ||
public void onPlayerQuit(PlayerQuitEvent event) { | ||
settings.remove(event.getPlayer()); | ||
} | ||
|
||
@EventHandler | ||
public void onTntSpawn(ExplosionPrimeEvent event) { | ||
if (event.getEntity() instanceof TNTPrimed) toAdd.add((TNTPrimed) event.getEntity()); | ||
} | ||
|
||
@EventHandler | ||
public void onTntExplode(EntityExplodeEvent event){ | ||
if (!(event.getEntity() instanceof TNTPrimed)) return; | ||
Location actual = event.getLocation(); | ||
for (Player player : settings) { | ||
if (actual.distance(player.getLocation()) >= 64.0f) player.playEffect(actual, Effect.EXPLOSION_HUGE, 0, 0, 0f, 0f, 0f, 1f, 256, 1); | ||
} | ||
} | ||
|
||
public GameProfile getProfileFor(TNTPrimed tnt) { | ||
if (entityIDs.isEmpty()) { | ||
entityIDs.put(tnt, new GameProfile(UUID.randomUUID(), "" + 1000)); | ||
viewers.put(tnt, new ArrayList<Player>()); | ||
usedIDs.add(1000); | ||
} else if (!entityIDs.containsKey(tnt)){ | ||
int i = Collections.max(usedIDs) + 1; | ||
entityIDs.put(tnt, new GameProfile(UUID.randomUUID(), "" + i)); | ||
viewers.put(tnt, new ArrayList<Player>()); | ||
usedIDs.add(i); | ||
} | ||
return entityIDs.get(tnt); | ||
} | ||
|
||
public int getIdFor(TNTPrimed tnt) { | ||
return Integer.MAX_VALUE - Integer.parseInt(getProfileFor(tnt).getName()); | ||
} | ||
|
||
public DataWatcher createFakePlayerWatcher(Player player) { | ||
DataWatcher data = new DataWatcher(((CraftPlayer)player).getHandle()); | ||
data.a(0, (byte) 0x20); | ||
return data; | ||
} | ||
|
||
public Packet teamPacket(TNTPrimed tnt, boolean state) { | ||
PacketPlayOutScoreboardTeam teamPacket = new PacketPlayOutScoreboardTeam(); | ||
|
||
teamPacket.a = "\000TabView" + 80; // team name | ||
teamPacket.b = "\000TabView" + 80; // team display name | ||
teamPacket.c = ""; // team prefix | ||
teamPacket.d = ""; // team suffix | ||
teamPacket.e = "never"; // name tag visibility | ||
teamPacket.f = -1; // color | ||
teamPacket.g = Collections.singletonList(getProfileFor(tnt).getName()); // list of player names (string list) | ||
teamPacket.h = state ? 3 : 4; // action (0 to add team, 3 to add player, 4 to remove player) | ||
teamPacket.i = 0; // allowFriendlyFire() + canSeeFriendlyInvisibles() | ||
return teamPacket; | ||
} | ||
|
||
public Packet tabListPacket(TNTPrimed tnt, boolean state) { | ||
PacketPlayOutPlayerInfo listPacket = new PacketPlayOutPlayerInfo(); | ||
|
||
listPacket.a = state ? PacketPlayOutPlayerInfo.EnumPlayerInfoAction.ADD_PLAYER : PacketPlayOutPlayerInfo.EnumPlayerInfoAction.REMOVE_PLAYER; | ||
List<PacketPlayOutPlayerInfo.PlayerInfoData> dataList = Collections.singletonList(new PacketPlayOutPlayerInfo.PlayerInfoData(getProfileFor(tnt), 0, WorldSettings.EnumGamemode.SURVIVAL, IChatBaseComponent.ChatSerializer.a("{text:\"" + getProfileFor(tnt).getName() + "\"}"))); | ||
try { | ||
Field b = listPacket.getClass().getDeclaredField("b"); | ||
b.setAccessible(true); | ||
b.set(listPacket, dataList); | ||
} catch (Exception e) { | ||
e.printStackTrace(); | ||
} | ||
return listPacket; | ||
} | ||
|
||
public void createFakePlayerPacket(Player player, TNTPrimed tnt) { | ||
Location loc = tnt.getLocation(); | ||
PacketPlayOutNamedEntitySpawn spawnPacket = new PacketPlayOutNamedEntitySpawn(); | ||
|
||
spawnPacket.a = getIdFor(tnt); | ||
spawnPacket.b = getProfileFor(tnt).getId(); | ||
spawnPacket.c = (int)(loc.getX() * 32); //x | ||
spawnPacket.d = (int)((loc.getY() - 1.2) * 32); //y | ||
spawnPacket.e = (int)(loc.getZ() * 32); //z | ||
spawnPacket.f = 0; // yaw | ||
spawnPacket.g = 0; // pitch | ||
spawnPacket.h = 0; // item in hand | ||
spawnPacket.i = createFakePlayerWatcher(player);// DataWatcher | ||
spawnPacket.j = spawnPacket.i.c(); // List<WatchableObject>, from DataWatcher | ||
DataWatcher.deepCopy(spawnPacket.j); // No idea what this is for, but the constructor for PacketPlayOutNamedEntitySpawn(EntityHuman) does it | ||
|
||
sendPacket(player, spawnPacket); | ||
|
||
PacketPlayOutEntityEquipment armorPacket = new PacketPlayOutEntityEquipment(getIdFor(tnt), 4, CraftItemStack.asNMSCopy(new ItemStack(Material.TNT))); | ||
|
||
sendPacket(player, armorPacket); | ||
} | ||
|
||
|
||
public Packet movePacket(TNTPrimed tnt) { | ||
Location loc = tnt.getLocation(); | ||
|
||
PacketPlayOutEntityTeleport movePacket = new PacketPlayOutEntityTeleport(); | ||
|
||
movePacket.a = getIdFor(tnt); | ||
movePacket.b = (int) (loc.getX() * 32.0D); | ||
movePacket.c = (int) ((loc.getY() - 1.2) * 32.0D); | ||
movePacket.d = (int) (loc.getZ() * 32.0D); | ||
movePacket.e = 0; | ||
movePacket.f = 0; | ||
movePacket.g = false; | ||
|
||
return movePacket; | ||
} | ||
|
||
public Packet removeFakePlayerPacket(TNTPrimed tnt) { | ||
return new PacketPlayOutEntityDestroy(getIdFor(tnt)); | ||
} | ||
|
||
public void broadcastPacket(Packet packet) { | ||
for (Player player : settings) { | ||
sendPacket(player, packet); | ||
} | ||
} | ||
|
||
public void sendPacket(Player player, Packet packet) { | ||
((CraftPlayer) player).getHandle().playerConnection.sendPacket(packet); | ||
} | ||
} |
14 changes: 14 additions & 0 deletions
14
src/main/java/in/twizmwaz/cardinal/module/modules/longTntRender/LongTntRenderBuilder.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
package in.twizmwaz.cardinal.module.modules.longTntRender; | ||
|
||
import in.twizmwaz.cardinal.match.Match; | ||
import in.twizmwaz.cardinal.module.ModuleBuilder; | ||
import in.twizmwaz.cardinal.module.ModuleCollection; | ||
|
||
public class LongTntRenderBuilder implements ModuleBuilder { | ||
|
||
@Override | ||
public ModuleCollection<LongTntRender> load(Match match) { | ||
return new ModuleCollection<>(new LongTntRender()); | ||
} | ||
|
||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.