Package com.destroystokyo.paper
Class ParticleBuilder
java.lang.Object
com.destroystokyo.paper.ParticleBuilder
Helps prepare a particle to be sent to players.
Usage of the builder is preferred over the super long
World.spawnParticle(Particle, Location, int, double, double, double, double, Object)
API-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionSends this particle to all players in the world.color
(int r, int g, int b) Sets the particle Color.Sets the particle Color.Sets the particle Color and size.int
count()
count
(int count) Sets the number of particles to spawn<T> T
data()
Gets the particle custom data.data
(T data) Sets the particle custom data.double
extra()
Gets the Particle extra data.extra
(double extra) Sets the particle extra data.boolean
force()
force
(boolean force) Sets whether the particle is forcefully shown to the player.boolean
Example use: builder.receivers(16); if (builder.hasReceivers()) { sendParticleAsync(builder); }location()
Sets the location of where to spawn the particleSets the location of where to spawn the particleoffset
(double offsetX, double offsetY, double offsetZ) Sets the particle offset.double
offsetX()
Particle offset X.double
offsetY()
Particle offset Y.double
offsetZ()
Particle offset Z.particle()
Changes what particle will be sentreceivers
(int radius) Selects all players within a cuboid selection around the particle location, within the specified bounding box.receivers
(int radius, boolean byDistance) Selects all players within the specified radius around the particle location.receivers
(int xzRadius, int yRadius) Selects all players within a cuboid selection around the particle location, within the specified bounding box.receivers
(int xzRadius, int yRadius, boolean byDistance) Selects all players within the specified radius around the particle location.receivers
(int xRadius, int yRadius, int zRadius) Selects all players within a cuboid selection around the particle location, within the specified bounding box.receivers
(@Nullable Collection<Player> receivers) source()
Sets the source of this particle for visibility concerns (Vanish API)spawn()
Sends the particle to all receiving players (or all).
-
Constructor Details
-
ParticleBuilder
-
-
Method Details
-
spawn
Sends the particle to all receiving players (or all). This method is safe to use Asynchronously- Returns:
- a reference to this object.
-
particle
- Returns:
- The particle going to be sent
-
particle
Changes what particle will be sent- Parameters:
particle
- The particle- Returns:
- a reference to this object.
-
receivers
- Returns:
- List of players who will receive the particle, or null for all in world
-
hasReceivers
public boolean hasReceivers()Example use: builder.receivers(16); if (builder.hasReceivers()) { sendParticleAsync(builder); }- Returns:
- If this particle is going to be sent to someone
-
allPlayers
Sends this particle to all players in the world. This is rather silly and you should likely not be doing this. Just be a logical person and use receivers by radius or collection.- Returns:
- a reference to this object.
-
receivers
- Parameters:
receivers
- List of players to receive this particle, or null for all players in the world- Returns:
- a reference to this object.
-
receivers
@NotNull public @NotNull ParticleBuilder receivers(@Nullable @Nullable Collection<Player> receivers) - Parameters:
receivers
- List of players to receive this particle, or null for all players in the world- Returns:
- a reference to this object.
-
receivers
- Parameters:
receivers
- List of players to be receive this particle, or null for all players in the world- Returns:
- a reference to this object.
-
receivers
Selects all players within a cuboid selection around the particle location, within the specified bounding box. If you want a more spherical check, seereceivers(int, boolean)
- Parameters:
radius
- amount to add on all axis- Returns:
- a reference to this object.
-
receivers
Selects all players within the specified radius around the particle location. If byDistance is false, behavior uses cuboid selection the same asreceivers(int, int)
If byDistance is true, radius is tested by distance in a spherical shape- Parameters:
radius
- amount to add on each axisbyDistance
- true to use a spherical radius, false to use a cuboid- Returns:
- a reference to this object.
-
receivers
Selects all players within a cuboid selection around the particle location, within the specified bounding box. Allows specifying a different Y size than X and Z If you want a more cylinder check, seereceivers(int, int, boolean)
If you want a more spherical check, seereceivers(int, boolean)
- Parameters:
xzRadius
- amount to add on the x/z axisyRadius
- amount to add on the y axis- Returns:
- a reference to this object.
-
receivers
Selects all players within the specified radius around the particle location. If byDistance is false, behavior uses cuboid selection the same asreceivers(int, int)
If byDistance is true, radius is tested by distance on the y plane and on the x/z plane, in a cylinder shape.- Parameters:
xzRadius
- amount to add on the x/z axisyRadius
- amount to add on the y axisbyDistance
- true to use a cylinder shape, false to use cuboid- Returns:
- a reference to this object.
-
receivers
Selects all players within a cuboid selection around the particle location, within the specified bounding box. If you want a more cylinder check, seereceivers(int, int, boolean)
If you want a more spherical check, seereceivers(int, boolean)
- Parameters:
xRadius
- amount to add on the x axisyRadius
- amount to add on the y axiszRadius
- amount to add on the z axis- Returns:
- a reference to this object.
-
source
- Returns:
- The player considered the source of this particle (for Visibility concerns), or null
-
source
Sets the source of this particle for visibility concerns (Vanish API)- Parameters:
source
- The player who is considered the source- Returns:
- a reference to this object.
-
location
- Returns:
- Location of where the particle will spawn
-
location
Sets the location of where to spawn the particle- Parameters:
location
- The location of the particle- Returns:
- a reference to this object.
-
location
@NotNull public @NotNull ParticleBuilder location(@NotNull @NotNull World world, double x, double y, double z) Sets the location of where to spawn the particle- Parameters:
world
- World to spawn particle inx
- X locationy
- Y locationz
- Z location- Returns:
- a reference to this object.
-
count
public int count()- Returns:
- Number of particles to spawn
-
count
Sets the number of particles to spawn- Parameters:
count
- Number of particles- Returns:
- a reference to this object.
-
offsetX
public double offsetX()Particle offset X. Varies by particle on how this is used- Returns:
- Particle offset X.
-
offsetY
public double offsetY()Particle offset Y. Varies by particle on how this is used- Returns:
- Particle offset Y.
-
offsetZ
public double offsetZ()Particle offset Z. Varies by particle on how this is used- Returns:
- Particle offset Z.
-
offset
Sets the particle offset. Varies by particle on how this is used- Parameters:
offsetX
- Particle offset XoffsetY
- Particle offset YoffsetZ
- Particle offset Z- Returns:
- a reference to this object.
-
extra
public double extra()Gets the Particle extra data. Varies by particle on how this is used- Returns:
- the extra particle data
-
extra
Sets the particle extra data. Varies by particle on how this is used- Parameters:
extra
- the extra particle data- Returns:
- a reference to this object.
-
data
Gets the particle custom data. Varies by particle on how this is used- Type Parameters:
T
- The Particle data type- Returns:
- the ParticleData for this particle
-
data
Sets the particle custom data. Varies by particle on how this is used- Type Parameters:
T
- The Particle data type- Parameters:
data
- The new particle data- Returns:
- a reference to this object.
-
force
public boolean force()- Returns:
- whether the particle is forcefully shown to players.
-
force
Sets whether the particle is forcefully shown to the player. If forced, the particle will show faraway, as far as the player's view distance allows. If false, the particle will show according to the client's particle settings.- Parameters:
force
- true to force, false for normal- Returns:
- a reference to this object.
-
color
Sets the particle Color. Only valid for REDSTONE.- Parameters:
color
- the new particle color- Returns:
- a reference to this object.
-
color
Sets the particle Color and size. Only valid for REDSTONE.- Parameters:
color
- the new particle colorsize
- the size of the particle- Returns:
- a reference to this object.
-
color
Sets the particle Color. Only valid for REDSTONE.- Parameters:
r
- red color componentg
- green color componentb
- blue color component- Returns:
- a reference to this object.
-