Remove MarkerHologram class, add parameter to Hologram constructor

This commit is contained in:
BuildTools 2021-07-04 14:04:55 +08:00
parent 6a2846a9c6
commit 323fcbe114
2 changed files with 29 additions and 128 deletions

View File

@ -20,8 +20,10 @@ import java.util.Set;
public class Hologram implements Viewable { public class Hologram implements Viewable {
private static final float OFFSET_Y = -0.9875f; private static final float OFFSET_Y = -0.9875f;
private static final float MARKER_OFFSET_Y = -0.40625f;
private final Entity entity; private final Entity entity;
private final float yOffset;
private Position position; private Position position;
private Component text; private Component text;
@ -75,45 +77,43 @@ public class Hologram implements Viewable {
* @param autoViewable {@code true}if the hologram should be visible automatically, otherwise {@code false}. * @param autoViewable {@code true}if the hologram should be visible automatically, otherwise {@code false}.
*/ */
public Hologram(Instance instance, Position spawnPosition, Component text, boolean autoViewable) { public Hologram(Instance instance, Position spawnPosition, Component text, boolean autoViewable) {
this(instance, spawnPosition, text, autoViewable, false);
}
/**
* Constructs a new {@link Hologram} with the given parameters.
*
* @param instance The instance where the hologram should be spawned.
* @param spawnPosition The spawn position of this hologram.
* @param text The text of this hologram.
* @param autoViewable {@code true}if the hologram should be visible automatically, otherwise {@code false}.
*/
public Hologram(Instance instance, Position spawnPosition, Component text, boolean autoViewable, boolean marker) {
this.entity = new Entity(EntityType.ARMOR_STAND); this.entity = new Entity(EntityType.ARMOR_STAND);
ArmorStandMeta armorStandMeta = (ArmorStandMeta) entity.getEntityMeta(); ArmorStandMeta armorStandMeta = (ArmorStandMeta) entity.getEntityMeta();
armorStandMeta.setNotifyAboutChanges(false); armorStandMeta.setNotifyAboutChanges(false);
updateDefaultMeta(armorStandMeta); if(marker) {
this.yOffset = MARKER_OFFSET_Y;
armorStandMeta.setNotifyAboutChanges(true); armorStandMeta.setMarker(true);
} else {
this.entity.setInstance(instance, spawnPosition.clone().add(0, getOffsetY(), 0)); this.yOffset = OFFSET_Y;
this.entity.setAutoViewable(autoViewable);
this.position = spawnPosition;
setText(text);
}
/**
* Sets the default {@link ArmorStandMeta} flags for this Hologram,
* subclasses may override this method to modify the metadata.
*
* @param armorStandMeta the meta to update
*/
protected void updateDefaultMeta(ArmorStandMeta armorStandMeta) {
armorStandMeta.setSmall(true); armorStandMeta.setSmall(true);
}
armorStandMeta.setHasNoGravity(true); armorStandMeta.setHasNoGravity(true);
armorStandMeta.setCustomName(Component.empty()); armorStandMeta.setCustomName(Component.empty());
armorStandMeta.setCustomNameVisible(true); armorStandMeta.setCustomNameVisible(true);
armorStandMeta.setInvisible(true); armorStandMeta.setInvisible(true);
}
/** armorStandMeta.setNotifyAboutChanges(true);
* Vertical offset used to center the nametag,
* subclasses may override this method to modify the position this.entity.setInstance(instance, spawnPosition.clone().add(0, this.yOffset, 0));
* this.entity.setAutoViewable(autoViewable);
* @return the vertical offset used to center the nametag
*/ this.position = spawnPosition;
protected float getOffsetY() { setText(text);
return OFFSET_Y;
} }
/** /**
@ -132,7 +132,7 @@ public class Hologram implements Viewable {
*/ */
public void setPosition(Position position) { public void setPosition(Position position) {
checkRemoved(); checkRemoved();
position.add(0, getOffsetY(), 0); position.add(0, this.yOffset, 0);
this.position = position; this.position = position;
this.entity.teleport(position); this.entity.teleport(position);
} }

View File

@ -1,99 +0,0 @@
package net.minestom.server.entity.hologram;
import net.kyori.adventure.text.Component;
import net.minestom.server.Viewable;
import net.minestom.server.chat.JsonMessage;
import net.minestom.server.entity.Entity;
import net.minestom.server.entity.EntityType;
import net.minestom.server.entity.Player;
import net.minestom.server.entity.metadata.other.ArmorStandMeta;
import net.minestom.server.instance.Instance;
import net.minestom.server.utils.Position;
import net.minestom.server.utils.validate.Check;
import org.jetbrains.annotations.NotNull;
/**
* A hologram that sets the marker flag of the Armor Stand, allowing players to place blocks inside of it
*/
public class MarkerHologram extends Hologram {
//Y Offset such that the spawnPosition represents the center of the rendered nametag
private static final float OFFSET_Y = -0.40625f;
/**
* Constructs a new {@link MarkerHologram} with the given parameters.
*
* @param instance The instance where the hologram should be spawned.
* @param spawnPosition The spawn position of this hologram.
* @param text The text of this hologram.
* @param autoViewable {@code true}if the hologram should be visible automatically, otherwise {@code false}.
* @deprecated Use {@link #MarkerHologram(Instance, Position, Component, boolean)}
*/
public MarkerHologram(Instance instance, Position spawnPosition, JsonMessage text, boolean autoViewable) {
super(instance, spawnPosition, text, autoViewable);
}
/**
* Constructs a new {@link MarkerHologram} with the given parameters.
*
* @param instance The instance where the hologram should be spawned.
* @param spawnPosition The spawn position of this hologram.
* @param text The text of this hologram.
* @deprecated Use {@link #MarkerHologram(Instance, Position, Component)}
*/
public MarkerHologram(Instance instance, Position spawnPosition, JsonMessage text) {
super(instance, spawnPosition, text);
}
/**
* Constructs a new {@link MarkerHologram} with the given parameters.
*
* @param instance The instance where the hologram should be spawned.
* @param spawnPosition The spawn position of this hologram.
* @param text The text of this hologram.
*/
public MarkerHologram(Instance instance, Position spawnPosition, Component text) {
super(instance, spawnPosition, text);
}
/**
* Constructs a new {@link MarkerHologram} with the given parameters.
*
* @param instance The instance where the hologram should be spawned.
* @param spawnPosition The spawn position of this hologram.
* @param text The text of this hologram.
* @param autoViewable {@code true}if the hologram should be visible automatically, otherwise {@code false}.
*/
public MarkerHologram(Instance instance, Position spawnPosition, Component text, boolean autoViewable) {
super(instance, spawnPosition, text, autoViewable);
}
/**
* Sets the default {@link ArmorStandMeta} flags for this Hologram,
* subclasses may override this method to modify the metadata.
*
* {@link MarkerHologram}: Set the marker flag to true
*
* @param armorStandMeta the meta to update
*/
@Override
protected void updateDefaultMeta(ArmorStandMeta armorStandMeta) {
super.updateDefaultMeta(armorStandMeta);
armorStandMeta.setMarker(true);
}
/**
* Vertical offset used to center the nametag,
* subclasses may override this method to modify the position
*
* {@link MarkerHologram}: Correct the Y offset for marker Armor Stands
*
* @return
*/
@Override
protected float getOffsetY() {
return OFFSET_Y;
}
}