mirror of
https://github.com/filoghost/HolographicDisplays.git
synced 2025-01-01 21:57:36 +01:00
Introduce HologramPosition API and refactor implementation
This commit is contained in:
parent
1be79f05b0
commit
14c7ebce69
@ -104,63 +104,71 @@ public interface Hologram {
|
|||||||
double getHeight();
|
double getHeight();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Teleports a hologram to the given location.
|
* Returns the hologram position.
|
||||||
*
|
*
|
||||||
* @param location the new location
|
* @return the hologram position
|
||||||
* @since 1
|
* @since 1
|
||||||
*/
|
*/
|
||||||
void teleport(@NotNull Location location);
|
@NotNull HologramPosition getPosition();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Teleports a hologram to the given location.
|
* Returns the world of the hologram position.
|
||||||
*
|
*
|
||||||
* @param world the world where the hologram should be teleported, use {@link #getWorld()} to teleport it in the same world.
|
* @return the world of the hologram position
|
||||||
|
* @since 1
|
||||||
|
*/
|
||||||
|
@NotNull World getPositionWorld();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the X coordinate of the hologram position.
|
||||||
|
*
|
||||||
|
* @return the X coordinate of the hologram position
|
||||||
|
* @since 1
|
||||||
|
*/
|
||||||
|
double getPositionX();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the Y coordinate of the hologram position.
|
||||||
|
*
|
||||||
|
* @return the Y coordinate of the hologram position
|
||||||
|
* @since 1
|
||||||
|
*/
|
||||||
|
double getPositionY();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the Z coordinate of the hologram position.
|
||||||
|
*
|
||||||
|
* @return the Z coordinate of the hologram position
|
||||||
|
* @since 1
|
||||||
|
*/
|
||||||
|
double getPositionZ();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Moves the hologram to the given position.
|
||||||
|
*
|
||||||
|
* @param position the new position
|
||||||
|
* @since 1
|
||||||
|
*/
|
||||||
|
void setPosition(@NotNull HologramPosition position);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Moves the hologram to the given position.
|
||||||
|
*
|
||||||
|
* @param world the world where the hologram should be moved
|
||||||
* @param x the X coordinate
|
* @param x the X coordinate
|
||||||
* @param y the Y coordinate
|
* @param y the Y coordinate
|
||||||
* @param z the Z coordinate
|
* @param z the Z coordinate
|
||||||
* @since 1
|
* @since 1
|
||||||
*/
|
*/
|
||||||
void teleport(@NotNull World world, double x, double y, double z);
|
void setPosition(@NotNull World world, double x, double y, double z);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the position of the hologram.
|
* Moves the hologram to the given position.
|
||||||
*
|
*
|
||||||
* @return the Location of the hologram
|
* @param location the new position
|
||||||
* @since 1
|
* @since 1
|
||||||
*/
|
*/
|
||||||
@NotNull Location getLocation();
|
void setPosition(@NotNull Location location);
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the world.
|
|
||||||
*
|
|
||||||
* @return the world of the hologram
|
|
||||||
* @since 1
|
|
||||||
*/
|
|
||||||
@NotNull World getWorld();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the X coordinate.
|
|
||||||
*
|
|
||||||
* @return the X coordinate of the hologram
|
|
||||||
* @since 1
|
|
||||||
*/
|
|
||||||
double getX();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the Y coordinate.
|
|
||||||
*
|
|
||||||
* @return the Y coordinate of the hologram
|
|
||||||
* @since 1
|
|
||||||
*/
|
|
||||||
double getY();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the Z coordinate.
|
|
||||||
*
|
|
||||||
* @return the Z coordinate of the hologram
|
|
||||||
* @since 1
|
|
||||||
*/
|
|
||||||
double getZ();
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the {@link VisibilitySettings} of this hologram.
|
* Returns the {@link VisibilitySettings} of this hologram.
|
||||||
|
@ -0,0 +1,53 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) filoghost and contributors
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
*/
|
||||||
|
package me.filoghost.holographicdisplays.api.hologram;
|
||||||
|
|
||||||
|
import me.filoghost.holographicdisplays.api.internal.HolographicDisplaysAPIProvider;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.World;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
public interface HologramPosition {
|
||||||
|
|
||||||
|
static @NotNull HologramPosition create(@NotNull World world, double x, double y, double z) {
|
||||||
|
return HolographicDisplaysAPIProvider.getImplementation().createHologramPosition(world, x, y, z);
|
||||||
|
}
|
||||||
|
|
||||||
|
static @NotNull HologramPosition fromLocation(@NotNull Location location) {
|
||||||
|
return HolographicDisplaysAPIProvider.getImplementation().createHologramPosition(location);
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull World getWorld();
|
||||||
|
|
||||||
|
void setWorld(@NotNull World world);
|
||||||
|
|
||||||
|
double getX();
|
||||||
|
|
||||||
|
void setX(double x);
|
||||||
|
|
||||||
|
double getY();
|
||||||
|
|
||||||
|
void setY(double y);
|
||||||
|
|
||||||
|
double getZ();
|
||||||
|
|
||||||
|
void setZ(double z);
|
||||||
|
|
||||||
|
void add(double x, double y, double z);
|
||||||
|
|
||||||
|
int getBlockX();
|
||||||
|
|
||||||
|
int getBlockY();
|
||||||
|
|
||||||
|
int getBlockZ();
|
||||||
|
|
||||||
|
double distance(@NotNull Location location);
|
||||||
|
|
||||||
|
double distanceSquared(@NotNull Location location);
|
||||||
|
|
||||||
|
@NotNull Location toLocation();
|
||||||
|
|
||||||
|
}
|
@ -6,6 +6,9 @@
|
|||||||
package me.filoghost.holographicdisplays.api.internal;
|
package me.filoghost.holographicdisplays.api.internal;
|
||||||
|
|
||||||
import me.filoghost.holographicdisplays.api.HolographicDisplaysAPI;
|
import me.filoghost.holographicdisplays.api.HolographicDisplaysAPI;
|
||||||
|
import me.filoghost.holographicdisplays.api.hologram.HologramPosition;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.World;
|
||||||
import org.bukkit.plugin.Plugin;
|
import org.bukkit.plugin.Plugin;
|
||||||
import org.jetbrains.annotations.ApiStatus.Internal;
|
import org.jetbrains.annotations.ApiStatus.Internal;
|
||||||
|
|
||||||
@ -30,4 +33,8 @@ public abstract class HolographicDisplaysAPIProvider {
|
|||||||
|
|
||||||
public abstract HolographicDisplaysAPI getHolographicDisplaysAPI(Plugin plugin);
|
public abstract HolographicDisplaysAPI getHolographicDisplaysAPI(Plugin plugin);
|
||||||
|
|
||||||
|
public abstract HologramPosition createHologramPosition(World world, double x, double y, double z);
|
||||||
|
|
||||||
|
public abstract HologramPosition createHologramPosition(Location location);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -54,7 +54,7 @@ public class PowerUps extends JavaPlugin implements Listener {
|
|||||||
|
|
||||||
icon.setPickupListener((Player player) -> {
|
icon.setPickupListener((Player player) -> {
|
||||||
// Play an effect
|
// Play an effect
|
||||||
player.playEffect(hologram.getLocation(), Effect.MOBSPAWNER_FLAMES, null);
|
player.playEffect(hologram.getPosition().toLocation(), Effect.MOBSPAWNER_FLAMES, null);
|
||||||
|
|
||||||
// 30 seconds of speed II
|
// 30 seconds of speed II
|
||||||
player.addPotionEffect(new PotionEffect(PotionEffectType.SPEED, 30 * 20, 1), true);
|
player.addPotionEffect(new PotionEffect(PotionEffectType.SPEED, 30 * 20, 1), true);
|
||||||
|
@ -10,6 +10,7 @@ import me.filoghost.holographicdisplays.api.HolographicDisplaysAPI;
|
|||||||
import me.filoghost.holographicdisplays.api.hologram.Hologram;
|
import me.filoghost.holographicdisplays.api.hologram.Hologram;
|
||||||
import me.filoghost.holographicdisplays.api.placeholder.PlaceholderReplacer;
|
import me.filoghost.holographicdisplays.api.placeholder.PlaceholderReplacer;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.api.APIHologramManager;
|
import me.filoghost.holographicdisplays.plugin.hologram.api.APIHologramManager;
|
||||||
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.placeholder.registry.PlaceholderRegistry;
|
import me.filoghost.holographicdisplays.plugin.placeholder.registry.PlaceholderRegistry;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
@ -36,7 +37,7 @@ class DefaultHolographicDisplaysAPI implements HolographicDisplaysAPI {
|
|||||||
Preconditions.notNull(source.getWorld(), "source's world");
|
Preconditions.notNull(source.getWorld(), "source's world");
|
||||||
Preconditions.checkState(Bukkit.isPrimaryThread(), "Async hologram creation");
|
Preconditions.checkState(Bukkit.isPrimaryThread(), "Async hologram creation");
|
||||||
|
|
||||||
return apiHologramManager.createHologram(source, plugin);
|
return apiHologramManager.createHologram(new BaseHologramPosition(source), plugin);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -7,10 +7,14 @@ package me.filoghost.holographicdisplays.plugin.api.current;
|
|||||||
|
|
||||||
import me.filoghost.fcommons.Preconditions;
|
import me.filoghost.fcommons.Preconditions;
|
||||||
import me.filoghost.holographicdisplays.api.HolographicDisplaysAPI;
|
import me.filoghost.holographicdisplays.api.HolographicDisplaysAPI;
|
||||||
|
import me.filoghost.holographicdisplays.api.hologram.HologramPosition;
|
||||||
import me.filoghost.holographicdisplays.api.internal.HolographicDisplaysAPIProvider;
|
import me.filoghost.holographicdisplays.api.internal.HolographicDisplaysAPIProvider;
|
||||||
import me.filoghost.holographicdisplays.common.nms.NMSManager;
|
import me.filoghost.holographicdisplays.common.nms.NMSManager;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.api.APIHologramManager;
|
import me.filoghost.holographicdisplays.plugin.hologram.api.APIHologramManager;
|
||||||
|
import me.filoghost.holographicdisplays.plugin.hologram.api.APIHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.placeholder.registry.PlaceholderRegistry;
|
import me.filoghost.holographicdisplays.plugin.placeholder.registry.PlaceholderRegistry;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.World;
|
||||||
import org.bukkit.plugin.Plugin;
|
import org.bukkit.plugin.Plugin;
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
@ -43,4 +47,14 @@ public class DefaultHolographicDisplaysAPIProvider extends HolographicDisplaysAP
|
|||||||
new DefaultHolographicDisplaysAPI(pluginKey, apiHologramManager, placeholderRegistry));
|
new DefaultHolographicDisplaysAPI(pluginKey, apiHologramManager, placeholderRegistry));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public HologramPosition createHologramPosition(World world, double x, double y, double z) {
|
||||||
|
return new APIHologramPosition(world, x, y, z);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public HologramPosition createHologramPosition(Location location) {
|
||||||
|
return new APIHologramPosition(location);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -71,37 +71,37 @@ public class V2HologramAdapter implements Hologram {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void teleport(Location location) {
|
public void teleport(Location location) {
|
||||||
v3Hologram.teleport(location);
|
v3Hologram.setPosition(location);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void teleport(World world, double x, double y, double z) {
|
public void teleport(World world, double x, double y, double z) {
|
||||||
v3Hologram.teleport(world, x, y, z);
|
v3Hologram.setPosition(world, x, y, z);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Location getLocation() {
|
public Location getLocation() {
|
||||||
return v3Hologram.getHologramLocation().toBukkitLocation();
|
return new Location(v3Hologram.getPositionWorld(), v3Hologram.getPositionX(), v3Hologram.getPositionY(), v3Hologram.getPositionZ());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public double getX() {
|
public double getX() {
|
||||||
return v3Hologram.getHologramLocation().getX();
|
return v3Hologram.getPositionX();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public double getY() {
|
public double getY() {
|
||||||
return v3Hologram.getHologramLocation().getY();
|
return v3Hologram.getPositionY();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public double getZ() {
|
public double getZ() {
|
||||||
return v3Hologram.getHologramLocation().getZ();
|
return v3Hologram.getPositionZ();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public World getWorld() {
|
public World getWorld() {
|
||||||
return v3Hologram.getHologramLocation().getWorld();
|
return v3Hologram.getPositionWorld();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -11,6 +11,7 @@ import com.gmail.filoghost.holographicdisplays.api.placeholder.PlaceholderReplac
|
|||||||
import me.filoghost.fcommons.Preconditions;
|
import me.filoghost.fcommons.Preconditions;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.api.APIHologram;
|
import me.filoghost.holographicdisplays.plugin.hologram.api.APIHologram;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.api.APIHologramManager;
|
import me.filoghost.holographicdisplays.plugin.hologram.api.APIHologramManager;
|
||||||
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.placeholder.registry.PlaceholderRegistry;
|
import me.filoghost.holographicdisplays.plugin.placeholder.registry.PlaceholderRegistry;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
@ -40,7 +41,7 @@ public class V2HologramsAPIProvider extends HologramsAPIProvider {
|
|||||||
Preconditions.notNull(source.getWorld(), "source's world");
|
Preconditions.notNull(source.getWorld(), "source's world");
|
||||||
Preconditions.checkState(Bukkit.isPrimaryThread(), "async hologram creation");
|
Preconditions.checkState(Bukkit.isPrimaryThread(), "async hologram creation");
|
||||||
|
|
||||||
return apiHologramManager.createHologram(source, plugin).getV2Adapter();
|
return apiHologramManager.createHologram(new BaseHologramPosition(source), plugin).getV2Adapter();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -13,6 +13,7 @@ import me.filoghost.holographicdisplays.plugin.config.HologramLineParser;
|
|||||||
import me.filoghost.holographicdisplays.plugin.config.HologramLoadException;
|
import me.filoghost.holographicdisplays.plugin.config.HologramLoadException;
|
||||||
import me.filoghost.holographicdisplays.plugin.event.InternalHologramChangeEvent;
|
import me.filoghost.holographicdisplays.plugin.event.InternalHologramChangeEvent;
|
||||||
import me.filoghost.holographicdisplays.plugin.event.InternalHologramChangeEvent.ChangeType;
|
import me.filoghost.holographicdisplays.plugin.event.InternalHologramChangeEvent.ChangeType;
|
||||||
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologram;
|
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologram;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologramLine;
|
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologramLine;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologramManager;
|
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologramManager;
|
||||||
@ -67,8 +68,8 @@ public class InternalHologramEditor {
|
|||||||
return internalHologramManager.getHolograms();
|
return internalHologramManager.getHolograms();
|
||||||
}
|
}
|
||||||
|
|
||||||
public InternalHologram create(Location spawnLocation, String hologramName) {
|
public InternalHologram create(BaseHologramPosition spawnPosition, String hologramName) {
|
||||||
return internalHologramManager.createHologram(spawnLocation, hologramName);
|
return internalHologramManager.createHologram(spawnPosition, hologramName);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void delete(InternalHologram hologram) {
|
public void delete(InternalHologram hologram) {
|
||||||
|
@ -12,9 +12,8 @@ import me.filoghost.holographicdisplays.plugin.commands.HologramSubCommand;
|
|||||||
import me.filoghost.holographicdisplays.plugin.commands.InternalHologramEditor;
|
import me.filoghost.holographicdisplays.plugin.commands.InternalHologramEditor;
|
||||||
import me.filoghost.holographicdisplays.plugin.event.InternalHologramChangeEvent.ChangeType;
|
import me.filoghost.holographicdisplays.plugin.event.InternalHologramChangeEvent.ChangeType;
|
||||||
import me.filoghost.holographicdisplays.plugin.format.ColorScheme;
|
import me.filoghost.holographicdisplays.plugin.format.ColorScheme;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.base.HologramLocation;
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologram;
|
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologram;
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
|
|
||||||
public class AlignCommand extends HologramSubCommand {
|
public class AlignCommand extends HologramSubCommand {
|
||||||
@ -37,24 +36,24 @@ public class AlignCommand extends HologramSubCommand {
|
|||||||
|
|
||||||
CommandValidate.check(hologram != referenceHologram, "The holograms must not be the same.");
|
CommandValidate.check(hologram != referenceHologram, "The holograms must not be the same.");
|
||||||
|
|
||||||
HologramLocation referenceLocation = referenceHologram.getHologramLocation();
|
BaseHologramPosition referencePosition = referenceHologram.getBasePosition();
|
||||||
Location newLocation = hologram.getHologramLocation().toBukkitLocation();
|
BaseHologramPosition newPosition = hologram.getBasePosition();
|
||||||
|
|
||||||
String axis = args[0];
|
String axis = args[0];
|
||||||
if (axis.equalsIgnoreCase("x")) {
|
if (axis.equalsIgnoreCase("x")) {
|
||||||
newLocation.setX(referenceLocation.getX());
|
newPosition.setX(referencePosition.getX());
|
||||||
} else if (axis.equalsIgnoreCase("y")) {
|
} else if (axis.equalsIgnoreCase("y")) {
|
||||||
newLocation.setY(referenceLocation.getY());
|
newPosition.setY(referencePosition.getY());
|
||||||
} else if (axis.equalsIgnoreCase("z")) {
|
} else if (axis.equalsIgnoreCase("z")) {
|
||||||
newLocation.setZ(referenceLocation.getZ());
|
newPosition.setZ(referencePosition.getZ());
|
||||||
} else if (axis.equalsIgnoreCase("xz")) {
|
} else if (axis.equalsIgnoreCase("xz")) {
|
||||||
newLocation.setX(referenceLocation.getX());
|
newPosition.setX(referencePosition.getX());
|
||||||
newLocation.setZ(referenceLocation.getZ());
|
newPosition.setZ(referencePosition.getZ());
|
||||||
} else {
|
} else {
|
||||||
throw new CommandException("You must specify either X, Y, Z or XZ, " + axis + " is not a valid axis.");
|
throw new CommandException("You must specify either X, Y, Z or XZ, " + axis + " is not a valid axis.");
|
||||||
}
|
}
|
||||||
|
|
||||||
hologram.teleport(newLocation);
|
hologram.setPosition(newPosition);
|
||||||
hologramEditor.saveChanges(hologram, ChangeType.EDIT_LOCATION);
|
hologramEditor.saveChanges(hologram, ChangeType.EDIT_LOCATION);
|
||||||
|
|
||||||
sender.sendMessage(ColorScheme.PRIMARY + "Hologram \"" + hologram.getName() + "\""
|
sender.sendMessage(ColorScheme.PRIMARY + "Hologram \"" + hologram.getName() + "\""
|
||||||
|
@ -13,10 +13,10 @@ import me.filoghost.holographicdisplays.plugin.commands.HologramSubCommand;
|
|||||||
import me.filoghost.holographicdisplays.plugin.commands.InternalHologramEditor;
|
import me.filoghost.holographicdisplays.plugin.commands.InternalHologramEditor;
|
||||||
import me.filoghost.holographicdisplays.plugin.event.InternalHologramChangeEvent.ChangeType;
|
import me.filoghost.holographicdisplays.plugin.event.InternalHologramChangeEvent.ChangeType;
|
||||||
import me.filoghost.holographicdisplays.plugin.format.ColorScheme;
|
import me.filoghost.holographicdisplays.plugin.format.ColorScheme;
|
||||||
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologram;
|
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologram;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologramLine;
|
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologramLine;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
@ -47,14 +47,14 @@ public class CreateCommand extends HologramSubCommand {
|
|||||||
CommandValidate.check(hologramEditor.getHologram(hologramName) == null,
|
CommandValidate.check(hologramEditor.getHologram(hologramName) == null,
|
||||||
"A hologram with that name already exists.");
|
"A hologram with that name already exists.");
|
||||||
|
|
||||||
Location spawnLocation = player.getLocation();
|
BaseHologramPosition spawnPosition = new BaseHologramPosition(player.getLocation());
|
||||||
boolean moveUp = player.isOnGround();
|
boolean moveUp = player.isOnGround();
|
||||||
|
|
||||||
if (moveUp) {
|
if (moveUp) {
|
||||||
spawnLocation.add(0.0, 1.2, 0.0);
|
spawnPosition.add(0, 1.2, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
InternalHologram hologram = hologramEditor.create(spawnLocation, hologramName);
|
InternalHologram hologram = hologramEditor.create(spawnPosition, hologramName);
|
||||||
InternalHologramLine line;
|
InternalHologramLine line;
|
||||||
|
|
||||||
if (args.length > 1) {
|
if (args.length > 1) {
|
||||||
|
@ -12,7 +12,7 @@ import me.filoghost.holographicdisplays.plugin.commands.HologramSubCommand;
|
|||||||
import me.filoghost.holographicdisplays.plugin.commands.InternalHologramEditor;
|
import me.filoghost.holographicdisplays.plugin.commands.InternalHologramEditor;
|
||||||
import me.filoghost.holographicdisplays.plugin.format.ColorScheme;
|
import me.filoghost.holographicdisplays.plugin.format.ColorScheme;
|
||||||
import me.filoghost.holographicdisplays.plugin.format.DisplayFormat;
|
import me.filoghost.holographicdisplays.plugin.format.DisplayFormat;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.base.HologramLocation;
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologram;
|
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologram;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
|
|
||||||
@ -55,11 +55,11 @@ public class ListCommand extends HologramSubCommand {
|
|||||||
for (int i = fromIndex; i < toIndex; i++) {
|
for (int i = fromIndex; i < toIndex; i++) {
|
||||||
if (i < holograms.size()) {
|
if (i < holograms.size()) {
|
||||||
InternalHologram hologram = holograms.get(i);
|
InternalHologram hologram = holograms.get(i);
|
||||||
HologramLocation location = hologram.getHologramLocation();
|
BaseHologramPosition position = hologram.getBasePosition();
|
||||||
sender.sendMessage(ColorScheme.SECONDARY_DARKER + "- " + ColorScheme.SECONDARY_BOLD + hologram.getName()
|
sender.sendMessage(ColorScheme.SECONDARY_DARKER + "- " + ColorScheme.SECONDARY_BOLD + hologram.getName()
|
||||||
+ " " + ColorScheme.SECONDARY_DARKER + "at"
|
+ " " + ColorScheme.SECONDARY_DARKER + "at"
|
||||||
+ " x: " + location.getBlockX() + ", y: " + location.getBlockY() + ", z: " + location.getBlockZ()
|
+ " x: " + position.getBlockX() + ", y: " + position.getBlockY() + ", z: " + position.getBlockZ()
|
||||||
+ " (lines: " + hologram.getLineCount() + ", world: \"" + location.getWorld().getName() + "\")");
|
+ " (lines: " + hologram.getLineCount() + ", world: \"" + position.getWorld().getName() + "\")");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@ public class MovehereCommand extends HologramSubCommand {
|
|||||||
Player player = CommandValidate.getPlayerSender(sender);
|
Player player = CommandValidate.getPlayerSender(sender);
|
||||||
InternalHologram hologram = hologramEditor.getHologram(args[0]);
|
InternalHologram hologram = hologramEditor.getHologram(args[0]);
|
||||||
|
|
||||||
hologram.teleport(player.getLocation());
|
hologram.setPosition(player.getLocation());
|
||||||
hologramEditor.saveChanges(hologram, ChangeType.EDIT_LOCATION);
|
hologramEditor.saveChanges(hologram, ChangeType.EDIT_LOCATION);
|
||||||
|
|
||||||
hologramEditor.teleportLookingDown(player, player.getLocation());
|
hologramEditor.teleportLookingDown(player, player.getLocation());
|
||||||
|
@ -12,7 +12,7 @@ import me.filoghost.holographicdisplays.plugin.commands.HologramSubCommand;
|
|||||||
import me.filoghost.holographicdisplays.plugin.commands.InternalHologramEditor;
|
import me.filoghost.holographicdisplays.plugin.commands.InternalHologramEditor;
|
||||||
import me.filoghost.holographicdisplays.plugin.format.ColorScheme;
|
import me.filoghost.holographicdisplays.plugin.format.ColorScheme;
|
||||||
import me.filoghost.holographicdisplays.plugin.format.DisplayFormat;
|
import me.filoghost.holographicdisplays.plugin.format.DisplayFormat;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.base.HologramLocation;
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologram;
|
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologram;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
@ -44,8 +44,8 @@ public class NearCommand extends HologramSubCommand {
|
|||||||
List<InternalHologram> nearHolograms = new ArrayList<>();
|
List<InternalHologram> nearHolograms = new ArrayList<>();
|
||||||
|
|
||||||
for (InternalHologram hologram : hologramEditor.getHolograms()) {
|
for (InternalHologram hologram : hologramEditor.getHolograms()) {
|
||||||
HologramLocation location = hologram.getHologramLocation();
|
BaseHologramPosition position = hologram.getBasePosition();
|
||||||
if (location.getWorld().equals(world) && location.distance(player.getLocation()) <= radius) {
|
if (position.getWorld().equals(world) && position.distance(player.getLocation()) <= radius) {
|
||||||
nearHolograms.add(hologram);
|
nearHolograms.add(hologram);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -54,10 +54,10 @@ public class NearCommand extends HologramSubCommand {
|
|||||||
|
|
||||||
DisplayFormat.sendTitle(player, "Near holograms");
|
DisplayFormat.sendTitle(player, "Near holograms");
|
||||||
for (InternalHologram nearHologram : nearHolograms) {
|
for (InternalHologram nearHologram : nearHolograms) {
|
||||||
HologramLocation location = nearHologram.getHologramLocation();
|
BaseHologramPosition position = nearHologram.getBasePosition();
|
||||||
player.sendMessage(ColorScheme.SECONDARY_DARKER + "- "
|
player.sendMessage(ColorScheme.SECONDARY_DARKER + "- "
|
||||||
+ ColorScheme.SECONDARY_BOLD + nearHologram.getName() + " " + ColorScheme.SECONDARY_DARKER + "at"
|
+ ColorScheme.SECONDARY_BOLD + nearHologram.getName() + " " + ColorScheme.SECONDARY_DARKER + "at"
|
||||||
+ " x: " + location.getBlockX() + ", y: " + location.getBlockY() + ", z: " + location.getBlockZ()
|
+ " x: " + position.getBlockX() + ", y: " + position.getBlockY() + ", z: " + position.getBlockZ()
|
||||||
+ " (lines: " + nearHologram.getLineCount() + ")");
|
+ " (lines: " + nearHologram.getLineCount() + ")");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -34,7 +34,7 @@ public class TeleportCommand extends HologramSubCommand {
|
|||||||
Player player = CommandValidate.getPlayerSender(sender);
|
Player player = CommandValidate.getPlayerSender(sender);
|
||||||
InternalHologram hologram = hologramEditor.getHologram(args[0]);
|
InternalHologram hologram = hologramEditor.getHologram(args[0]);
|
||||||
|
|
||||||
hologramEditor.teleportLookingDown(player, hologram.getHologramLocation().toBukkitLocation());
|
hologramEditor.teleportLookingDown(player, hologram.getBasePosition().toLocation());
|
||||||
player.sendMessage(ColorScheme.PRIMARY + "You were teleported to the hologram named '" + hologram.getName() + "'.");
|
player.sendMessage(ColorScheme.PRIMARY + "You were teleported to the hologram named '" + hologram.getName() + "'.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,12 +7,11 @@ package me.filoghost.holographicdisplays.plugin.config;
|
|||||||
|
|
||||||
import me.filoghost.fcommons.Strings;
|
import me.filoghost.fcommons.Strings;
|
||||||
import me.filoghost.fcommons.config.ConfigSection;
|
import me.filoghost.fcommons.config.ConfigSection;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.base.HologramLocation;
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologram;
|
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologram;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologramLine;
|
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologramLine;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologramManager;
|
import me.filoghost.holographicdisplays.plugin.hologram.internal.InternalHologramManager;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
|
|
||||||
import java.text.DecimalFormat;
|
import java.text.DecimalFormat;
|
||||||
@ -23,17 +22,17 @@ import java.util.Locale;
|
|||||||
|
|
||||||
public class HologramConfig {
|
public class HologramConfig {
|
||||||
|
|
||||||
private static final DecimalFormat LOCATION_NUMBER_FORMAT
|
private static final DecimalFormat POSITION_NUMBER_FORMAT
|
||||||
= new DecimalFormat("0.000", DecimalFormatSymbols.getInstance(Locale.ROOT));
|
= new DecimalFormat("0.000", DecimalFormatSymbols.getInstance(Locale.ROOT));
|
||||||
|
|
||||||
private final String name;
|
private final String name;
|
||||||
private final List<String> serializedLines;
|
private final List<String> serializedLines;
|
||||||
private final String serializedLocation;
|
private final String serializedPosition;
|
||||||
|
|
||||||
public HologramConfig(String name, ConfigSection configSection) {
|
public HologramConfig(String name, ConfigSection configSection) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
this.serializedLines = configSection.getStringList("lines");
|
this.serializedLines = configSection.getStringList("lines");
|
||||||
this.serializedLocation = configSection.getString("location");
|
this.serializedPosition = configSection.getString("location");
|
||||||
}
|
}
|
||||||
|
|
||||||
public HologramConfig(InternalHologram hologram) {
|
public HologramConfig(InternalHologram hologram) {
|
||||||
@ -43,13 +42,13 @@ public class HologramConfig {
|
|||||||
serializedLines.add(line.getSerializedConfigValue());
|
serializedLines.add(line.getSerializedConfigValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
this.serializedLocation = serializeLocation(hologram.getHologramLocation());
|
this.serializedPosition = serializePosition(hologram.getBasePosition());
|
||||||
}
|
}
|
||||||
|
|
||||||
public ConfigSection toConfigSection() {
|
public ConfigSection toConfigSection() {
|
||||||
ConfigSection configSection = new ConfigSection();
|
ConfigSection configSection = new ConfigSection();
|
||||||
configSection.setStringList("lines", serializedLines);
|
configSection.setStringList("lines", serializedLines);
|
||||||
configSection.setString("location", serializedLocation);
|
configSection.setString("location", serializedPosition);
|
||||||
return configSection;
|
return configSection;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -57,12 +56,12 @@ public class HologramConfig {
|
|||||||
if (serializedLines == null || serializedLines.size() == 0) {
|
if (serializedLines == null || serializedLines.size() == 0) {
|
||||||
throw new HologramLoadException("at least one line is required");
|
throw new HologramLoadException("at least one line is required");
|
||||||
}
|
}
|
||||||
if (serializedLocation == null) {
|
if (serializedPosition == null) {
|
||||||
throw new HologramLoadException("no location set");
|
throw new HologramLoadException("no location set");
|
||||||
}
|
}
|
||||||
|
|
||||||
Location location = deserializeLocation(serializedLocation);
|
BaseHologramPosition position = deserializePosition(serializedPosition);
|
||||||
InternalHologram hologram = internalHologramManager.createHologram(location, name);
|
InternalHologram hologram = internalHologramManager.createHologram(position, name);
|
||||||
List<InternalHologramLine> lines = new ArrayList<>();
|
List<InternalHologramLine> lines = new ArrayList<>();
|
||||||
|
|
||||||
for (String serializedLine : serializedLines) {
|
for (String serializedLine : serializedLines) {
|
||||||
@ -78,15 +77,15 @@ public class HologramConfig {
|
|||||||
return hologram;
|
return hologram;
|
||||||
}
|
}
|
||||||
|
|
||||||
private String serializeLocation(HologramLocation location) {
|
private String serializePosition(BaseHologramPosition position) {
|
||||||
return location.getWorld().getName()
|
return position.getWorld().getName()
|
||||||
+ ", " + LOCATION_NUMBER_FORMAT.format(location.getX())
|
+ ", " + POSITION_NUMBER_FORMAT.format(position.getX())
|
||||||
+ ", " + LOCATION_NUMBER_FORMAT.format(location.getY())
|
+ ", " + POSITION_NUMBER_FORMAT.format(position.getY())
|
||||||
+ ", " + LOCATION_NUMBER_FORMAT.format(location.getZ());
|
+ ", " + POSITION_NUMBER_FORMAT.format(position.getZ());
|
||||||
}
|
}
|
||||||
|
|
||||||
private Location deserializeLocation(String serializedLocation) throws HologramLoadException {
|
private BaseHologramPosition deserializePosition(String serializedPosition) throws HologramLoadException {
|
||||||
String[] parts = Strings.splitAndTrim(serializedLocation, ",");
|
String[] parts = Strings.splitAndTrim(serializedPosition, ",");
|
||||||
|
|
||||||
if (parts.length != 4) {
|
if (parts.length != 4) {
|
||||||
throw new HologramLoadException("hologram \"" + name + "\" has an invalid location format:"
|
throw new HologramLoadException("hologram \"" + name + "\" has an invalid location format:"
|
||||||
@ -105,7 +104,7 @@ public class HologramConfig {
|
|||||||
+ " was in the world \"" + worldName + "\" but it wasn't loaded");
|
+ " was in the world \"" + worldName + "\" but it wasn't loaded");
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Location(world, x, y, z);
|
return new BaseHologramPosition(world, x, y, z);
|
||||||
|
|
||||||
} catch (NumberFormatException ex) {
|
} catch (NumberFormatException ex) {
|
||||||
throw new HologramLoadException("hologram \"" + name + "\""
|
throw new HologramLoadException("hologram \"" + name + "\""
|
||||||
|
@ -7,12 +7,12 @@ package me.filoghost.holographicdisplays.plugin.hologram.api;
|
|||||||
|
|
||||||
import me.filoghost.fcommons.Preconditions;
|
import me.filoghost.fcommons.Preconditions;
|
||||||
import me.filoghost.holographicdisplays.api.hologram.Hologram;
|
import me.filoghost.holographicdisplays.api.hologram.Hologram;
|
||||||
|
import me.filoghost.holographicdisplays.api.hologram.HologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.api.v2.V2HologramAdapter;
|
import me.filoghost.holographicdisplays.plugin.api.v2.V2HologramAdapter;
|
||||||
import me.filoghost.holographicdisplays.plugin.config.Settings;
|
import me.filoghost.holographicdisplays.plugin.config.Settings;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologram;
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologram;
|
||||||
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.tracking.LineTrackerManager;
|
import me.filoghost.holographicdisplays.plugin.hologram.tracking.LineTrackerManager;
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.World;
|
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.plugin.Plugin;
|
import org.bukkit.plugin.Plugin;
|
||||||
@ -32,11 +32,11 @@ public class APIHologram extends BaseHologram<APIHologramLine> implements Hologr
|
|||||||
private boolean allowPlaceholders;
|
private boolean allowPlaceholders;
|
||||||
|
|
||||||
protected APIHologram(
|
protected APIHologram(
|
||||||
Location location,
|
BaseHologramPosition position,
|
||||||
Plugin plugin,
|
Plugin plugin,
|
||||||
APIHologramManager apiHologramManager,
|
APIHologramManager apiHologramManager,
|
||||||
LineTrackerManager lineTrackerManager) {
|
LineTrackerManager lineTrackerManager) {
|
||||||
super(location, lineTrackerManager);
|
super(position, lineTrackerManager);
|
||||||
Preconditions.notNull(plugin, "plugin");
|
Preconditions.notNull(plugin, "plugin");
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
this.apiHologramManager = apiHologramManager;
|
this.apiHologramManager = apiHologramManager;
|
||||||
@ -135,28 +135,13 @@ public class APIHologram extends BaseHologram<APIHologramLine> implements Hologr
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public @NotNull Location getLocation() {
|
public @NotNull HologramPosition getPosition() {
|
||||||
return getHologramLocation().toBukkitLocation();
|
return new APIHologramPosition(getPositionWorld(), getPositionX(), getPositionY(), getPositionZ());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public @NotNull World getWorld() {
|
public void setPosition(@NotNull HologramPosition position) {
|
||||||
return getHologramLocation().getWorld();
|
super.setPosition(position.getWorld(), position.getX(), position.getY(), position.getZ());
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public double getX() {
|
|
||||||
return getHologramLocation().getX();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public double getY() {
|
|
||||||
return getHologramLocation().getY();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public double getZ() {
|
|
||||||
return getHologramLocation().getZ();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -7,8 +7,8 @@ package me.filoghost.holographicdisplays.plugin.hologram.api;
|
|||||||
|
|
||||||
import me.filoghost.holographicdisplays.api.hologram.Hologram;
|
import me.filoghost.holographicdisplays.api.hologram.Hologram;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramManager;
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramManager;
|
||||||
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.tracking.LineTrackerManager;
|
import me.filoghost.holographicdisplays.plugin.hologram.tracking.LineTrackerManager;
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.plugin.Plugin;
|
import org.bukkit.plugin.Plugin;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@ -24,8 +24,8 @@ public class APIHologramManager extends BaseHologramManager<APIHologram> {
|
|||||||
this.lineTrackerManager = lineTrackerManager;
|
this.lineTrackerManager = lineTrackerManager;
|
||||||
}
|
}
|
||||||
|
|
||||||
public APIHologram createHologram(Location source, Plugin plugin) {
|
public APIHologram createHologram(BaseHologramPosition position, Plugin plugin) {
|
||||||
APIHologram hologram = new APIHologram(source, plugin, this, lineTrackerManager);
|
APIHologram hologram = new APIHologram(position, plugin, this, lineTrackerManager);
|
||||||
super.addHologram(hologram);
|
super.addHologram(hologram);
|
||||||
return hologram;
|
return hologram;
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,23 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) filoghost and contributors
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
*/
|
||||||
|
package me.filoghost.holographicdisplays.plugin.hologram.api;
|
||||||
|
|
||||||
|
import me.filoghost.holographicdisplays.api.hologram.HologramPosition;
|
||||||
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.World;
|
||||||
|
|
||||||
|
public class APIHologramPosition extends BaseHologramPosition implements HologramPosition {
|
||||||
|
|
||||||
|
public APIHologramPosition(World world, double x, double y, double z) {
|
||||||
|
super(world, x, y, z);
|
||||||
|
}
|
||||||
|
|
||||||
|
public APIHologramPosition(Location location) {
|
||||||
|
super(location);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -8,6 +8,8 @@ package me.filoghost.holographicdisplays.plugin.hologram.base;
|
|||||||
import me.filoghost.fcommons.Preconditions;
|
import me.filoghost.fcommons.Preconditions;
|
||||||
import me.filoghost.holographicdisplays.plugin.config.Settings;
|
import me.filoghost.holographicdisplays.plugin.config.Settings;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.tracking.LineTrackerManager;
|
import me.filoghost.holographicdisplays.plugin.hologram.tracking.LineTrackerManager;
|
||||||
|
import me.filoghost.holographicdisplays.plugin.util.CachedBoolean;
|
||||||
|
import org.bukkit.Chunk;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
@ -21,17 +23,20 @@ import java.util.List;
|
|||||||
|
|
||||||
public abstract class BaseHologram<T extends EditableHologramLine> extends BaseHologramComponent {
|
public abstract class BaseHologram<T extends EditableHologramLine> extends BaseHologramComponent {
|
||||||
|
|
||||||
private final HologramLocation location;
|
|
||||||
private final List<T> lines;
|
private final List<T> lines;
|
||||||
private final List<T> unmodifiableLinesView;
|
private final List<T> unmodifiableLinesView;
|
||||||
private final LineTrackerManager lineTrackerManager;
|
private final LineTrackerManager lineTrackerManager;
|
||||||
|
|
||||||
public BaseHologram(Location location, LineTrackerManager lineTrackerManager) {
|
private World world;
|
||||||
Preconditions.notNull(location, "location");
|
private double x, y, z;
|
||||||
this.location = new HologramLocation(location);
|
private int chunkX, chunkZ;
|
||||||
|
private final CachedBoolean isInLoadedChunk = new CachedBoolean(() -> world.isChunkLoaded(chunkX, chunkZ));
|
||||||
|
|
||||||
|
public BaseHologram(BaseHologramPosition position, LineTrackerManager lineTrackerManager) {
|
||||||
this.lines = new ArrayList<>();
|
this.lines = new ArrayList<>();
|
||||||
this.unmodifiableLinesView = Collections.unmodifiableList(lines);
|
this.unmodifiableLinesView = Collections.unmodifiableList(lines);
|
||||||
this.lineTrackerManager = lineTrackerManager;
|
this.lineTrackerManager = lineTrackerManager;
|
||||||
|
setPosition(position.getWorld(), position.getX(), position.getY(), position.getZ());
|
||||||
}
|
}
|
||||||
|
|
||||||
protected abstract boolean isVisibleTo(Player player);
|
protected abstract boolean isVisibleTo(Player player);
|
||||||
@ -123,20 +128,58 @@ public abstract class BaseHologram<T extends EditableHologramLine> extends BaseH
|
|||||||
return lines.size();
|
return lines.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void teleport(@NotNull Location location) {
|
public BaseHologramPosition getBasePosition() {
|
||||||
|
return new BaseHologramPosition(getPositionWorld(), getPositionX(), getPositionY(), getPositionZ());
|
||||||
|
}
|
||||||
|
|
||||||
|
public @NotNull World getPositionWorld() {
|
||||||
|
return world;
|
||||||
|
}
|
||||||
|
|
||||||
|
public double getPositionX() {
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
|
||||||
|
public double getPositionY() {
|
||||||
|
return y;
|
||||||
|
}
|
||||||
|
|
||||||
|
public double getPositionZ() {
|
||||||
|
return z;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPosition(@NotNull BaseHologramPosition position) {
|
||||||
|
Preconditions.notNull(position, "position");
|
||||||
|
setPosition(position.getWorld(), position.getX(), position.getY(), position.getZ());
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPosition(@NotNull Location location) {
|
||||||
|
Preconditions.notNull(location, "location");
|
||||||
|
setPosition(location.getWorld(), location.getX(), location.getY(), location.getZ());
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPosition(@NotNull World world, double x, double y, double z) {
|
||||||
|
Preconditions.notNull(world, "world");
|
||||||
checkNotDeleted();
|
checkNotDeleted();
|
||||||
this.location.set(location);
|
|
||||||
|
this.x = x;
|
||||||
|
this.y = y;
|
||||||
|
this.z = z;
|
||||||
|
|
||||||
|
int chunkX = getChunkCoordinate(x);
|
||||||
|
int chunkZ = getChunkCoordinate(z);
|
||||||
|
if (this.world != world || this.chunkX != chunkX || this.chunkZ != chunkZ) {
|
||||||
|
this.world = world;
|
||||||
|
this.chunkX = chunkX;
|
||||||
|
this.chunkZ = chunkZ;
|
||||||
|
this.isInLoadedChunk.invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
updateLineLocations();
|
updateLineLocations();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void teleport(@NotNull World world, double x, double y, double z) {
|
private int getChunkCoordinate(double positionCoordinate) {
|
||||||
checkNotDeleted();
|
return Location.locToBlock(positionCoordinate) >> 4;
|
||||||
this.location.set(world, x, y, z);
|
|
||||||
updateLineLocations();
|
|
||||||
}
|
|
||||||
|
|
||||||
public HologramLocation getHologramLocation() {
|
|
||||||
return location;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -144,7 +187,7 @@ public abstract class BaseHologram<T extends EditableHologramLine> extends BaseH
|
|||||||
* The second line is below the first, and so on.
|
* The second line is below the first, and so on.
|
||||||
*/
|
*/
|
||||||
private void updateLineLocations() {
|
private void updateLineLocations() {
|
||||||
double currentLineY = location.getY();
|
double currentLineY = y;
|
||||||
|
|
||||||
for (int i = 0; i < lines.size(); i++) {
|
for (int i = 0; i < lines.size(); i++) {
|
||||||
T line = lines.get(i);
|
T line = lines.get(i);
|
||||||
@ -154,13 +197,29 @@ public abstract class BaseHologram<T extends EditableHologramLine> extends BaseH
|
|||||||
currentLineY -= Settings.spaceBetweenLines;
|
currentLineY -= Settings.spaceBetweenLines;
|
||||||
}
|
}
|
||||||
|
|
||||||
line.setLocation(location.getX(), currentLineY, location.getZ());
|
line.setLocation(x, currentLineY, z);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void onChunkLoad(Chunk chunk) {
|
||||||
|
if (world == chunk.getWorld() && chunkX == chunk.getX() && chunkZ == chunk.getZ()) {
|
||||||
|
isInLoadedChunk.set(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void onChunkUnload(Chunk chunk) {
|
||||||
|
if (world == chunk.getWorld() && chunkX == chunk.getX() && chunkZ == chunk.getZ()) {
|
||||||
|
isInLoadedChunk.set(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected boolean isInLoadedChunk() {
|
||||||
|
return isInLoadedChunk.get();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "BaseHologram [location=" + location + ", lines=" + lines + ", deleted=" + isDeleted() + "]";
|
return "Hologram [position=" + getBasePosition() + ", lines=" + lines + ", deleted=" + isDeleted() + "]";
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -57,11 +57,11 @@ public abstract class BaseHologramLine extends BaseHologramComponent implements
|
|||||||
}
|
}
|
||||||
|
|
||||||
public World getWorld() {
|
public World getWorld() {
|
||||||
return hologram.getHologramLocation().getWorld();
|
return hologram.getPositionWorld();
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isInLoadedChunk() {
|
public boolean isInLoadedChunk() {
|
||||||
return hologram.getHologramLocation().isInLoadedChunk();
|
return hologram.isInLoadedChunk();
|
||||||
}
|
}
|
||||||
|
|
||||||
public final boolean isVisibleTo(Player player) {
|
public final boolean isVisibleTo(Player player) {
|
||||||
|
@ -41,13 +41,13 @@ public abstract class BaseHologramManager<H extends BaseHologram<?>> {
|
|||||||
|
|
||||||
public void onChunkLoad(Chunk chunk) {
|
public void onChunkLoad(Chunk chunk) {
|
||||||
for (H hologram : holograms) {
|
for (H hologram : holograms) {
|
||||||
hologram.getHologramLocation().onChunkLoad(chunk);
|
hologram.onChunkLoad(chunk);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onChunkUnload(Chunk chunk) {
|
public void onChunkUnload(Chunk chunk) {
|
||||||
for (H hologram : holograms) {
|
for (H hologram : holograms) {
|
||||||
hologram.getHologramLocation().onChunkUnload(chunk);
|
hologram.onChunkUnload(chunk);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -0,0 +1,112 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) filoghost and contributors
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
*/
|
||||||
|
package me.filoghost.holographicdisplays.plugin.hologram.base;
|
||||||
|
|
||||||
|
import me.filoghost.fcommons.Preconditions;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.World;
|
||||||
|
import org.bukkit.util.NumberConversions;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
public class BaseHologramPosition {
|
||||||
|
|
||||||
|
private World world;
|
||||||
|
private double x, y, z;
|
||||||
|
|
||||||
|
public BaseHologramPosition(World world, double x, double y, double z) {
|
||||||
|
Preconditions.notNull(world, "world");
|
||||||
|
this.world = world;
|
||||||
|
this.x = x;
|
||||||
|
this.y = y;
|
||||||
|
this.z = z;
|
||||||
|
}
|
||||||
|
|
||||||
|
public BaseHologramPosition(Location location) {
|
||||||
|
Preconditions.notNull(location, "location");
|
||||||
|
Preconditions.notNull(location.getWorld(), "location's world");
|
||||||
|
this.world = location.getWorld();
|
||||||
|
this.x = location.getX();
|
||||||
|
this.y = location.getY();
|
||||||
|
this.z = location.getZ();
|
||||||
|
}
|
||||||
|
|
||||||
|
public @NotNull World getWorld() {
|
||||||
|
return world;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setWorld(@NotNull World world) {
|
||||||
|
Preconditions.notNull(world, "world");
|
||||||
|
this.world = world;
|
||||||
|
}
|
||||||
|
|
||||||
|
public double getX() {
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setX(double x) {
|
||||||
|
this.x = x;
|
||||||
|
}
|
||||||
|
|
||||||
|
public double getY() {
|
||||||
|
return y;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setY(double y) {
|
||||||
|
this.y = y;
|
||||||
|
}
|
||||||
|
|
||||||
|
public double getZ() {
|
||||||
|
return z;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setZ(double z) {
|
||||||
|
this.z = z;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void add(double x, double y, double z) {
|
||||||
|
this.x += x;
|
||||||
|
this.y += y;
|
||||||
|
this.z += z;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getBlockX() {
|
||||||
|
return Location.locToBlock(x);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getBlockY() {
|
||||||
|
return Location.locToBlock(y);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getBlockZ() {
|
||||||
|
return Location.locToBlock(z);
|
||||||
|
}
|
||||||
|
|
||||||
|
public double distance(@NotNull Location location) {
|
||||||
|
return Math.sqrt(distanceSquared(location));
|
||||||
|
}
|
||||||
|
|
||||||
|
public double distanceSquared(@NotNull Location location) {
|
||||||
|
Preconditions.notNull(location, "location");
|
||||||
|
return NumberConversions.square(this.x - location.getX())
|
||||||
|
+ NumberConversions.square(this.y - location.getY())
|
||||||
|
+ NumberConversions.square(this.z - location.getZ());
|
||||||
|
}
|
||||||
|
|
||||||
|
public @NotNull Location toLocation() {
|
||||||
|
return new Location(world, x, y, z);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "HologramPosition ["
|
||||||
|
+ "world=" + world
|
||||||
|
+ ", x=" + x
|
||||||
|
+ ", y=" + y
|
||||||
|
+ ", z=" + z
|
||||||
|
+ "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,121 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) filoghost and contributors
|
|
||||||
*
|
|
||||||
* SPDX-License-Identifier: GPL-3.0-or-later
|
|
||||||
*/
|
|
||||||
package me.filoghost.holographicdisplays.plugin.hologram.base;
|
|
||||||
|
|
||||||
import me.filoghost.fcommons.Preconditions;
|
|
||||||
import me.filoghost.holographicdisplays.plugin.util.CachedBoolean;
|
|
||||||
import org.bukkit.Chunk;
|
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.World;
|
|
||||||
import org.bukkit.util.NumberConversions;
|
|
||||||
|
|
||||||
public class HologramLocation {
|
|
||||||
|
|
||||||
private World world;
|
|
||||||
private double x, y, z;
|
|
||||||
private int chunkX, chunkZ;
|
|
||||||
private final CachedBoolean chunkLoaded;
|
|
||||||
|
|
||||||
public HologramLocation(Location location) {
|
|
||||||
this.chunkLoaded = new CachedBoolean(() -> world.isChunkLoaded(chunkX, chunkZ));
|
|
||||||
set(location);
|
|
||||||
}
|
|
||||||
|
|
||||||
public World getWorld() {
|
|
||||||
return world;
|
|
||||||
}
|
|
||||||
|
|
||||||
public double getX() {
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
|
|
||||||
public double getY() {
|
|
||||||
return y;
|
|
||||||
}
|
|
||||||
|
|
||||||
public double getZ() {
|
|
||||||
return z;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getBlockX() {
|
|
||||||
return Location.locToBlock(x);
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getBlockY() {
|
|
||||||
return Location.locToBlock(y);
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getBlockZ() {
|
|
||||||
return Location.locToBlock(z);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void set(Location location) {
|
|
||||||
Preconditions.notNull(location, "location");
|
|
||||||
set(location.getWorld(), location.getX(), location.getY(), location.getZ());
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void set(World world, double x, double y, double z) {
|
|
||||||
Preconditions.notNull(world, "world");
|
|
||||||
|
|
||||||
this.world = world;
|
|
||||||
this.x = x;
|
|
||||||
this.y = y;
|
|
||||||
this.z = z;
|
|
||||||
|
|
||||||
int newChunkX = getChunkCoord(x);
|
|
||||||
int newChunkZ = getChunkCoord(z);
|
|
||||||
if (this.chunkX != newChunkX || this.chunkZ != newChunkZ) {
|
|
||||||
this.chunkX = newChunkX;
|
|
||||||
this.chunkZ = newChunkZ;
|
|
||||||
this.chunkLoaded.invalidate();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private int getChunkCoord(double locationCoord) {
|
|
||||||
return Location.locToBlock(locationCoord) >> 4;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isInLoadedChunk() {
|
|
||||||
return chunkLoaded.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void onChunkLoad(Chunk chunk) {
|
|
||||||
if (world == chunk.getWorld() && chunkX == chunk.getX() && chunkZ == chunk.getZ()) {
|
|
||||||
chunkLoaded.set(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void onChunkUnload(Chunk chunk) {
|
|
||||||
if (world == chunk.getWorld() && chunkX == chunk.getX() && chunkZ == chunk.getZ()) {
|
|
||||||
chunkLoaded.set(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public Location toBukkitLocation() {
|
|
||||||
return new Location(world, x, y, z);
|
|
||||||
}
|
|
||||||
|
|
||||||
public double distance(Location location) {
|
|
||||||
return Math.sqrt(distanceSquared(location));
|
|
||||||
}
|
|
||||||
|
|
||||||
public double distanceSquared(Location location) {
|
|
||||||
return NumberConversions.square(this.x - location.getX())
|
|
||||||
+ NumberConversions.square(this.y - location.getY())
|
|
||||||
+ NumberConversions.square(this.z - location.getZ());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "HologramLocation ["
|
|
||||||
+ "world=" + world
|
|
||||||
+ ", x=" + x
|
|
||||||
+ ", y=" + y
|
|
||||||
+ ", z=" + z
|
|
||||||
+ "]";
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -7,8 +7,8 @@ package me.filoghost.holographicdisplays.plugin.hologram.internal;
|
|||||||
|
|
||||||
import me.filoghost.holographicdisplays.plugin.HolographicDisplays;
|
import me.filoghost.holographicdisplays.plugin.HolographicDisplays;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologram;
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologram;
|
||||||
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.tracking.LineTrackerManager;
|
import me.filoghost.holographicdisplays.plugin.hologram.tracking.LineTrackerManager;
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.plugin.Plugin;
|
import org.bukkit.plugin.Plugin;
|
||||||
@ -17,8 +17,8 @@ public class InternalHologram extends BaseHologram<InternalHologramLine> {
|
|||||||
|
|
||||||
private final String name;
|
private final String name;
|
||||||
|
|
||||||
protected InternalHologram(Location location, String name, LineTrackerManager lineTrackerManager) {
|
protected InternalHologram(BaseHologramPosition position, String name, LineTrackerManager lineTrackerManager) {
|
||||||
super(location, lineTrackerManager);
|
super(position, lineTrackerManager);
|
||||||
this.name = name;
|
this.name = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6,8 +6,8 @@
|
|||||||
package me.filoghost.holographicdisplays.plugin.hologram.internal;
|
package me.filoghost.holographicdisplays.plugin.hologram.internal;
|
||||||
|
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramManager;
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramManager;
|
||||||
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.tracking.LineTrackerManager;
|
import me.filoghost.holographicdisplays.plugin.hologram.tracking.LineTrackerManager;
|
||||||
import org.bukkit.Location;
|
|
||||||
|
|
||||||
public class InternalHologramManager extends BaseHologramManager<InternalHologram> {
|
public class InternalHologramManager extends BaseHologramManager<InternalHologram> {
|
||||||
|
|
||||||
@ -17,8 +17,8 @@ public class InternalHologramManager extends BaseHologramManager<InternalHologra
|
|||||||
this.lineTrackerManager = lineTrackerManager;
|
this.lineTrackerManager = lineTrackerManager;
|
||||||
}
|
}
|
||||||
|
|
||||||
public InternalHologram createHologram(Location source, String name) {
|
public InternalHologram createHologram(BaseHologramPosition position, String name) {
|
||||||
InternalHologram hologram = new InternalHologram(source, name, lineTrackerManager);
|
InternalHologram hologram = new InternalHologram(position, name, lineTrackerManager);
|
||||||
super.addHologram(hologram);
|
super.addHologram(hologram);
|
||||||
return hologram;
|
return hologram;
|
||||||
}
|
}
|
||||||
|
@ -10,10 +10,10 @@ import com.gmail.filoghost.holographicdisplays.api.line.TextLine;
|
|||||||
import me.filoghost.holographicdisplays.api.hologram.ClickListener;
|
import me.filoghost.holographicdisplays.api.hologram.ClickListener;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.api.APIHologram;
|
import me.filoghost.holographicdisplays.plugin.hologram.api.APIHologram;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.api.APIHologramManager;
|
import me.filoghost.holographicdisplays.plugin.hologram.api.APIHologramManager;
|
||||||
|
import me.filoghost.holographicdisplays.plugin.hologram.base.BaseHologramPosition;
|
||||||
import me.filoghost.holographicdisplays.plugin.hologram.api.APITextLine;
|
import me.filoghost.holographicdisplays.plugin.hologram.api.APITextLine;
|
||||||
import me.filoghost.holographicdisplays.plugin.test.Mocks;
|
import me.filoghost.holographicdisplays.plugin.test.Mocks;
|
||||||
import me.filoghost.holographicdisplays.plugin.test.TestAPIHologramManager;
|
import me.filoghost.holographicdisplays.plugin.test.TestAPIHologramManager;
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
@ -26,7 +26,7 @@ class V2TouchableLineAdapterTest {
|
|||||||
APIHologramManager apiHologramManager = new TestAPIHologramManager();
|
APIHologramManager apiHologramManager = new TestAPIHologramManager();
|
||||||
|
|
||||||
APIHologram hologram = apiHologramManager.createHologram(
|
APIHologram hologram = apiHologramManager.createHologram(
|
||||||
new Location(Mocks.WORLD, 0, 0, 0),
|
new BaseHologramPosition(Mocks.WORLD, 0, 0, 0),
|
||||||
Mocks.PLUGIN
|
Mocks.PLUGIN
|
||||||
);
|
);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user