+ 1.11 Update

+ testing ArmorStand modeling
This commit is contained in:
Johannes Theiner 2016-11-24 20:13:13 +01:00
parent 79d0dfd757
commit 50da4db042
6 changed files with 150 additions and 55 deletions

31
pom.xml
View File

@ -48,36 +48,49 @@
</plugins> </plugins>
</build> </build>
<!--TODO: add maven repo for univento code-->
<repositories> <repositories>
<repository> <repository>
<id>spigot-repo</id> <id>univentoEU</id>
<url>https://hub.spigotmc.org/nexus/content/repositories/snapshots/</url> <url>http://dev.joethei.de:8081/repository/public/</url>
</repository> </repository>
</repositories> </repositories>
<dependencies> <dependencies>
<dependency> <dependency>
<groupId>eu.univento</groupId> <groupId>com.destroystokyo.paper</groupId>
<artifactId>Core</artifactId> <artifactId>paper-api</artifactId>
<version>1.0-SNAPSHOT</version> <version>1.11-R0.1-SNAPSHOT</version>
<scope>provided</scope>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.spigotmc</groupId> <groupId>org.spigotmc</groupId>
<artifactId>spigot-api</artifactId> <artifactId>spigot-api</artifactId>
<version>1.10.2-R0.1-SNAPSHOT</version> <version>1.11-R0.1-SNAPSHOT</version>
<scope>provided</scope> <scope>provided</scope>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.bukkit</groupId> <groupId>org.bukkit</groupId>
<artifactId>bukkit</artifactId> <artifactId>bukkit</artifactId>
<version>1.10.2-R0.1-SNAPSHOT</version> <version>1.11-R0.1-SNAPSHOT</version>
<scope>provided</scope> <scope>provided</scope>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.bukkit</groupId> <groupId>org.bukkit</groupId>
<artifactId>craftbukkit</artifactId> <artifactId>craftbukkit</artifactId>
<version>1.10.2-R0.1-SNAPSHOT</version> <version>1.11-R0.1-SNAPSHOT</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>eu.univento</groupId>
<artifactId>Core</artifactId>
<version>1.0-SNAPSHOT</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>eu.univento</groupId>
<artifactId>Commons</artifactId>
<version>1.0-SNAPSHOT</version>
<scope>provided</scope> <scope>provided</scope>
</dependency> </dependency>
</dependencies> </dependencies>

View File

@ -1,8 +1,8 @@
package eu.univento.trashgames; package eu.univento.trashgames;
import eu.univento.commons.server.ServerType;
import eu.univento.core.Core; import eu.univento.core.Core;
import eu.univento.core.api.server.ServerSettings; import eu.univento.core.api.server.ServerSettings;
import eu.univento.core.api.server.ServerType;
import eu.univento.trashgames.commands.Setloc; import eu.univento.trashgames.commands.Setloc;
import eu.univento.trashgames.game.GameState; import eu.univento.trashgames.game.GameState;
import eu.univento.trashgames.listeners.JoinQuit; import eu.univento.trashgames.listeners.JoinQuit;
@ -42,7 +42,7 @@ public class TrashGames extends JavaPlugin {
Core.getInstance().registerPlugin(this); Core.getInstance().registerPlugin(this);
ServerSettings.setGame(true); ServerSettings.setGame(true);
ServerSettings.setServerType(ServerType.GAME_TRASHGAMES); ServerSettings.setServerType(ServerType.SECRET_GAME_TRASHGAMES);
ServerSettings.setGameMode(GameMode.ADVENTURE); ServerSettings.setGameMode(GameMode.ADVENTURE);
PluginManager pm = Bukkit.getPluginManager(); PluginManager pm = Bukkit.getPluginManager();

View File

@ -0,0 +1,81 @@
package eu.univento.trashgames.game;
import eu.univento.core.api.items.ItemBuilder;
import eu.univento.trashgames.TrashGames;
import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.entity.ArmorStand;
import org.bukkit.inventory.ItemStack;
import org.bukkit.scheduler.BukkitRunnable;
import org.bukkit.util.EulerAngle;
import java.util.HashMap;
/**
* @author joethei
* @version 0.1
*/
public class Duck {
private HashMap<String, ArmorStand> parts = new HashMap<>();
public Duck(Location location) {
ArmorStand body = getNewArmorStand(location, false, true);
ArmorStand head = getNewArmorStand(location.clone().add(0, 0.2, 0.2), false, true);
ArmorStand leftFeather = getNewArmorStand(location.clone().add(0.43, 0.2, 0.5), false, true);
ArmorStand rightFeather = getNewArmorStand(location.clone().add(-0.04, 0.2, 0.5), false, true);
ArmorStand leftFeet = getNewArmorStand(location.clone().add(0.4, 0.15, 0.2), false, true);
ArmorStand rightFeet = getNewArmorStand(location.clone().add(0, 0.15, 0.2), false, true);
body.setHelmet(new ItemStack(Material.GOLD_BLOCK));
head.setHelmet(new ItemBuilder(Material.SKULL).data(3).skullOwner("duck").make());
leftFeather.setHeadPose(new EulerAngle(4.7123889804, 0, 1.5707963268));
leftFeather.setHelmet(new ItemStack(Material.INK_SACK, 1, (short) 11));
rightFeather.setHeadPose(new EulerAngle(4.7123889804, 0, 1.5707963268));
rightFeather.setHelmet(new ItemStack(Material.INK_SACK, 1, (short) 11));
leftFeet.setRightArmPose(new EulerAngle(0.2617993878, 0, 0));
leftFeet.setItemInHand(new ItemStack(Material.RED_SANDSTONE));
rightFeet.setRightArmPose(new EulerAngle(0.2617993878, 0, 0));
rightFeet.setItemInHand(new ItemStack(Material.RED_SANDSTONE));
parts.put("body", body);
parts.put("head", head);
parts.put("leftfeather", leftFeather);
parts.put("rightfeather", rightFeather);
parts.put("leftfeet", leftFeet);
parts.put("rightfeet", rightFeet);
}
private ArmorStand getNewArmorStand(Location location, boolean visible, boolean mini) {
ArmorStand as = location.getWorld().spawn(location, ArmorStand.class);
as.setBasePlate(false);
as.setArms(true);
as.setVisible(visible);
as.setInvulnerable(true);
as.setCanPickupItems(false);
as.setGravity(false);
as.setSmall(mini);
return as;
}
public void fly() {
new BukkitRunnable() {
public void run() {
for(String part : parts.keySet()) {
parts.get(part).teleport(parts.get(part).getLocation().add(0,0.1,0));
}
}
}.runTaskTimer(TrashGames.getInstance(), 0L, 1L);
}
}

View File

@ -7,6 +7,7 @@ import eu.univento.core.api.player.SpectateManager;
import eu.univento.core.api.player.Spectator; import eu.univento.core.api.player.Spectator;
import eu.univento.trashgames.TrashGames; import eu.univento.trashgames.TrashGames;
import eu.univento.trashgames.game.GameState; import eu.univento.trashgames.game.GameState;
import org.bukkit.Particle;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerJoinEvent; import org.bukkit.event.player.PlayerJoinEvent;
@ -29,6 +30,7 @@ public class JoinQuit implements Listener{
//new GameCountdown(); //new GameCountdown();
} }
} }
p.spawnParticle(Particle.TOTEM, p.getLocation(), 1);
} }
@EventHandler @EventHandler
@ -37,6 +39,7 @@ public class JoinQuit implements Listener{
if(PlayerManager.contains(p)) { if(PlayerManager.contains(p)) {
PlayerManager.remove(p); PlayerManager.remove(p);
if(TrashGames.getState() == GameState.GAME) { if(TrashGames.getState() == GameState.GAME) {
p.damage(99999D);
e.setQuitMessage(p.getDatabasePlayer().getRank().getColor() + p.getDisplayName() + " hat uns verlassen"); e.setQuitMessage(p.getDatabasePlayer().getRank().getColor() + p.getDisplayName() + " hat uns verlassen");
PlayerManager.getPlayers().get(0).getDatabasePlayer().addCoins(50); PlayerManager.getPlayers().get(0).getDatabasePlayer().addCoins(50);
Utils.restart(); Utils.restart();

View File

@ -6,20 +6,17 @@ import eu.univento.core.api.player.CustomPlayer;
import eu.univento.trashgames.TrashGames; import eu.univento.trashgames.TrashGames;
import eu.univento.trashgames.game.GameState; import eu.univento.trashgames.game.GameState;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.Effect; import org.bukkit.entity.*;
import org.bukkit.Material;
import org.bukkit.entity.Arrow;
import org.bukkit.entity.FishHook;
import org.bukkit.entity.Player;
import org.bukkit.entity.SpectralArrow;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.entity.EntityDamageByEntityEvent; import org.bukkit.event.entity.EntityDamageByEntityEvent;
import org.bukkit.event.entity.EntityDamageEvent; import org.bukkit.event.entity.EntityDamageEvent;
import org.bukkit.event.entity.PlayerDeathEvent; import org.bukkit.event.entity.PlayerDeathEvent;
import org.bukkit.event.player.PlayerInteractEvent; import org.bukkit.event.entity.ProjectileLaunchEvent;
import org.bukkit.event.player.PlayerRespawnEvent; import org.bukkit.event.player.PlayerRespawnEvent;
import java.util.Random;
/** /**
* @author joethei * @author joethei
* @version 0.1 * @version 0.1
@ -32,7 +29,7 @@ public class PlayerEvents implements Listener{
if(PlayerManager.contains(p)) { if(PlayerManager.contains(p)) {
PlayerManager.remove(p); PlayerManager.remove(p);
TrashGames.setState(GameState.RESTART); TrashGames.setState(GameState.RESTART);
Bukkit.broadcastMessage(PlayerManager.getPlayers().get(0) + " hat gewonnen"); Bukkit.broadcastMessage(PlayerManager.getPlayers().get(0).getDisplayName() + " hat gewonnen");
PlayerManager.getPlayers().get(0).getDatabasePlayer().addCoins(50); PlayerManager.getPlayers().get(0).getDatabasePlayer().addCoins(50);
} }
} }
@ -52,17 +49,31 @@ public class PlayerEvents implements Listener{
} }
} }
@EventHandler
public void onShoot(ProjectileLaunchEvent e) {
Projectile projectile = e.getEntity();
projectile.setGravity(false);
projectile.setCustomName("Hallo du");
projectile.setCustomNameVisible(true);
}
@EventHandler @EventHandler
public void onDamageByEntity(EntityDamageByEntityEvent e) { public void onDamageByEntity(EntityDamageByEntityEvent e) {
if(e.getEntity() instanceof Player) { if(e.getEntity() instanceof Player) {
CustomPlayer p = CustomPlayer.getPlayer((Player) e.getEntity()); CustomPlayer p = CustomPlayer.getPlayer((Player) e.getEntity());
if(e.getDamager() instanceof Player) { if(e.getDamager() instanceof Player) {
CustomPlayer t = CustomPlayer.getPlayer((Player) e.getDamager()); CustomPlayer t = CustomPlayer.getPlayer((Player) e.getDamager());
if(e.getDamager().getLocation().getY() - t.getLocation().getY() > 1.35D) {
e.setDamage(e.getDamage() * 5D);
p.sendMessage("§4Head§6Shoot");
}
p.sendMessage("Du hast was abgekriegt von " + t.getDatabasePlayer().getRank().getColor() + t.getDisplayName()); p.sendMessage("Du hast was abgekriegt von " + t.getDatabasePlayer().getRank().getColor() + t.getDisplayName());
p.setArrowsInBody(new Random().nextInt(50));
} }
if(e.getDamager() instanceof Arrow) { if(e.getDamager() instanceof Arrow) {
Arrow arrow = (Arrow) e.getDamager(); Arrow arrow = (Arrow) e.getDamager();
CustomPlayer shooter = CustomPlayer.getPlayer((Player) arrow.getShooter()); CustomPlayer shooter = CustomPlayer.getPlayer((Player) arrow.getShooter());
arrow.setBounce(true);
p.sendMessage("Der Pfeil kam von " + shooter.getDatabasePlayer().getRank().getColor() + shooter.getDisplayName()); p.sendMessage("Der Pfeil kam von " + shooter.getDatabasePlayer().getRank().getColor() + shooter.getDisplayName());
} }
if(e.getDamager() instanceof SpectralArrow) { if(e.getDamager() instanceof SpectralArrow) {
@ -78,14 +89,4 @@ public class PlayerEvents implements Listener{
} }
} }
@EventHandler
public void onInteract(PlayerInteractEvent e) {
CustomPlayer p = CustomPlayer.getPlayer(e.getPlayer());
if(e.getClickedBlock() == null) return;
if(e.getClickedBlock().getType() == Material.CHEST) {
e.setCancelled(true);
p.playEffect(e.getClickedBlock().getLocation(), Effect.CLOUD, 200);
}
}
} }

View File

@ -6,9 +6,10 @@ import eu.univento.core.api.Utils;
import eu.univento.core.api.blocks.banners.BannerString; import eu.univento.core.api.blocks.banners.BannerString;
import eu.univento.core.api.blocks.banners.FloatingText; import eu.univento.core.api.blocks.banners.FloatingText;
import eu.univento.core.api.game.PlayerManager; import eu.univento.core.api.game.PlayerManager;
import eu.univento.core.api.map.Cuboid;
import eu.univento.core.api.player.CustomPlayer; import eu.univento.core.api.player.CustomPlayer;
import eu.univento.core.api.schematic.Cuboid;
import eu.univento.trashgames.TrashGames; import eu.univento.trashgames.TrashGames;
import eu.univento.trashgames.game.Duck;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.Material; import org.bukkit.Material;
@ -17,8 +18,6 @@ import org.bukkit.block.Banner;
import org.bukkit.entity.Entity; import org.bukkit.entity.Entity;
import org.bukkit.entity.Item; import org.bukkit.entity.Item;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
import org.bukkit.potion.PotionEffect;
import org.bukkit.potion.PotionEffectType;
import org.bukkit.scheduler.BukkitRunnable; import org.bukkit.scheduler.BukkitRunnable;
import java.util.ArrayList; import java.util.ArrayList;
@ -33,7 +32,7 @@ import java.util.stream.Collectors;
*/ */
public class GameCountdown extends BukkitRunnable { public class GameCountdown extends BukkitRunnable {
private int time = 3611; private int time = 611;
private Cuboid blocks; private Cuboid blocks;
public GameCountdown() { public GameCountdown() {
@ -42,25 +41,21 @@ public class GameCountdown extends BukkitRunnable {
@Override @Override
public void run() { public void run() {
Core.getCommons().getLoggingHandler().getTrashGames().info("GameCountdown running: " + time);
time--; time--;
if(time == 3610) { if(time == 610) {
Bukkit.broadcastMessage("Teleport");
blocks = new Cuboid(Config.readLocation("TrashGames.Locs.Corner.1"), Config.readLocation("TrashGames.Locs.Corner.2")); blocks = new Cuboid(Config.readLocation("TrashGames.Locs.Corner.1"), Config.readLocation("TrashGames.Locs.Corner.2"));
Bukkit.broadcastMessage("Blocks: " + blocks.getBlocks().size());
int i = 0; int i = 0;
for(CustomPlayer player : PlayerManager.getPlayers()) { for(CustomPlayer player : PlayerManager.getPlayers()) {
i++; i++;
player.teleport(Config.readLocation("TrashGames.Locs.Spawn." + i)); player.teleport(Config.readLocation("TrashGames.Locs.Spawn." + i));
player.addPotionEffect(new PotionEffect(PotionEffectType.SLOW, 10, 10000, false));
} }
ArrayList<Banner> wallBanners = blocks.getBlocks().stream().filter(block -> block.getType() == Material.WALL_BANNER).map(block -> (Banner) block.getState()).collect(Collectors.toCollection(ArrayList::new)); ArrayList<Banner> wallBanners = blocks.getBlocks().stream().filter(block -> block.getType() == Material.WALL_BANNER).map(block -> (Banner) block.getState()).collect(Collectors.toCollection(ArrayList::new));
ArrayList<Banner> banners = blocks.getBlocks().stream().filter(block -> block.getType() == Material.STANDING_BANNER).map(block -> (Banner) block.getState()).collect(Collectors.toCollection(ArrayList::new)); ArrayList<Banner> banners = blocks.getBlocks().stream().filter(block -> block.getType() == Material.STANDING_BANNER).map(block -> (Banner) block.getState()).collect(Collectors.toCollection(ArrayList::new));
BannerString string = new BannerString(wallBanners); BannerString string = new BannerString(wallBanners);
FloatingText text = new FloatingText("§FeuniventoEU", 4); FloatingText text = new FloatingText("univentoEU", 4);
new BukkitRunnable() { new BukkitRunnable() {
@Override @Override
public void run() { public void run() {
@ -69,7 +64,7 @@ public class GameCountdown extends BukkitRunnable {
}.runTaskTimer(TrashGames.getInstance(), 2, 3); }.runTaskTimer(TrashGames.getInstance(), 2, 3);
BannerString string1 = new BannerString(banners); BannerString string1 = new BannerString(banners);
FloatingText text1 = new FloatingText("§F3TrashGames", 4); FloatingText text1 = new FloatingText("TrashGames", 4);
new BukkitRunnable() { new BukkitRunnable() {
@Override @Override
public void run() { public void run() {
@ -78,12 +73,11 @@ public class GameCountdown extends BukkitRunnable {
}.runTaskTimer(TrashGames.getInstance(), 2, 3); }.runTaskTimer(TrashGames.getInstance(), 2, 3);
} }
if (time == 3600) { if (time == 600) {
for(CustomPlayer player : PlayerManager.getPlayers()) { for(CustomPlayer player : PlayerManager.getPlayers()) {
dropItems(player.getLocation().add(0.0D, 3.0D, 0.0D)); dropItems(player.getLocation().add(0.0D, 2.0D, 0.0D));
player.sendTitle(1, 5, 1, "§5Los", "§egehts"); player.sendTitle("§5Los", "§egehts");
} }
Bukkit.broadcastMessage("Jetzt aber schnell");
new BukkitRunnable() { new BukkitRunnable() {
@Override @Override
public void run() { public void run() {
@ -92,8 +86,11 @@ public class GameCountdown extends BukkitRunnable {
}.runTaskLater(TrashGames.getInstance(), 10 * 20L); }.runTaskLater(TrashGames.getInstance(), 10 * 20L);
} }
if (time == 3400) { if (time == 300) {
Bukkit.broadcastMessage("Die Hälfte ist geschaft"); Bukkit.broadcastMessage("§aDie Hälfte ist geschaft");
new Duck(PlayerManager.getPlayers().get(0).getLocation()).fly();
blocks.getBlocks().stream().filter(block -> block.getType() == Material.CHEST).forEach(block -> { blocks.getBlocks().stream().filter(block -> block.getType() == Material.CHEST).forEach(block -> {
for (CustomPlayer players : PlayerManager.getPlayers()) { for (CustomPlayer players : PlayerManager.getPlayers()) {
players.changeChestState(block.getLocation(), true); players.changeChestState(block.getLocation(), true);
@ -102,12 +99,11 @@ public class GameCountdown extends BukkitRunnable {
new BukkitRunnable() { new BukkitRunnable() {
@Override @Override
public void run() { public void run() {
List<Material> materials = Arrays.asList(Material.DIAMOND_SWORD, Material.IRON_SWORD, Material.DIAMOND_AXE, Material.DIAMOND_CHESTPLATE); List<Material> materials = Arrays.asList(Material.DIAMOND_SWORD, Material.IRON_SWORD, Material.DIAMOND_AXE, Material.DIAMOND_CHESTPLATE,
Material.DEAD_BUSH, Material.DEAD_BUSH, Material.DEAD_BUSH, Material.DEAD_BUSH, Material.DEAD_BUSH, Material.DEAD_BUSH, Material.DEAD_BUSH);
int random = new Random().nextInt(materials.size()); int random = new Random().nextInt(materials.size());
Item item = block.getWorld().dropItem(block.getLocation().add(0.0D, 1.0D, 0.0D), new ItemStack(materials.get(random))); Item item = block.getWorld().dropItem(block.getLocation().add(0.0D, 1.0D, 0.0D), new ItemStack(materials.get(random)));
item.setPickupDelay(5); item.setPickupDelay(5);
item.setGlowing(true);
item.setVelocity(item.getLocation().getDirection().multiply(0D).setY(0.5D));
for (CustomPlayer player : PlayerManager.getPlayers()) for (CustomPlayer player : PlayerManager.getPlayers())
player.playSound(block.getLocation(), Sound.ENTITY_CHICKEN_EGG, 1.0F, 1.0F); player.playSound(block.getLocation(), Sound.ENTITY_CHICKEN_EGG, 1.0F, 1.0F);
} }
@ -127,7 +123,11 @@ public class GameCountdown extends BukkitRunnable {
} }
if (time == 0) { if (time == 0) {
Bukkit.broadcastMessage("Die Zeit ist um"); for(CustomPlayer player : PlayerManager.getPlayers()) {
player.setVelocity(player.getLocation().getDirection().multiply(0.0D).setY(10.0D));
player.setGliding(true);
player.setInvulnerable(true);
}
this.cancel(); this.cancel();
Utils.restart(); Utils.restart();
for(CustomPlayer players : Core.getOnlinePlayers()) for(CustomPlayer players : Core.getOnlinePlayers())
@ -140,20 +140,17 @@ public class GameCountdown extends BukkitRunnable {
} }
}.runTaskLater(TrashGames.getInstance(), 5 * 20L); }.runTaskLater(TrashGames.getInstance(), 5 * 20L);
} }
for (CustomPlayer player : Core.getOnlinePlayers()) { for (CustomPlayer player : Core.getOnlinePlayers())
player.setLevel(time); player.setLevel(time);
}
} }
private void dropItems(Location loc) { private void dropItems(Location loc) {
List<ItemStack> items = Arrays.asList(new ItemStack(Material.APPLE, 64), new ItemStack(Material.WORKBENCH), List<ItemStack> items = Arrays.asList(new ItemStack(Material.APPLE, 64), new ItemStack(Material.WORKBENCH),
new ItemStack(Material.COBBLESTONE, 2), new ItemStack(Material.STICK, 4), new ItemStack(Material.ROTTEN_FLESH, 64), new ItemStack(Material.COBBLESTONE, 2), new ItemStack(Material.STICK, 4), new ItemStack(Material.ROTTEN_FLESH, 64),
new ItemStack(Material.APPLE, 20)); new ItemStack(Material.APPLE, 20), new ItemStack(Material.BOW), new ItemStack(Material.ARROW, 20));
for (ItemStack itemStack : items) { for (ItemStack itemStack : items) {
Item item = loc.getWorld().dropItemNaturally(loc, itemStack); Item item = loc.getWorld().dropItemNaturally(loc, itemStack);
item.setPickupDelay(3); item.setPickupDelay(3);
item.setGlowing(true);
item.setVelocity(item.getLocation().getDirection().multiply(0D).setY(0.5D));
for (CustomPlayer player : PlayerManager.getPlayers()) for (CustomPlayer player : PlayerManager.getPlayers())
player.playSound(item.getLocation(), Sound.ENTITY_CHICKEN_EGG, 1.0F, 1.0F); player.playSound(item.getLocation(), Sound.ENTITY_CHICKEN_EGG, 1.0F, 1.0F);
} }