mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-15 21:01:24 +01:00
#890: Add more Sculk API (bloom, shriek, bloom event)
By: Collin <collinjbarber@gmail.com>
This commit is contained in:
parent
32643feee7
commit
6f4bee4eb0
@ -1,7 +1,27 @@
|
||||
package org.bukkit.block;
|
||||
|
||||
import org.bukkit.event.entity.EntityDeathEvent;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
|
||||
/**
|
||||
* Represents a captured state of a sculk catalyst.
|
||||
*/
|
||||
public interface SculkCatalyst extends TileState {
|
||||
|
||||
/**
|
||||
* Causes a new sculk bloom, as if an entity just died around this catalyst.
|
||||
* <p>
|
||||
* Typically, charges should be set to the exp reward of a mob
|
||||
* ({@link EntityDeathEvent#getDroppedExp()}), which is usually
|
||||
* 3-5 for animals, and 5-10 for the average mob (up to 50 for
|
||||
* wither skeletons). Roughly speaking, for each charge, 1 more
|
||||
* sculk block will be placed.
|
||||
* <p>
|
||||
* If <code>charges > 1000</code>, multiple cursors will be spawned in the
|
||||
* block.
|
||||
*
|
||||
* @param block which block to spawn the cursor in
|
||||
* @param charges how much charge to spawn.
|
||||
*/
|
||||
void bloom(@NotNull Block block, int charges);
|
||||
}
|
||||
|
@ -1,5 +1,8 @@
|
||||
package org.bukkit.block;
|
||||
|
||||
import org.bukkit.entity.Player;
|
||||
import org.jetbrains.annotations.Nullable;
|
||||
|
||||
/**
|
||||
* Represents a captured state of a sculk shrieker.
|
||||
*/
|
||||
@ -24,4 +27,11 @@ public interface SculkShrieker extends TileState {
|
||||
* @param level new warning level
|
||||
*/
|
||||
void setWarningLevel(int level);
|
||||
|
||||
/**
|
||||
* Simulates a player causing a vibration.
|
||||
*
|
||||
* @param player the player that "caused" the shriek
|
||||
*/
|
||||
void tryShriek(@Nullable Player player);
|
||||
}
|
||||
|
@ -0,0 +1,88 @@
|
||||
package org.bukkit.event.block;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
import org.bukkit.block.Block;
|
||||
import org.bukkit.block.SculkCatalyst;
|
||||
import org.bukkit.event.Cancellable;
|
||||
import org.bukkit.event.HandlerList;
|
||||
import org.bukkit.event.entity.EntityDeathEvent;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
|
||||
/**
|
||||
* Represents an event triggered when a new cursor is created by a {@link SculkCatalyst}.
|
||||
* <p>
|
||||
* <strong>Cursor Definition:</strong>
|
||||
* A cursor in this context is a dynamic marker or pointer generated by the
|
||||
* SculkCatalyst. It occupies a block and spreads sculk as it moves. It is
|
||||
* similar to entity, but it is not an entity. Cursors are ticked by the
|
||||
* tile entity.
|
||||
* <p>
|
||||
* <strong>Triggers for Cursor Creation:</strong>
|
||||
* <ul>
|
||||
* <li>An entity, when killed and drops experience, within an 8-block radius of a {@link SculkCatalyst}.</li>
|
||||
* <li>An explicit call from a plugin using {@link SculkCatalyst#bloom(Block, int)}.</li>
|
||||
* </ul>
|
||||
*
|
||||
* The result of {@link #getBlock()} is the location that the cursor is spawning at.
|
||||
*/
|
||||
public class SculkBloomEvent extends BlockEvent implements Cancellable {
|
||||
|
||||
private static final HandlerList handlers = new HandlerList();
|
||||
private boolean cancel = false;
|
||||
|
||||
private int charge;
|
||||
|
||||
public SculkBloomEvent(@NotNull Block theBlock, int charge) {
|
||||
super(theBlock);
|
||||
this.charge = charge;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the charge of the cursor, <1000 by default.
|
||||
*
|
||||
* @return the charge of the cursor
|
||||
*/
|
||||
public int getCharge() {
|
||||
return charge;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the charge of the cursor.
|
||||
* <p>
|
||||
* Increasing the charge of a cursor makes the cursor last longer, giving
|
||||
* it more time to spread sculk blocks across a larger range.
|
||||
* <p>
|
||||
* Typically, charges should be set to the exp reward of a mob
|
||||
* ({@link EntityDeathEvent#getDroppedExp()}), which is usually
|
||||
* 3-5 for animals, and 5-10 for the average mob (up to 50 for
|
||||
* wither skeletons). Roughly speaking, for each charge, 1 more
|
||||
* sculk block will be placed.
|
||||
*
|
||||
* @param charge the charge of the cursor.
|
||||
*/
|
||||
public void setCharge(int charge) {
|
||||
Preconditions.checkArgument(charge >= 0 && charge <= 1000, charge + " is not in range [0, 1000]");
|
||||
this.charge = charge;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isCancelled() {
|
||||
return cancel;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setCancelled(boolean cancel) {
|
||||
this.cancel = cancel;
|
||||
}
|
||||
|
||||
@NotNull
|
||||
@Override
|
||||
public HandlerList getHandlers() {
|
||||
return handlers;
|
||||
}
|
||||
|
||||
@NotNull
|
||||
public static HandlerList getHandlerList() {
|
||||
return handlers;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user