Merge pull request #338 from Moulberry/master

Changes to Hologram API
This commit is contained in:
TheMode 2021-07-04 08:12:07 +02:00 committed by GitHub
commit 677ec61f74
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 32 additions and 3 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,13 +77,31 @@ 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);
if(marker) {
this.yOffset = MARKER_OFFSET_Y;
armorStandMeta.setMarker(true);
} else {
this.yOffset = OFFSET_Y;
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);
@ -89,7 +109,7 @@ public class Hologram implements Viewable {
armorStandMeta.setNotifyAboutChanges(true); armorStandMeta.setNotifyAboutChanges(true);
this.entity.setInstance(instance, spawnPosition.clone().add(0, OFFSET_Y, 0)); this.entity.setInstance(instance, spawnPosition.clone().add(0, this.yOffset, 0));
this.entity.setAutoViewable(autoViewable); this.entity.setAutoViewable(autoViewable);
this.position = spawnPosition; this.position = spawnPosition;
@ -112,7 +132,7 @@ public class Hologram implements Viewable {
*/ */
public void setPosition(Position position) { public void setPosition(Position position) {
checkRemoved(); checkRemoved();
position.add(0, OFFSET_Y, 0); position.add(0, this.yOffset, 0);
this.position = position; this.position = position;
this.entity.teleport(position); this.entity.teleport(position);
} }

View File

@ -6,6 +6,7 @@ import net.minestom.server.entity.Entity;
import net.minestom.server.entity.EntityType; import net.minestom.server.entity.EntityType;
import net.minestom.server.entity.GameMode; import net.minestom.server.entity.GameMode;
import net.minestom.server.entity.Player; import net.minestom.server.entity.Player;
import net.minestom.server.entity.metadata.other.ArmorStandMeta;
import net.minestom.server.event.EventDispatcher; import net.minestom.server.event.EventDispatcher;
import net.minestom.server.event.player.PlayerBlockInteractEvent; import net.minestom.server.event.player.PlayerBlockInteractEvent;
import net.minestom.server.event.player.PlayerBlockPlaceEvent; import net.minestom.server.event.player.PlayerBlockPlaceEvent;
@ -132,6 +133,14 @@ public class BlockPlacementListener {
entity.getEntityType() == EntityType.ITEM) entity.getEntityType() == EntityType.ITEM)
continue; continue;
// Marker Armor Stands should not prevent block placement
if(entity.getEntityMeta() instanceof ArmorStandMeta) {
ArmorStandMeta armorStandMeta = (ArmorStandMeta) entity.getEntityMeta();
if(armorStandMeta.isMarker()) {
continue;
}
}
intersect = entity.getBoundingBox().intersect(blockPosition); intersect = entity.getBoundingBox().intersect(blockPosition);
if (intersect) if (intersect)
break; break;