All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.minestom.server.Viewable Maven / Gradle / Ivy

There is a newer version: 7320437640
Show newest version
package net.minestom.server;

import net.kyori.adventure.audience.Audience;
import net.minestom.server.adventure.audience.PacketGroupingAudience;
import net.minestom.server.entity.Player;
import net.minestom.server.network.packet.server.SendablePacket;
import net.minestom.server.network.packet.server.ServerPacket;
import net.minestom.server.utils.PacketSendingUtils;
import org.jetbrains.annotations.NotNull;

import java.util.Collection;
import java.util.List;
import java.util.Set;

/**
 * Represents something which can be displayed or hidden to players.
 */
public interface Viewable {

    /**
     * Adds a viewer.
     *
     * @param player the viewer to add
     * @return true if the player has been added, false otherwise (could be because he is already a viewer)
     */
    boolean addViewer(@NotNull Player player);

    /**
     * Removes a viewer.
     *
     * @param player the viewer to remove
     * @return true if the player has been removed, false otherwise (could be because he was not a viewer)
     */
    boolean removeViewer(@NotNull Player player);

    /**
     * Gets all the viewers of this viewable element.
     *
     * @return A Set containing all the element's viewers
     */
    @NotNull Set<@NotNull Player> getViewers();

    /**
     * Gets if a player is seeing this viewable object.
     *
     * @param player the player to check
     * @return true if {@code player} is a viewer, false otherwise
     */
    default boolean isViewer(@NotNull Player player) {
        return getViewers().contains(player);
    }

    /**
     * Sends a packet to all viewers.
     * 

* It is better than looping through the viewers * to send a packet since it is here only serialized once. * * @param packet the packet to send to all viewers */ default void sendPacketToViewers(@NotNull SendablePacket packet) { if (packet instanceof ServerPacket serverPacket) { PacketSendingUtils.sendGroupedPacket(getViewers(), serverPacket); } else { getViewers().forEach(player -> player.sendPacket(packet)); } } default void sendPacketsToViewers(@NotNull Collection packets) { packets.forEach(this::sendPacketToViewers); } default void sendPacketsToViewers(@NotNull SendablePacket... packets) { sendPacketsToViewers(List.of(packets)); } /** * Sends a packet to all viewers and the viewable element if it is a player. *

* If 'this' isn't a player, then only {@link #sendPacketToViewers(SendablePacket)} is called. * * @param packet the packet to send */ default void sendPacketToViewersAndSelf(@NotNull SendablePacket packet) { sendPacketToViewers(packet); } /** * Gets the result of {@link #getViewers()} as an Adventure Audience. * * @return the audience */ default @NotNull Audience getViewersAsAudience() { return PacketGroupingAudience.of(this.getViewers()); } /** * Gets the result of {@link #getViewers()} as an {@link Iterable} of Adventure * {@link Audience}s. * * @return the audiences */ default @NotNull Iterable getViewersAsAudiences() { return this.getViewers(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy