mirror of
https://github.com/TotalFreedomMC/PlayerParticles.git
synced 2025-07-28 08:22:02 +00:00
81 lines
3 KiB
Java
81 lines
3 KiB
Java
package dev.esophose.playerparticles.styles;
|
|
|
|
import dev.esophose.playerparticles.PlayerParticles;
|
|
import dev.esophose.playerparticles.config.CommentedFileConfiguration;
|
|
import dev.esophose.playerparticles.manager.DataManager;
|
|
import dev.esophose.playerparticles.manager.ParticleManager;
|
|
import dev.esophose.playerparticles.particles.PParticle;
|
|
import dev.esophose.playerparticles.particles.PPlayer;
|
|
import dev.esophose.playerparticles.particles.ParticlePair;
|
|
import java.util.ArrayList;
|
|
import java.util.Collections;
|
|
import java.util.List;
|
|
import org.bukkit.Location;
|
|
import org.bukkit.entity.Player;
|
|
import org.bukkit.event.EventHandler;
|
|
import org.bukkit.event.EventPriority;
|
|
import org.bukkit.event.Listener;
|
|
import org.bukkit.event.block.BlockBreakEvent;
|
|
|
|
public class ParticleStyleBlockBreak extends DefaultParticleStyle implements Listener {
|
|
|
|
private int particleAmount;
|
|
private double particleSpread;
|
|
private double particleSpeed;
|
|
|
|
public ParticleStyleBlockBreak() {
|
|
super("blockbreak", false, false, 0);
|
|
}
|
|
|
|
@Override
|
|
public List<PParticle> getParticles(ParticlePair particle, Location location) {
|
|
List<PParticle> particles = new ArrayList<>();
|
|
|
|
location.add(0.5, 0.5, 0.5); // Center around the block
|
|
|
|
for (int i = 0; i < this.particleAmount; i++)
|
|
particles.add(new PParticle(location, this.particleSpread, this.particleSpread, this.particleSpread, this.particleSpeed));
|
|
|
|
return particles;
|
|
}
|
|
|
|
@Override
|
|
public void updateTimers() {
|
|
|
|
}
|
|
|
|
@Override
|
|
protected List<String> getGuiIconMaterialNames() {
|
|
return Collections.singletonList("IRON_PICKAXE");
|
|
}
|
|
|
|
@Override
|
|
protected void setDefaultSettings(CommentedFileConfiguration config) {
|
|
this.setIfNotExists("particle-amount", 10, "The number of particles to spawn");
|
|
this.setIfNotExists("particle-spread", 0.5, "The distance to spread particles");
|
|
this.setIfNotExists("particle-speed", 0.05, "The speed of the particles");
|
|
}
|
|
|
|
@Override
|
|
protected void loadSettings(CommentedFileConfiguration config) {
|
|
this.particleAmount = config.getInt("particle-amount");
|
|
this.particleSpread = config.getInt("particle-spread");
|
|
this.particleSpeed = config.getDouble("particle-speed");
|
|
}
|
|
|
|
@EventHandler(priority = EventPriority.MONITOR)
|
|
public void onBlockBreak(BlockBreakEvent event) {
|
|
ParticleManager particleManager = PlayerParticles.getInstance().getManager(ParticleManager.class);
|
|
|
|
Player player = event.getPlayer();
|
|
PPlayer pplayer = PlayerParticles.getInstance().getManager(DataManager.class).getPPlayer(player.getUniqueId());
|
|
if (pplayer == null)
|
|
return;
|
|
|
|
for (ParticlePair particle : pplayer.getActiveParticlesForStyle(DefaultStyles.BLOCKBREAK)) {
|
|
Location loc = event.getBlock().getLocation().clone();
|
|
particleManager.displayParticles(player, player.getWorld(), particle, DefaultStyles.BLOCKBREAK.getParticles(particle, loc), false);
|
|
}
|
|
}
|
|
|
|
}
|