diff --git a/pom.xml b/pom.xml
index 808bd16b..bf19c95d 100644
--- a/pom.xml
+++ b/pom.xml
@@ -118,12 +118,6 @@
system
${project.basedir}/lib/proxy-plugin-1.2.4.jar
-
- fr.mrmicky
- FastParticles
- 1.2.4
- compile
-
com.github.MilkBowl
VaultAPI
@@ -159,5 +153,11 @@
5.0.1
compile
+
+ xyz.xenondevs
+ particle
+ 1.8.4
+ compile
+
diff --git a/src/main/java/me/defender/cosmetics/api/category/glyphs/items/GlyphItems.java b/src/main/java/me/defender/cosmetics/api/category/glyphs/items/GlyphItems.java
index 6a9cada3..b3d0449e 100644
--- a/src/main/java/me/defender/cosmetics/api/category/glyphs/items/GlyphItems.java
+++ b/src/main/java/me/defender/cosmetics/api/category/glyphs/items/GlyphItems.java
@@ -69,7 +69,7 @@ public RarityType getRarity() {
public void execute(Player player, Location location) {
String fileLocation = config.getString(path + "file");
File file = new File(Utility.plugin().getDataFolder().getPath() + "/Glyphs/" + fileLocation);
- HCore.syncScheduler().every(500, TimeUnit.MILLISECONDS).limit(10).run(()-> {
+ HCore.asyncScheduler().every(500, TimeUnit.MILLISECONDS).limit(10).run(()-> {
glyphUtil.sendglyphs(player, file, location);
});
}
diff --git a/src/main/java/me/defender/cosmetics/api/category/glyphs/util/ImageParticles.java b/src/main/java/me/defender/cosmetics/api/category/glyphs/util/ImageParticles.java
index ec503e90..fc4bbec4 100644
--- a/src/main/java/me/defender/cosmetics/api/category/glyphs/util/ImageParticles.java
+++ b/src/main/java/me/defender/cosmetics/api/category/glyphs/util/ImageParticles.java
@@ -17,7 +17,7 @@ public class ImageParticles
private double ratio;
private final BufferedImage image;
private final int clearence;
-
+
public ImageParticles(final BufferedImage image, final int scanQuality) {
this.particles = new HashMap();
this.anchor = new Vector(0, 0, 0);
@@ -26,15 +26,15 @@ public ImageParticles(final BufferedImage image, final int scanQuality) {
this.image = image;
this.renderParticles(Math.abs(scanQuality));
}
-
+
public void setAnchor(final int x, final int y) {
this.anchor = new Vector(x, y, 0);
}
-
+
public void setDisplayRatio(final double ratio) {
this.ratio = ratio;
}
-
+
public Map getParticles(final Location location, final double pitch, final double yaw) {
final Map map = new HashMap();
for (final Vector vector : this.particles.keySet()) {
@@ -46,11 +46,11 @@ public Map getParticles(final Location location, final double p
}
return map;
}
-
+
public Map getParticles(final Location location) {
return this.getParticles(location, location.getPitch(), location.getYaw());
}
-
+
private void renderParticles(final int sensitivity) {
final int height = this.image.getHeight();
for (int width = this.image.getWidth(), x = 0; x < width; x += sensitivity) {
@@ -64,7 +64,7 @@ private void renderParticles(final int sensitivity) {
}
}
}
-
+
private Vector rotateAroundAxisX(final Vector v, double angle) {
angle = Math.toRadians(angle);
final double cos = Math.cos(angle);
@@ -73,7 +73,7 @@ private Vector rotateAroundAxisX(final Vector v, double angle) {
final double z = v.getY() * sin + v.getZ() * cos;
return v.setY(y).setZ(z);
}
-
+
private Vector rotateAroundAxisY(final Vector v, double angle) {
angle = -angle;
angle = Math.toRadians(angle);
diff --git a/src/main/java/me/defender/cosmetics/api/category/glyphs/util/glyphUtil.java b/src/main/java/me/defender/cosmetics/api/category/glyphs/util/glyphUtil.java
index 0e104798..f7fa1c75 100644
--- a/src/main/java/me/defender/cosmetics/api/category/glyphs/util/glyphUtil.java
+++ b/src/main/java/me/defender/cosmetics/api/category/glyphs/util/glyphUtil.java
@@ -2,12 +2,14 @@
package me.defender.cosmetics.api.category.glyphs.util;
-import fr.mrmicky.fastparticle.FastParticle;
-import fr.mrmicky.fastparticle.ParticleType;
+import com.hakan.core.HCore;
import org.bukkit.Color;
import org.bukkit.Location;
import org.bukkit.entity.Player;
import org.bukkit.scheduler.BukkitTask;
+import xyz.xenondevs.particle.ParticleBuilder;
+import xyz.xenondevs.particle.ParticleEffect;
+import xyz.xenondevs.particle.data.color.RegularColor;
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
@@ -20,19 +22,24 @@ public class glyphUtil
public static BukkitTask task = null;
public static void sendglyphs(Player p, File file, Location loc) {
- BufferedImage image = null;
try {
- image = ImageIO.read(file);
- }
- catch (final IOException e) {
- e.printStackTrace();
- }
- ImageParticles particles = new ImageParticles(image, 1);
- particles.setAnchor(50, 10);
- particles.setDisplayRatio(0.1);
- Map particle = particles.getParticles(loc, loc.getPitch(), 180.0);
- for (Location spot : particle.keySet()) {
- FastParticle.spawnParticle(p.getWorld(), ParticleType.REDSTONE, spot, 1, particle.get(spot));
+ BufferedImage image = null;
+ try {
+ image = ImageIO.read(file);
+ } catch (final IOException e) {
+ e.printStackTrace();
+ }
+ ImageParticles particles = new ImageParticles(image, 1);
+ particles.setAnchor(50, 10);
+ particles.setDisplayRatio(0.1);
+ Map particle = particles.getParticles(loc, loc.getPitch(), 180.0f);
+ for (Location spot : particle.keySet()) {
+ HCore.syncScheduler().run(() -> new ParticleBuilder(ParticleEffect.REDSTONE, spot)
+ .setParticleData(new RegularColor(particle.get(spot).getRed(), particle.get(spot).getGreen(), particle.get(spot).getBlue()))
+ .display());
+ }
+ }catch (Exception exception){
+
}
}
diff --git a/src/main/java/me/defender/cosmetics/api/util/StartupUtils.java b/src/main/java/me/defender/cosmetics/api/util/StartupUtils.java
index 10838feb..c0fff05b 100644
--- a/src/main/java/me/defender/cosmetics/api/util/StartupUtils.java
+++ b/src/main/java/me/defender/cosmetics/api/util/StartupUtils.java
@@ -142,7 +142,7 @@ public static void downloadGlyphs() {
tempFile.delete();
}
String[] filesInFolder = folder.list();
- if (filesInFolder != null && filesInFolder.length != 0) {
+ if (filesInFolder != null && filesInFolder.length == 0) {
return;
}
JavaPlugin plugin = Utility.plugin();
diff --git a/src/main/java/me/defender/cosmetics/listener/PlayerLeaveListener.java b/src/main/java/me/defender/cosmetics/listener/PlayerLeaveListener.java
index d770d85f..ddff8bfe 100644
--- a/src/main/java/me/defender/cosmetics/listener/PlayerLeaveListener.java
+++ b/src/main/java/me/defender/cosmetics/listener/PlayerLeaveListener.java
@@ -1,5 +1,6 @@
package me.defender.cosmetics.listener;
+import com.hakan.core.HCore;
import me.defender.cosmetics.api.BwcAPI;
import me.defender.cosmetics.api.util.Utility;
import org.bukkit.event.EventHandler;
@@ -12,9 +13,12 @@ public class PlayerLeaveListener implements Listener {
public void onLeave(PlayerQuitEvent e){
BwcAPI api = new BwcAPI();
// Saving for SQLite will be on shutdown.
- if(api.isMySQL()) {
- Utility.playerDataList.get(e.getPlayer().getUniqueId()).save();
- Utility.playerOwnedDataList.get(e.getPlayer().getUniqueId()).save();
+ if(api.isMySQL() && Utility.playerDataList.containsKey(e.getPlayer().getUniqueId())) {
+ HCore.asyncScheduler().run(() -> Utility.playerDataList.get(e.getPlayer().getUniqueId()).save());
+ // Didn't use && for playerOwnedData because it's okay for it to be null, I guess...
+ if(Utility.playerOwnedDataList.containsKey(e.getPlayer().getUniqueId())) {
+ HCore.asyncScheduler().run(() -> Utility.playerOwnedDataList.get(e.getPlayer().getUniqueId()).save());
+ }
}
}
}