EasterEggHunt #27
41
src/de/steamwar/lobby/otherparticle/WingDesign.java
Normale Datei
41
src/de/steamwar/lobby/otherparticle/WingDesign.java
Normale Datei
@ -0,0 +1,41 @@
|
||||
package de.steamwar.lobby.otherparticle;
|
||||
|
||||
import de.steamwar.lobby.particle.decorator.WingParticle;
|
||||
import lombok.SneakyThrows;
|
||||
import org.bukkit.util.Vector;
|
||||
|
||||
import javax.imageio.ImageIO;
|
||||
import java.awt.*;
|
||||
import java.awt.image.BufferedImage;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
public interface WingDesign {
|
||||
|
||||
@SneakyThrows
|
||||
static Vector[] create(String resource) {
|
||||
List<Vector> vectors = new ArrayList<>();
|
||||
BufferedImage bufferedImage = ImageIO.read(WingParticle.class.getResourceAsStream(resource));
|
||||
for (int x = 0; x < bufferedImage.getWidth(); x++) {
|
||||
for (int y = 0; y < bufferedImage.getHeight(); y++) {
|
||||
int rgb = bufferedImage.getRGB(x, y);
|
||||
if (Color.WHITE.getRGB() != rgb) {
|
||||
vectors.add(new Vector(x - bufferedImage.getWidth() / 2.0, bufferedImage.getHeight() - y - 1.0, 0));
|
||||
}
|
||||
}
|
||||
}
|
||||
return vectors.toArray(new Vector[0]);
|
||||
}
|
||||
|
||||
Vector[] getVectors();
|
||||
|
||||
WingDesign SIMPLE = () -> create("/de/steamwar/lobby/particle/decorator/WingSimple4.png");
|
||||
WingDesign COMPLEX = () -> create("/de/steamwar/lobby/particle/decorator/WingSimple2.png");
|
||||
WingDesign SWORD = () -> create("/de/steamwar/lobby/particle/decorator/WingSword.png");
|
||||
WingDesign SW = () -> create("/de/steamwar/lobby/particle/decorator/WingSW.png");
|
||||
WingDesign WGS = () -> create("/de/steamwar/lobby/particle/decorator/WingWGS.png");
|
||||
WingDesign SWORD_CROSSED = () -> create("/de/steamwar/lobby/particle/decorator/WingSwordCrossed.png");
|
||||
WingDesign MWGL = () -> create("/de/steamwar/lobby/particle/decorator/MWGL.png");
|
||||
|
||||
WingDesign ECLIPSE = () -> create("/de/steamwar/lobby/particle/decorator/ECLIPSE-Logo.png");
|
||||
}
|
36
src/de/steamwar/lobby/otherparticle/elements/Wing.java
Normale Datei
36
src/de/steamwar/lobby/otherparticle/elements/Wing.java
Normale Datei
@ -0,0 +1,36 @@
|
||||
package de.steamwar.lobby.otherparticle.elements;
|
||||
|
||||
import de.steamwar.lobby.otherparticle.ParticleElement;
|
||||
import de.steamwar.lobby.otherparticle.ParticleTickData;
|
||||
import de.steamwar.lobby.otherparticle.WingDesign;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.util.Vector;
|
||||
|
||||
public class Wing extends DelegatingParticleElement {
|
||||
|
||||
private double size;
|
||||
private WingDesign wingDesign;
|
||||
|
||||
public Wing(ParticleElement particleElement, double size, WingDesign wingDesign) {
|
||||
super(particleElement);
|
||||
this.wingDesign = wingDesign;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String attribute() {
|
||||
return "PARTICLE_ATTRIBUTE_WING";
|
||||
}
|
||||
|
||||
@Override
|
||||
public void tick(ParticleTickData particleTickData) {
|
||||
for (Vector dVector : wingDesign.getVectors()) {
|
||||
Vector vector = new Vector(dVector.getX() * size, 0.6 + dVector.getY() * size - (particleTickData.getPlayer().isSneaking() ? 0.5 : 0) , 0.5);
|
||||
vector.rotateAroundY(Math.toRadians(particleTickData.getPlayer().getLocation().getYaw() * -1));
|
||||
vector.setX(-vector.getX());
|
||||
vector.setZ(-vector.getZ());
|
||||
Location location = particleTickData.getPlayer().getLocation().clone().add(vector);
|
||||
ParticleTickData current = particleTickData.withLocation(location);
|
||||
particleElement.tick(current);
|
||||
}
|
||||
}
|
||||
}
|
In neuem Issue referenzieren
Einen Benutzer sperren