2015-08-02 06:58:35 +00:00
|
|
|
package com.projectkorra.projectkorra.airbending;
|
|
|
|
|
2016-02-21 21:01:28 +00:00
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.List;
|
2015-08-02 06:58:35 +00:00
|
|
|
|
|
|
|
import org.bukkit.Location;
|
|
|
|
import org.bukkit.entity.Entity;
|
|
|
|
import org.bukkit.entity.LivingEntity;
|
|
|
|
import org.bukkit.entity.Player;
|
|
|
|
import org.bukkit.potion.PotionEffect;
|
|
|
|
import org.bukkit.potion.PotionEffectType;
|
|
|
|
import org.bukkit.scheduler.BukkitRunnable;
|
|
|
|
|
2016-02-21 21:01:28 +00:00
|
|
|
import com.projectkorra.projectkorra.GeneralMethods;
|
|
|
|
import com.projectkorra.projectkorra.ProjectKorra;
|
|
|
|
import com.projectkorra.projectkorra.ability.AirAbility;
|
1.8.4 (#769)
* Fix OctopusForm (#734)
* Reload changes
* Catapult Fixes
* Catapult Adjustment
* Changes
* OctopusForm fix
* Attribute System + FireBlast example (#735)
* Attribute System + FireBlast example
* Removed PK jar :smiley: :dancer:
* Fixes Chi Descriptions/Instructions, Removes Fire Passive (#737)
* Fixes missing Chi ability descriptions and instructions
https://trello.com/c/3vto7SEn/734-re-add-paralyze-and-rapidpunch-descrip
tions-and-instructions
* Removes FirePassive
Was discussed in CD chat
https://trello.com/c/skKfHiwR/733-convert-firebending-passive-to-the-new
-passive-system
* Change Octoform freezing (#741)
* Reload changes
* Catapult Fixes
* Catapult Adjustment
* Changes
* OctopusForm fix
* Change Octoform Freezing
* Revert "Change Octoform Freezing"
This reverts commit d5745fe3171b0e24682631889322d81f153d73bd.
* Revert "Revert "Change Octoform Freezing""
This reverts commit 9a91730e0fec7c428f619ffca14e4ea467298b37.
* Changed attributes to use plain reflection rather than annotations (#743)
* should fix some issues with octopusform (#742)
when this .remove() is called nothing has happened with this instance, so the old tempblocks/phasechange never actually get removed, and we get nullpointers trying to remove the ones for this instance since they were never even created
* Fixed external elements, subelements and abilities not loading (#745)
Due to plugins that depend on ProjectKorra loading in AFTER pk, when a
BendingPlayer object is created, all the external elements, subelements
or abilities they may have are lost because they are caught in the null
checks.
To work around this, we will continuously loop every second for 30
seconds until the request times out. If any elements/abilities the user
has haven't loaded in, in that time (the side plugin has taken longer
than 30 seconds to load), then it will time out and report it in the
console.
* New Attribute System (#746)
• New Attribute System (WIP)
• Fields should now be marked with @Attribute(Attribute.DAMAGE) or
whatever the relevant attribute is.
• If the Attribute you want is not there, you can provide a string
instead
• At runtime, these Attributes can be changed with
Attributes.modify(ability/element, attribute, modifier)
• Air and Chi have all been marked with @Attribute annotations
• Updated Particlelib - Fixed bug with dragonbreath and endRod particles
being wrong. AND added new 1.11 particles.
* Adding blocks to the world async is not allowed (#744)
* Wip (#748)
* Fixed *abilitis* typo in Shockwave description
* fixed: WaterSpout not working on PACKED_ICE - cause was looking for nonexistent config boolean, instead of at Properties.Water.IceBlocks list
* Plant block removal and /b add all feature (#749)
* Fixed *abilitis* typo in Shockwave description
* fixed: WaterSpout not working on PACKED_ICE - cause was looking for nonexistent config boolean, instead of at Properties.Water.IceBlocks list
* Fixed: Surge and WaterArms not removing plant block
* New Feature: /bend add all [player]
* fixed passives not enabling on /bend toggle all (#751)
* fixed passives not enabling on /bend toggle all
* Correct/Update comment to act as a TODO note.
* Fix spectator target (#753)
* Don't target spectators
* Remove debug code
- Remove stick debug code that was causing a NullPointerException.
* Change block set order when moving earth (#754)
- Set the source block to air after setting the target block to the new
type. This will eliminate temporary holes, which minimizes major lighting
updates.
* Fix exceptions (#752)
* Fix world check when sending particles
- Check by World reference rather than string name comparison. The following
Location distanceSquared call will throw an exception if the World names
are the same but references aren't.
* Fix several exceptions
- Destroy LavaFlow instance when the Player leaves the World.
- Destroy Torrent instance when the Player leaves the World.
- Fix cooldown exception when Player is null.
* PhaseChange Speed option added (#756)
• Delay option changed to speed
• Fixed EarthArmor breaking when a player is paralyzed.
* FireManip, WaterBubble & 1.12 (#757)
• Added basic FireManipulation. Still needs lots of improving, but
that's for another commit.
• Redone WaterBubble. Now has a click version and an expand/shrink
animation.
• Removed AirBubble
• Updated Spigot to 1.12
• Fixed Octopus NPE
• Fixed EarthArmor remaining after TPs to other worlds
* EarthTunnel - DropLootIfNotRevert (#759)
* .gitignore - Added ignores for IntelliJ
* EarthTunnel: DropLootIfNotRevert - config & functionality
* .gitignore - Added ignores for IntelliJ
* EarthTunnel: DropLootIfNotRevert - config & functionality
* Bug Fixes (Catapult, Illumination, Config) (#760)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* Fix LavaFlow (#755)
Fixed "AllowNaturalFlow"
* Updated to 1.12 with for days (#761)
• Redone the (core) ability load system - The old one broke with the
Guava update in 1.12
• Fixed some WaterBubble floods
• Fixed PhaseChange melting snow super duper fast
• Fixed some other misc bugs
• Added 1.12 Spigot to classpath
* 1.12 Bug Fixes (#762)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* 1.12 fixes
* More 1.12 fixes (#763)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* 1.12 fixes
* More 1.12 Fixes
* Collision fixes, Air sound change,
* Tried Fixing Collisions
Currently the loops in
CollisionInitializer#initializeDefaultCollisions() don't work
* 1.8.4 Fixes (#764)
* Small 1.8.4 fixes
• Fixed selecting snow blocks as a water source not working when they
are more than 3 blocks away
• Fixed DensityShift turning lava into sand when you land softly
• Fixed IceBlast not working on TempBlocks
* Added FireManip particle options to config
Also removed a sneaky debug message
* 1.8.4 Fixes (#765)
* Redone Fire Combos (#766)
* Finalize Fire Combo split (#767)
* 1.8.4 Fixes
* Correct Fire Combos
* Remove unused imports
2017-06-13 07:54:30 +00:00
|
|
|
import com.projectkorra.projectkorra.attribute.Attribute;
|
2016-03-03 01:54:15 +00:00
|
|
|
import com.projectkorra.projectkorra.util.DamageHandler;
|
2015-08-02 06:58:35 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Suffocate
|
|
|
|
*
|
2016-10-24 06:23:02 +00:00
|
|
|
* Suffocate is an air ability that causes entities to be surrounded by a sphere
|
|
|
|
* air that causes constant damage after a configurable delay. Suffocate also
|
|
|
|
* causes Blinding and Slowing affects to entities depending on how the ability
|
|
|
|
* is configured. While in AvatarState this ability can be used on multiple
|
|
|
|
* entities within a large radius. If the user is damaged while performing this
|
2015-08-02 06:58:35 +00:00
|
|
|
* ability then the ability is removed.
|
|
|
|
*/
|
2016-01-13 21:14:34 +00:00
|
|
|
public class Suffocate extends AirAbility {
|
|
|
|
|
|
|
|
public static enum SpiralType {
|
|
|
|
HORIZONTAL1, HORIZONTAL2, VERTICAL1, VERTICAL2, DIAGONAL1, DIAGONAL2
|
|
|
|
};
|
|
|
|
|
|
|
|
private boolean started;
|
|
|
|
private boolean requireConstantAim;
|
|
|
|
private boolean canSuffocateUndead;
|
|
|
|
private int particleCount;
|
1.8.4 (#769)
* Fix OctopusForm (#734)
* Reload changes
* Catapult Fixes
* Catapult Adjustment
* Changes
* OctopusForm fix
* Attribute System + FireBlast example (#735)
* Attribute System + FireBlast example
* Removed PK jar :smiley: :dancer:
* Fixes Chi Descriptions/Instructions, Removes Fire Passive (#737)
* Fixes missing Chi ability descriptions and instructions
https://trello.com/c/3vto7SEn/734-re-add-paralyze-and-rapidpunch-descrip
tions-and-instructions
* Removes FirePassive
Was discussed in CD chat
https://trello.com/c/skKfHiwR/733-convert-firebending-passive-to-the-new
-passive-system
* Change Octoform freezing (#741)
* Reload changes
* Catapult Fixes
* Catapult Adjustment
* Changes
* OctopusForm fix
* Change Octoform Freezing
* Revert "Change Octoform Freezing"
This reverts commit d5745fe3171b0e24682631889322d81f153d73bd.
* Revert "Revert "Change Octoform Freezing""
This reverts commit 9a91730e0fec7c428f619ffca14e4ea467298b37.
* Changed attributes to use plain reflection rather than annotations (#743)
* should fix some issues with octopusform (#742)
when this .remove() is called nothing has happened with this instance, so the old tempblocks/phasechange never actually get removed, and we get nullpointers trying to remove the ones for this instance since they were never even created
* Fixed external elements, subelements and abilities not loading (#745)
Due to plugins that depend on ProjectKorra loading in AFTER pk, when a
BendingPlayer object is created, all the external elements, subelements
or abilities they may have are lost because they are caught in the null
checks.
To work around this, we will continuously loop every second for 30
seconds until the request times out. If any elements/abilities the user
has haven't loaded in, in that time (the side plugin has taken longer
than 30 seconds to load), then it will time out and report it in the
console.
* New Attribute System (#746)
• New Attribute System (WIP)
• Fields should now be marked with @Attribute(Attribute.DAMAGE) or
whatever the relevant attribute is.
• If the Attribute you want is not there, you can provide a string
instead
• At runtime, these Attributes can be changed with
Attributes.modify(ability/element, attribute, modifier)
• Air and Chi have all been marked with @Attribute annotations
• Updated Particlelib - Fixed bug with dragonbreath and endRod particles
being wrong. AND added new 1.11 particles.
* Adding blocks to the world async is not allowed (#744)
* Wip (#748)
* Fixed *abilitis* typo in Shockwave description
* fixed: WaterSpout not working on PACKED_ICE - cause was looking for nonexistent config boolean, instead of at Properties.Water.IceBlocks list
* Plant block removal and /b add all feature (#749)
* Fixed *abilitis* typo in Shockwave description
* fixed: WaterSpout not working on PACKED_ICE - cause was looking for nonexistent config boolean, instead of at Properties.Water.IceBlocks list
* Fixed: Surge and WaterArms not removing plant block
* New Feature: /bend add all [player]
* fixed passives not enabling on /bend toggle all (#751)
* fixed passives not enabling on /bend toggle all
* Correct/Update comment to act as a TODO note.
* Fix spectator target (#753)
* Don't target spectators
* Remove debug code
- Remove stick debug code that was causing a NullPointerException.
* Change block set order when moving earth (#754)
- Set the source block to air after setting the target block to the new
type. This will eliminate temporary holes, which minimizes major lighting
updates.
* Fix exceptions (#752)
* Fix world check when sending particles
- Check by World reference rather than string name comparison. The following
Location distanceSquared call will throw an exception if the World names
are the same but references aren't.
* Fix several exceptions
- Destroy LavaFlow instance when the Player leaves the World.
- Destroy Torrent instance when the Player leaves the World.
- Fix cooldown exception when Player is null.
* PhaseChange Speed option added (#756)
• Delay option changed to speed
• Fixed EarthArmor breaking when a player is paralyzed.
* FireManip, WaterBubble & 1.12 (#757)
• Added basic FireManipulation. Still needs lots of improving, but
that's for another commit.
• Redone WaterBubble. Now has a click version and an expand/shrink
animation.
• Removed AirBubble
• Updated Spigot to 1.12
• Fixed Octopus NPE
• Fixed EarthArmor remaining after TPs to other worlds
* EarthTunnel - DropLootIfNotRevert (#759)
* .gitignore - Added ignores for IntelliJ
* EarthTunnel: DropLootIfNotRevert - config & functionality
* .gitignore - Added ignores for IntelliJ
* EarthTunnel: DropLootIfNotRevert - config & functionality
* Bug Fixes (Catapult, Illumination, Config) (#760)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* Fix LavaFlow (#755)
Fixed "AllowNaturalFlow"
* Updated to 1.12 with for days (#761)
• Redone the (core) ability load system - The old one broke with the
Guava update in 1.12
• Fixed some WaterBubble floods
• Fixed PhaseChange melting snow super duper fast
• Fixed some other misc bugs
• Added 1.12 Spigot to classpath
* 1.12 Bug Fixes (#762)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* 1.12 fixes
* More 1.12 fixes (#763)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* 1.12 fixes
* More 1.12 Fixes
* Collision fixes, Air sound change,
* Tried Fixing Collisions
Currently the loops in
CollisionInitializer#initializeDefaultCollisions() don't work
* 1.8.4 Fixes (#764)
* Small 1.8.4 fixes
• Fixed selecting snow blocks as a water source not working when they
are more than 3 blocks away
• Fixed DensityShift turning lava into sand when you land softly
• Fixed IceBlast not working on TempBlocks
* Added FireManip particle options to config
Also removed a sneaky debug message
* 1.8.4 Fixes (#765)
* Redone Fire Combos (#766)
* Finalize Fire Combo split (#767)
* 1.8.4 Fixes
* Correct Fire Combos
* Remove unused imports
2017-06-13 07:54:30 +00:00
|
|
|
@Attribute(Attribute.CHARGE_DURATION)
|
2016-01-13 21:14:34 +00:00
|
|
|
private long chargeTime;
|
1.8.4 (#769)
* Fix OctopusForm (#734)
* Reload changes
* Catapult Fixes
* Catapult Adjustment
* Changes
* OctopusForm fix
* Attribute System + FireBlast example (#735)
* Attribute System + FireBlast example
* Removed PK jar :smiley: :dancer:
* Fixes Chi Descriptions/Instructions, Removes Fire Passive (#737)
* Fixes missing Chi ability descriptions and instructions
https://trello.com/c/3vto7SEn/734-re-add-paralyze-and-rapidpunch-descrip
tions-and-instructions
* Removes FirePassive
Was discussed in CD chat
https://trello.com/c/skKfHiwR/733-convert-firebending-passive-to-the-new
-passive-system
* Change Octoform freezing (#741)
* Reload changes
* Catapult Fixes
* Catapult Adjustment
* Changes
* OctopusForm fix
* Change Octoform Freezing
* Revert "Change Octoform Freezing"
This reverts commit d5745fe3171b0e24682631889322d81f153d73bd.
* Revert "Revert "Change Octoform Freezing""
This reverts commit 9a91730e0fec7c428f619ffca14e4ea467298b37.
* Changed attributes to use plain reflection rather than annotations (#743)
* should fix some issues with octopusform (#742)
when this .remove() is called nothing has happened with this instance, so the old tempblocks/phasechange never actually get removed, and we get nullpointers trying to remove the ones for this instance since they were never even created
* Fixed external elements, subelements and abilities not loading (#745)
Due to plugins that depend on ProjectKorra loading in AFTER pk, when a
BendingPlayer object is created, all the external elements, subelements
or abilities they may have are lost because they are caught in the null
checks.
To work around this, we will continuously loop every second for 30
seconds until the request times out. If any elements/abilities the user
has haven't loaded in, in that time (the side plugin has taken longer
than 30 seconds to load), then it will time out and report it in the
console.
* New Attribute System (#746)
• New Attribute System (WIP)
• Fields should now be marked with @Attribute(Attribute.DAMAGE) or
whatever the relevant attribute is.
• If the Attribute you want is not there, you can provide a string
instead
• At runtime, these Attributes can be changed with
Attributes.modify(ability/element, attribute, modifier)
• Air and Chi have all been marked with @Attribute annotations
• Updated Particlelib - Fixed bug with dragonbreath and endRod particles
being wrong. AND added new 1.11 particles.
* Adding blocks to the world async is not allowed (#744)
* Wip (#748)
* Fixed *abilitis* typo in Shockwave description
* fixed: WaterSpout not working on PACKED_ICE - cause was looking for nonexistent config boolean, instead of at Properties.Water.IceBlocks list
* Plant block removal and /b add all feature (#749)
* Fixed *abilitis* typo in Shockwave description
* fixed: WaterSpout not working on PACKED_ICE - cause was looking for nonexistent config boolean, instead of at Properties.Water.IceBlocks list
* Fixed: Surge and WaterArms not removing plant block
* New Feature: /bend add all [player]
* fixed passives not enabling on /bend toggle all (#751)
* fixed passives not enabling on /bend toggle all
* Correct/Update comment to act as a TODO note.
* Fix spectator target (#753)
* Don't target spectators
* Remove debug code
- Remove stick debug code that was causing a NullPointerException.
* Change block set order when moving earth (#754)
- Set the source block to air after setting the target block to the new
type. This will eliminate temporary holes, which minimizes major lighting
updates.
* Fix exceptions (#752)
* Fix world check when sending particles
- Check by World reference rather than string name comparison. The following
Location distanceSquared call will throw an exception if the World names
are the same but references aren't.
* Fix several exceptions
- Destroy LavaFlow instance when the Player leaves the World.
- Destroy Torrent instance when the Player leaves the World.
- Fix cooldown exception when Player is null.
* PhaseChange Speed option added (#756)
• Delay option changed to speed
• Fixed EarthArmor breaking when a player is paralyzed.
* FireManip, WaterBubble & 1.12 (#757)
• Added basic FireManipulation. Still needs lots of improving, but
that's for another commit.
• Redone WaterBubble. Now has a click version and an expand/shrink
animation.
• Removed AirBubble
• Updated Spigot to 1.12
• Fixed Octopus NPE
• Fixed EarthArmor remaining after TPs to other worlds
* EarthTunnel - DropLootIfNotRevert (#759)
* .gitignore - Added ignores for IntelliJ
* EarthTunnel: DropLootIfNotRevert - config & functionality
* .gitignore - Added ignores for IntelliJ
* EarthTunnel: DropLootIfNotRevert - config & functionality
* Bug Fixes (Catapult, Illumination, Config) (#760)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* Fix LavaFlow (#755)
Fixed "AllowNaturalFlow"
* Updated to 1.12 with for days (#761)
• Redone the (core) ability load system - The old one broke with the
Guava update in 1.12
• Fixed some WaterBubble floods
• Fixed PhaseChange melting snow super duper fast
• Fixed some other misc bugs
• Added 1.12 Spigot to classpath
* 1.12 Bug Fixes (#762)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* 1.12 fixes
* More 1.12 fixes (#763)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* 1.12 fixes
* More 1.12 Fixes
* Collision fixes, Air sound change,
* Tried Fixing Collisions
Currently the loops in
CollisionInitializer#initializeDefaultCollisions() don't work
* 1.8.4 Fixes (#764)
* Small 1.8.4 fixes
• Fixed selecting snow blocks as a water source not working when they
are more than 3 blocks away
• Fixed DensityShift turning lava into sand when you land softly
• Fixed IceBlast not working on TempBlocks
* Added FireManip particle options to config
Also removed a sneaky debug message
* 1.8.4 Fixes (#765)
* Redone Fire Combos (#766)
* Finalize Fire Combo split (#767)
* 1.8.4 Fixes
* Correct Fire Combos
* Remove unused imports
2017-06-13 07:54:30 +00:00
|
|
|
@Attribute(Attribute.COOLDOWN)
|
2016-01-13 21:14:34 +00:00
|
|
|
private long cooldown;
|
1.8.4 (#769)
* Fix OctopusForm (#734)
* Reload changes
* Catapult Fixes
* Catapult Adjustment
* Changes
* OctopusForm fix
* Attribute System + FireBlast example (#735)
* Attribute System + FireBlast example
* Removed PK jar :smiley: :dancer:
* Fixes Chi Descriptions/Instructions, Removes Fire Passive (#737)
* Fixes missing Chi ability descriptions and instructions
https://trello.com/c/3vto7SEn/734-re-add-paralyze-and-rapidpunch-descrip
tions-and-instructions
* Removes FirePassive
Was discussed in CD chat
https://trello.com/c/skKfHiwR/733-convert-firebending-passive-to-the-new
-passive-system
* Change Octoform freezing (#741)
* Reload changes
* Catapult Fixes
* Catapult Adjustment
* Changes
* OctopusForm fix
* Change Octoform Freezing
* Revert "Change Octoform Freezing"
This reverts commit d5745fe3171b0e24682631889322d81f153d73bd.
* Revert "Revert "Change Octoform Freezing""
This reverts commit 9a91730e0fec7c428f619ffca14e4ea467298b37.
* Changed attributes to use plain reflection rather than annotations (#743)
* should fix some issues with octopusform (#742)
when this .remove() is called nothing has happened with this instance, so the old tempblocks/phasechange never actually get removed, and we get nullpointers trying to remove the ones for this instance since they were never even created
* Fixed external elements, subelements and abilities not loading (#745)
Due to plugins that depend on ProjectKorra loading in AFTER pk, when a
BendingPlayer object is created, all the external elements, subelements
or abilities they may have are lost because they are caught in the null
checks.
To work around this, we will continuously loop every second for 30
seconds until the request times out. If any elements/abilities the user
has haven't loaded in, in that time (the side plugin has taken longer
than 30 seconds to load), then it will time out and report it in the
console.
* New Attribute System (#746)
• New Attribute System (WIP)
• Fields should now be marked with @Attribute(Attribute.DAMAGE) or
whatever the relevant attribute is.
• If the Attribute you want is not there, you can provide a string
instead
• At runtime, these Attributes can be changed with
Attributes.modify(ability/element, attribute, modifier)
• Air and Chi have all been marked with @Attribute annotations
• Updated Particlelib - Fixed bug with dragonbreath and endRod particles
being wrong. AND added new 1.11 particles.
* Adding blocks to the world async is not allowed (#744)
* Wip (#748)
* Fixed *abilitis* typo in Shockwave description
* fixed: WaterSpout not working on PACKED_ICE - cause was looking for nonexistent config boolean, instead of at Properties.Water.IceBlocks list
* Plant block removal and /b add all feature (#749)
* Fixed *abilitis* typo in Shockwave description
* fixed: WaterSpout not working on PACKED_ICE - cause was looking for nonexistent config boolean, instead of at Properties.Water.IceBlocks list
* Fixed: Surge and WaterArms not removing plant block
* New Feature: /bend add all [player]
* fixed passives not enabling on /bend toggle all (#751)
* fixed passives not enabling on /bend toggle all
* Correct/Update comment to act as a TODO note.
* Fix spectator target (#753)
* Don't target spectators
* Remove debug code
- Remove stick debug code that was causing a NullPointerException.
* Change block set order when moving earth (#754)
- Set the source block to air after setting the target block to the new
type. This will eliminate temporary holes, which minimizes major lighting
updates.
* Fix exceptions (#752)
* Fix world check when sending particles
- Check by World reference rather than string name comparison. The following
Location distanceSquared call will throw an exception if the World names
are the same but references aren't.
* Fix several exceptions
- Destroy LavaFlow instance when the Player leaves the World.
- Destroy Torrent instance when the Player leaves the World.
- Fix cooldown exception when Player is null.
* PhaseChange Speed option added (#756)
• Delay option changed to speed
• Fixed EarthArmor breaking when a player is paralyzed.
* FireManip, WaterBubble & 1.12 (#757)
• Added basic FireManipulation. Still needs lots of improving, but
that's for another commit.
• Redone WaterBubble. Now has a click version and an expand/shrink
animation.
• Removed AirBubble
• Updated Spigot to 1.12
• Fixed Octopus NPE
• Fixed EarthArmor remaining after TPs to other worlds
* EarthTunnel - DropLootIfNotRevert (#759)
* .gitignore - Added ignores for IntelliJ
* EarthTunnel: DropLootIfNotRevert - config & functionality
* .gitignore - Added ignores for IntelliJ
* EarthTunnel: DropLootIfNotRevert - config & functionality
* Bug Fixes (Catapult, Illumination, Config) (#760)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* Fix LavaFlow (#755)
Fixed "AllowNaturalFlow"
* Updated to 1.12 with for days (#761)
• Redone the (core) ability load system - The old one broke with the
Guava update in 1.12
• Fixed some WaterBubble floods
• Fixed PhaseChange melting snow super duper fast
• Fixed some other misc bugs
• Added 1.12 Spigot to classpath
* 1.12 Bug Fixes (#762)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* 1.12 fixes
* More 1.12 fixes (#763)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* 1.12 fixes
* More 1.12 Fixes
* Collision fixes, Air sound change,
* Tried Fixing Collisions
Currently the loops in
CollisionInitializer#initializeDefaultCollisions() don't work
* 1.8.4 Fixes (#764)
* Small 1.8.4 fixes
• Fixed selecting snow blocks as a water source not working when they
are more than 3 blocks away
• Fixed DensityShift turning lava into sand when you land softly
• Fixed IceBlast not working on TempBlocks
* Added FireManip particle options to config
Also removed a sneaky debug message
* 1.8.4 Fixes (#765)
* Redone Fire Combos (#766)
* Finalize Fire Combo split (#767)
* 1.8.4 Fixes
* Correct Fire Combos
* Remove unused imports
2017-06-13 07:54:30 +00:00
|
|
|
@Attribute(Attribute.RANGE)
|
2016-01-13 21:14:34 +00:00
|
|
|
private double range;
|
1.8.4 (#769)
* Fix OctopusForm (#734)
* Reload changes
* Catapult Fixes
* Catapult Adjustment
* Changes
* OctopusForm fix
* Attribute System + FireBlast example (#735)
* Attribute System + FireBlast example
* Removed PK jar :smiley: :dancer:
* Fixes Chi Descriptions/Instructions, Removes Fire Passive (#737)
* Fixes missing Chi ability descriptions and instructions
https://trello.com/c/3vto7SEn/734-re-add-paralyze-and-rapidpunch-descrip
tions-and-instructions
* Removes FirePassive
Was discussed in CD chat
https://trello.com/c/skKfHiwR/733-convert-firebending-passive-to-the-new
-passive-system
* Change Octoform freezing (#741)
* Reload changes
* Catapult Fixes
* Catapult Adjustment
* Changes
* OctopusForm fix
* Change Octoform Freezing
* Revert "Change Octoform Freezing"
This reverts commit d5745fe3171b0e24682631889322d81f153d73bd.
* Revert "Revert "Change Octoform Freezing""
This reverts commit 9a91730e0fec7c428f619ffca14e4ea467298b37.
* Changed attributes to use plain reflection rather than annotations (#743)
* should fix some issues with octopusform (#742)
when this .remove() is called nothing has happened with this instance, so the old tempblocks/phasechange never actually get removed, and we get nullpointers trying to remove the ones for this instance since they were never even created
* Fixed external elements, subelements and abilities not loading (#745)
Due to plugins that depend on ProjectKorra loading in AFTER pk, when a
BendingPlayer object is created, all the external elements, subelements
or abilities they may have are lost because they are caught in the null
checks.
To work around this, we will continuously loop every second for 30
seconds until the request times out. If any elements/abilities the user
has haven't loaded in, in that time (the side plugin has taken longer
than 30 seconds to load), then it will time out and report it in the
console.
* New Attribute System (#746)
• New Attribute System (WIP)
• Fields should now be marked with @Attribute(Attribute.DAMAGE) or
whatever the relevant attribute is.
• If the Attribute you want is not there, you can provide a string
instead
• At runtime, these Attributes can be changed with
Attributes.modify(ability/element, attribute, modifier)
• Air and Chi have all been marked with @Attribute annotations
• Updated Particlelib - Fixed bug with dragonbreath and endRod particles
being wrong. AND added new 1.11 particles.
* Adding blocks to the world async is not allowed (#744)
* Wip (#748)
* Fixed *abilitis* typo in Shockwave description
* fixed: WaterSpout not working on PACKED_ICE - cause was looking for nonexistent config boolean, instead of at Properties.Water.IceBlocks list
* Plant block removal and /b add all feature (#749)
* Fixed *abilitis* typo in Shockwave description
* fixed: WaterSpout not working on PACKED_ICE - cause was looking for nonexistent config boolean, instead of at Properties.Water.IceBlocks list
* Fixed: Surge and WaterArms not removing plant block
* New Feature: /bend add all [player]
* fixed passives not enabling on /bend toggle all (#751)
* fixed passives not enabling on /bend toggle all
* Correct/Update comment to act as a TODO note.
* Fix spectator target (#753)
* Don't target spectators
* Remove debug code
- Remove stick debug code that was causing a NullPointerException.
* Change block set order when moving earth (#754)
- Set the source block to air after setting the target block to the new
type. This will eliminate temporary holes, which minimizes major lighting
updates.
* Fix exceptions (#752)
* Fix world check when sending particles
- Check by World reference rather than string name comparison. The following
Location distanceSquared call will throw an exception if the World names
are the same but references aren't.
* Fix several exceptions
- Destroy LavaFlow instance when the Player leaves the World.
- Destroy Torrent instance when the Player leaves the World.
- Fix cooldown exception when Player is null.
* PhaseChange Speed option added (#756)
• Delay option changed to speed
• Fixed EarthArmor breaking when a player is paralyzed.
* FireManip, WaterBubble & 1.12 (#757)
• Added basic FireManipulation. Still needs lots of improving, but
that's for another commit.
• Redone WaterBubble. Now has a click version and an expand/shrink
animation.
• Removed AirBubble
• Updated Spigot to 1.12
• Fixed Octopus NPE
• Fixed EarthArmor remaining after TPs to other worlds
* EarthTunnel - DropLootIfNotRevert (#759)
* .gitignore - Added ignores for IntelliJ
* EarthTunnel: DropLootIfNotRevert - config & functionality
* .gitignore - Added ignores for IntelliJ
* EarthTunnel: DropLootIfNotRevert - config & functionality
* Bug Fixes (Catapult, Illumination, Config) (#760)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* Fix LavaFlow (#755)
Fixed "AllowNaturalFlow"
* Updated to 1.12 with for days (#761)
• Redone the (core) ability load system - The old one broke with the
Guava update in 1.12
• Fixed some WaterBubble floods
• Fixed PhaseChange melting snow super duper fast
• Fixed some other misc bugs
• Added 1.12 Spigot to classpath
* 1.12 Bug Fixes (#762)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* 1.12 fixes
* More 1.12 fixes (#763)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* 1.12 fixes
* More 1.12 Fixes
* Collision fixes, Air sound change,
* Tried Fixing Collisions
Currently the loops in
CollisionInitializer#initializeDefaultCollisions() don't work
* 1.8.4 Fixes (#764)
* Small 1.8.4 fixes
• Fixed selecting snow blocks as a water source not working when they
are more than 3 blocks away
• Fixed DensityShift turning lava into sand when you land softly
• Fixed IceBlast not working on TempBlocks
* Added FireManip particle options to config
Also removed a sneaky debug message
* 1.8.4 Fixes (#765)
* Redone Fire Combos (#766)
* Finalize Fire Combo split (#767)
* 1.8.4 Fixes
* Correct Fire Combos
* Remove unused imports
2017-06-13 07:54:30 +00:00
|
|
|
@Attribute(Attribute.RADIUS)
|
2016-01-13 21:14:34 +00:00
|
|
|
private double radius;
|
1.8.4 (#769)
* Fix OctopusForm (#734)
* Reload changes
* Catapult Fixes
* Catapult Adjustment
* Changes
* OctopusForm fix
* Attribute System + FireBlast example (#735)
* Attribute System + FireBlast example
* Removed PK jar :smiley: :dancer:
* Fixes Chi Descriptions/Instructions, Removes Fire Passive (#737)
* Fixes missing Chi ability descriptions and instructions
https://trello.com/c/3vto7SEn/734-re-add-paralyze-and-rapidpunch-descrip
tions-and-instructions
* Removes FirePassive
Was discussed in CD chat
https://trello.com/c/skKfHiwR/733-convert-firebending-passive-to-the-new
-passive-system
* Change Octoform freezing (#741)
* Reload changes
* Catapult Fixes
* Catapult Adjustment
* Changes
* OctopusForm fix
* Change Octoform Freezing
* Revert "Change Octoform Freezing"
This reverts commit d5745fe3171b0e24682631889322d81f153d73bd.
* Revert "Revert "Change Octoform Freezing""
This reverts commit 9a91730e0fec7c428f619ffca14e4ea467298b37.
* Changed attributes to use plain reflection rather than annotations (#743)
* should fix some issues with octopusform (#742)
when this .remove() is called nothing has happened with this instance, so the old tempblocks/phasechange never actually get removed, and we get nullpointers trying to remove the ones for this instance since they were never even created
* Fixed external elements, subelements and abilities not loading (#745)
Due to plugins that depend on ProjectKorra loading in AFTER pk, when a
BendingPlayer object is created, all the external elements, subelements
or abilities they may have are lost because they are caught in the null
checks.
To work around this, we will continuously loop every second for 30
seconds until the request times out. If any elements/abilities the user
has haven't loaded in, in that time (the side plugin has taken longer
than 30 seconds to load), then it will time out and report it in the
console.
* New Attribute System (#746)
• New Attribute System (WIP)
• Fields should now be marked with @Attribute(Attribute.DAMAGE) or
whatever the relevant attribute is.
• If the Attribute you want is not there, you can provide a string
instead
• At runtime, these Attributes can be changed with
Attributes.modify(ability/element, attribute, modifier)
• Air and Chi have all been marked with @Attribute annotations
• Updated Particlelib - Fixed bug with dragonbreath and endRod particles
being wrong. AND added new 1.11 particles.
* Adding blocks to the world async is not allowed (#744)
* Wip (#748)
* Fixed *abilitis* typo in Shockwave description
* fixed: WaterSpout not working on PACKED_ICE - cause was looking for nonexistent config boolean, instead of at Properties.Water.IceBlocks list
* Plant block removal and /b add all feature (#749)
* Fixed *abilitis* typo in Shockwave description
* fixed: WaterSpout not working on PACKED_ICE - cause was looking for nonexistent config boolean, instead of at Properties.Water.IceBlocks list
* Fixed: Surge and WaterArms not removing plant block
* New Feature: /bend add all [player]
* fixed passives not enabling on /bend toggle all (#751)
* fixed passives not enabling on /bend toggle all
* Correct/Update comment to act as a TODO note.
* Fix spectator target (#753)
* Don't target spectators
* Remove debug code
- Remove stick debug code that was causing a NullPointerException.
* Change block set order when moving earth (#754)
- Set the source block to air after setting the target block to the new
type. This will eliminate temporary holes, which minimizes major lighting
updates.
* Fix exceptions (#752)
* Fix world check when sending particles
- Check by World reference rather than string name comparison. The following
Location distanceSquared call will throw an exception if the World names
are the same but references aren't.
* Fix several exceptions
- Destroy LavaFlow instance when the Player leaves the World.
- Destroy Torrent instance when the Player leaves the World.
- Fix cooldown exception when Player is null.
* PhaseChange Speed option added (#756)
• Delay option changed to speed
• Fixed EarthArmor breaking when a player is paralyzed.
* FireManip, WaterBubble & 1.12 (#757)
• Added basic FireManipulation. Still needs lots of improving, but
that's for another commit.
• Redone WaterBubble. Now has a click version and an expand/shrink
animation.
• Removed AirBubble
• Updated Spigot to 1.12
• Fixed Octopus NPE
• Fixed EarthArmor remaining after TPs to other worlds
* EarthTunnel - DropLootIfNotRevert (#759)
* .gitignore - Added ignores for IntelliJ
* EarthTunnel: DropLootIfNotRevert - config & functionality
* .gitignore - Added ignores for IntelliJ
* EarthTunnel: DropLootIfNotRevert - config & functionality
* Bug Fixes (Catapult, Illumination, Config) (#760)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* Fix LavaFlow (#755)
Fixed "AllowNaturalFlow"
* Updated to 1.12 with for days (#761)
• Redone the (core) ability load system - The old one broke with the
Guava update in 1.12
• Fixed some WaterBubble floods
• Fixed PhaseChange melting snow super duper fast
• Fixed some other misc bugs
• Added 1.12 Spigot to classpath
* 1.12 Bug Fixes (#762)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* 1.12 fixes
* More 1.12 fixes (#763)
* Bug Fixes (Catapult, Illumination, Config)
* Finish Fixing Illumination
* Fix Catapult angle
* Fix Catapult bug
* Angle cancel option Catapult
* Fix Illumination on leaves, Fix water flooding
* Config stuff for Toby
* 1.12 fixes
* More 1.12 Fixes
* Collision fixes, Air sound change,
* Tried Fixing Collisions
Currently the loops in
CollisionInitializer#initializeDefaultCollisions() don't work
* 1.8.4 Fixes (#764)
* Small 1.8.4 fixes
• Fixed selecting snow blocks as a water source not working when they
are more than 3 blocks away
• Fixed DensityShift turning lava into sand when you land softly
• Fixed IceBlast not working on TempBlocks
* Added FireManip particle options to config
Also removed a sneaky debug message
* 1.8.4 Fixes (#765)
* Redone Fire Combos (#766)
* Finalize Fire Combo split (#767)
* 1.8.4 Fixes
* Correct Fire Combos
* Remove unused imports
2017-06-13 07:54:30 +00:00
|
|
|
@Attribute(Attribute.DAMAGE)
|
2016-01-13 21:14:34 +00:00
|
|
|
private double damage;
|
|
|
|
private double damageDelay;
|
|
|
|
private double damageRepeat;
|
|
|
|
private double slow;
|
|
|
|
private double slowRepeat;
|
|
|
|
private double slowDelay;
|
|
|
|
private double constantAimRadius;
|
|
|
|
private double blind;
|
|
|
|
private double blindDelay;
|
|
|
|
private double blindRepeat;
|
|
|
|
private double animationSpeed;
|
2016-02-21 21:01:28 +00:00
|
|
|
private Suffocate ability;
|
2015-08-02 06:58:35 +00:00
|
|
|
private ArrayList<BukkitRunnable> tasks;
|
|
|
|
private ArrayList<LivingEntity> targets;
|
2016-10-24 06:23:02 +00:00
|
|
|
|
2015-08-02 06:58:35 +00:00
|
|
|
public Suffocate(Player player) {
|
2016-01-13 21:14:34 +00:00
|
|
|
super(player);
|
2016-02-21 21:01:28 +00:00
|
|
|
ability = this;
|
2016-01-13 21:14:34 +00:00
|
|
|
if (bPlayer.isOnCooldown(this)) {
|
|
|
|
return;
|
2016-01-16 21:07:14 +00:00
|
|
|
} else if (hasAbility(player, Suffocate.class)) {
|
2015-08-02 06:58:35 +00:00
|
|
|
return;
|
2015-11-11 20:19:45 +00:00
|
|
|
}
|
2015-08-02 06:58:35 +00:00
|
|
|
|
2016-01-13 21:14:34 +00:00
|
|
|
this.started = false;
|
|
|
|
this.requireConstantAim = getConfig().getBoolean("Abilities.Air.Suffocate.RequireConstantAim");
|
|
|
|
this.canSuffocateUndead = getConfig().getBoolean("Abilities.Air.Suffocate.CanBeUsedOnUndeadMobs");
|
|
|
|
this.particleCount = getConfig().getInt("Abilities.Air.Suffocate.AnimationParticleAmount");
|
|
|
|
this.animationSpeed = getConfig().getDouble("Abilities.Air.Suffocate.AnimationSpeed");
|
|
|
|
this.chargeTime = getConfig().getLong("Abilities.Air.Suffocate.ChargeTime");
|
|
|
|
this.cooldown = getConfig().getLong("Abilities.Air.Suffocate.Cooldown");
|
|
|
|
this.range = getConfig().getDouble("Abilities.Air.Suffocate.Range");
|
|
|
|
this.radius = getConfig().getDouble("Abilities.Air.Suffocate.AnimationRadius");
|
|
|
|
this.constantAimRadius = getConfig().getDouble("Abilities.Air.Suffocate.RequireConstantAimRadius");
|
|
|
|
this.damage = getConfig().getDouble("Abilities.Air.Suffocate.Damage");
|
|
|
|
this.damageDelay = getConfig().getDouble("Abilities.Air.Suffocate.DamageInitialDelay");
|
|
|
|
this.damageRepeat = getConfig().getDouble("Abilities.Air.Suffocate.DamageInterval");
|
|
|
|
this.slow = getConfig().getInt("Abilities.Air.Suffocate.SlowPotency");
|
|
|
|
this.slowRepeat = getConfig().getDouble("Abilities.Air.Suffocate.SlowInterval");
|
|
|
|
this.slowDelay = getConfig().getDouble("Abilities.Air.Suffocate.SlowDelay");
|
|
|
|
this.blind = getConfig().getInt("Abilities.Air.Suffocate.BlindPotentcy");
|
|
|
|
this.blindDelay = getConfig().getDouble("Abilities.Air.Suffocate.BlindDelay");
|
|
|
|
this.blindRepeat = getConfig().getDouble("Abilities.Air.Suffocate.BlindInterval");
|
2016-01-15 01:07:59 +00:00
|
|
|
this.targets = new ArrayList<>();
|
|
|
|
this.tasks = new ArrayList<>();
|
2016-01-13 21:14:34 +00:00
|
|
|
|
|
|
|
if (bPlayer.isAvatarState()) {
|
2017-01-07 00:21:25 +00:00
|
|
|
cooldown = getConfig().getLong("Abilities.Avatar.AvatarState.Air.Suffocate.Cooldown");
|
|
|
|
chargeTime = getConfig().getLong("Abilities.Avatar.AvatarState.Air.Suffocate.ChargeTime");
|
|
|
|
damage = getConfig().getDouble("Abilities.Avatar.AvatarState.Air.Suffocate.Damage");
|
|
|
|
range = getConfig().getDouble("Abilities.Avatar.AvatarState.Air.Suffocate.Range");
|
2017-01-16 06:48:20 +00:00
|
|
|
|
2015-08-02 06:58:35 +00:00
|
|
|
}
|
2016-01-13 21:14:34 +00:00
|
|
|
|
|
|
|
if (particleCount < 1) {
|
|
|
|
particleCount = 1;
|
|
|
|
} else if (particleCount > 2) {
|
|
|
|
particleCount = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (bPlayer.isAvatarState()) {
|
|
|
|
for (Entity ent : GeneralMethods.getEntitiesAroundPoint(player.getLocation(), range)) {
|
|
|
|
if (ent instanceof LivingEntity && !ent.equals(player)) {
|
2015-08-02 06:58:35 +00:00
|
|
|
targets.add((LivingEntity) ent);
|
2016-01-05 22:22:00 +00:00
|
|
|
}
|
|
|
|
}
|
2016-01-13 21:14:34 +00:00
|
|
|
} else {
|
2016-01-31 21:02:21 +00:00
|
|
|
//Location location = GeneralMethods.getTargetedLocation(player, 6, getTransparentMaterial());
|
|
|
|
//List<Entity> entities = GeneralMethods.getEntitiesAroundPoint(location, 1.5);
|
|
|
|
List<Entity> entities = new ArrayList<Entity>();
|
|
|
|
for (int i = 0; i < 6; i++) {
|
2017-08-06 07:18:12 +00:00
|
|
|
Location location = GeneralMethods.getTargetedLocation(player, i, getTransparentMaterials());
|
2016-01-31 21:02:21 +00:00
|
|
|
entities = GeneralMethods.getEntitiesAroundPoint(location, 1.7);
|
|
|
|
if (entities.contains(player))
|
|
|
|
entities.remove(player);
|
|
|
|
if (entities != null && !entities.isEmpty() && !entities.contains(player)) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2016-01-15 01:07:59 +00:00
|
|
|
if (entities == null || entities.isEmpty()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
Entity target = entities.get(0);
|
|
|
|
if (target != null && target instanceof LivingEntity) {
|
|
|
|
targets.add((LivingEntity) target);
|
2015-12-29 21:35:12 +00:00
|
|
|
}
|
2015-08-02 06:58:35 +00:00
|
|
|
}
|
2016-10-24 06:23:02 +00:00
|
|
|
|
2016-01-13 21:14:34 +00:00
|
|
|
if (!canSuffocateUndead) {
|
2015-08-02 06:58:35 +00:00
|
|
|
for (int i = 0; i < targets.size(); i++) {
|
|
|
|
LivingEntity target = targets.get(i);
|
|
|
|
if (GeneralMethods.isUndead(target)) {
|
|
|
|
targets.remove(i);
|
|
|
|
i--;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-13 21:14:34 +00:00
|
|
|
bPlayer.addCooldown(this);
|
|
|
|
start();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void progress() {
|
|
|
|
for (int i = 0; i < targets.size(); i++) {
|
|
|
|
LivingEntity target = targets.get(i);
|
2016-10-24 06:23:02 +00:00
|
|
|
if (target.isDead() || !target.getWorld().equals(player.getWorld()) || target.getLocation().distanceSquared(player.getEyeLocation()) > range * range || GeneralMethods.isRegionProtectedFromBuild(this, target.getLocation())) {
|
2016-01-13 21:14:34 +00:00
|
|
|
breakSuffocateLocal(target);
|
|
|
|
i--;
|
|
|
|
} else if (target instanceof Player) {
|
|
|
|
Player targPlayer = (Player) target;
|
|
|
|
if (!targPlayer.isOnline()) {
|
|
|
|
breakSuffocateLocal(target);
|
|
|
|
i--;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (targets.size() == 0 || !bPlayer.canBendIgnoreCooldowns(this)) {
|
|
|
|
remove();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (requireConstantAim) {
|
2016-10-15 04:32:15 +00:00
|
|
|
double dist = 0;
|
2016-10-24 06:23:02 +00:00
|
|
|
if (player.getWorld().equals(targets.get(0).getWorld())) {
|
2016-10-15 04:32:15 +00:00
|
|
|
dist = player.getEyeLocation().distance(targets.get(0).getEyeLocation());
|
|
|
|
}
|
2016-10-24 06:23:02 +00:00
|
|
|
Location targetLoc = player.getEyeLocation().clone().add(player.getEyeLocation().getDirection().normalize().multiply(dist));
|
2016-01-13 21:14:34 +00:00
|
|
|
List<Entity> ents = GeneralMethods.getEntitiesAroundPoint(targetLoc, constantAimRadius);
|
|
|
|
|
|
|
|
for (int i = 0; i < targets.size(); i++) {
|
|
|
|
LivingEntity target = targets.get(i);
|
|
|
|
if (!ents.contains(target)) {
|
|
|
|
breakSuffocateLocal(target);
|
|
|
|
i--;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (targets.size() == 0) {
|
|
|
|
remove();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-10-24 06:23:02 +00:00
|
|
|
if (System.currentTimeMillis() - getStartTime() < chargeTime) {
|
2015-08-02 06:58:35 +00:00
|
|
|
return;
|
2016-01-13 21:14:34 +00:00
|
|
|
} else if (!started) {
|
|
|
|
started = true;
|
|
|
|
for (LivingEntity targ : targets) {
|
|
|
|
final LivingEntity target = targ;
|
|
|
|
BukkitRunnable br1 = new BukkitRunnable() {
|
|
|
|
@Override
|
|
|
|
public void run() {
|
2016-03-03 01:54:15 +00:00
|
|
|
DamageHandler.damageEntity(target, damage, ability);
|
2016-01-13 21:14:34 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
BukkitRunnable br2 = new BukkitRunnable() {
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
target.addPotionEffect(new PotionEffect(PotionEffectType.SLOW, (int) (slowRepeat * 20), (int) slow));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
BukkitRunnable br3 = new BukkitRunnable() {
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
target.addPotionEffect(new PotionEffect(PotionEffectType.BLINDNESS, (int) (blindRepeat * 20), (int) blind));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
tasks.add(br1);
|
|
|
|
tasks.add(br2);
|
|
|
|
tasks.add(br3);
|
|
|
|
br1.runTaskTimer(ProjectKorra.plugin, (long) (damageDelay * 20), (long) (damageRepeat * 20));
|
|
|
|
br2.runTaskTimer(ProjectKorra.plugin, (long) (slowDelay * 20), (long) (slowRepeat * 20 / 0.25));
|
|
|
|
br3.runTaskTimer(ProjectKorra.plugin, (long) (blindDelay * 20), (long) (blindRepeat * 20));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
animate();
|
|
|
|
if (!player.isSneaking()) {
|
|
|
|
remove();
|
2015-08-02 06:58:35 +00:00
|
|
|
return;
|
2016-01-13 21:14:34 +00:00
|
|
|
}
|
2015-08-02 06:58:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Stops an entity from being suffocated **/
|
|
|
|
public static void breakSuffocate(Entity entity) {
|
2016-01-16 21:07:14 +00:00
|
|
|
for (Suffocate suffocate : getAbilities(Suffocate.class)) {
|
2015-08-02 06:58:35 +00:00
|
|
|
if (suffocate.targets.contains(entity)) {
|
|
|
|
suffocate.breakSuffocateLocal(entity);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Checks if an entity is being suffocated **/
|
|
|
|
public static boolean isBreathbent(Entity entity) {
|
2016-01-16 21:07:14 +00:00
|
|
|
for (Suffocate suffocate : getAbilities(Suffocate.class)) {
|
2015-08-02 06:58:35 +00:00
|
|
|
if (suffocate.targets.contains(entity)) {
|
|
|
|
return suffocate.started;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Determines if a player is Suffocating entities **/
|
|
|
|
public static boolean isChannelingSphere(Player player) {
|
2016-01-16 21:07:14 +00:00
|
|
|
return hasAbility(player, Suffocate.class);
|
2015-08-02 06:58:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-10-24 06:23:02 +00:00
|
|
|
* Removes an instance of Suffocate if player is the one suffocating
|
|
|
|
* entities
|
2015-08-02 06:58:35 +00:00
|
|
|
**/
|
|
|
|
public static void remove(Player player) {
|
2016-01-16 21:07:14 +00:00
|
|
|
Suffocate suff = getAbility(player, Suffocate.class);
|
2016-01-13 21:14:34 +00:00
|
|
|
if (suff != null) {
|
|
|
|
suff.remove();
|
2015-11-11 20:19:45 +00:00
|
|
|
}
|
|
|
|
}
|
2015-11-11 23:22:27 +00:00
|
|
|
|
2015-08-02 06:58:35 +00:00
|
|
|
/**
|
2016-10-24 06:23:02 +00:00
|
|
|
* Removes all instances of Suffocate at loc within the radius threshold.
|
|
|
|
* The location of a Suffocate is defined at the benders location, not the
|
|
|
|
* location of the entities being suffocated.
|
2015-08-02 06:58:35 +00:00
|
|
|
*
|
2015-08-03 04:48:54 +00:00
|
|
|
* @param causer The player causing this instance to be removed
|
|
|
|
**/
|
2015-08-02 06:58:35 +00:00
|
|
|
public static boolean removeAtLocation(Player causer, Location loc, double radius) {
|
2016-01-13 21:14:34 +00:00
|
|
|
if (causer == null) {
|
|
|
|
return false;
|
|
|
|
}
|
2016-01-16 21:07:14 +00:00
|
|
|
for (Suffocate suff : getAbilities(Suffocate.class)) {
|
2016-01-13 21:14:34 +00:00
|
|
|
if (!suff.player.equals(causer)) {
|
2015-11-11 20:19:45 +00:00
|
|
|
Location playerLoc = suff.getPlayer().getLocation();
|
2016-01-13 21:14:34 +00:00
|
|
|
if (playerLoc.getWorld().equals(loc.getWorld()) && playerLoc.distanceSquared(loc) <= radius * radius) {
|
2015-11-11 20:19:45 +00:00
|
|
|
suff.remove();
|
2015-08-02 06:58:35 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-10-24 06:23:02 +00:00
|
|
|
* Animates this instance of the Suffocate ability. Depending on the
|
|
|
|
* specific time (dt) the ability will create a different set of
|
|
|
|
* SuffocationSpirals.
|
2015-08-02 06:58:35 +00:00
|
|
|
*/
|
|
|
|
public void animate() {
|
2016-01-13 21:14:34 +00:00
|
|
|
int steps = 8 * particleCount;
|
2015-08-02 06:58:35 +00:00
|
|
|
long curTime = System.currentTimeMillis();
|
2016-10-24 06:23:02 +00:00
|
|
|
long dt = curTime - getStartTime() - chargeTime;
|
2016-01-13 21:14:34 +00:00
|
|
|
long delay = 2 / particleCount;
|
|
|
|
long t1 = (long) (1500 * animationSpeed);
|
|
|
|
long t2 = (long) (2500 * animationSpeed);
|
|
|
|
long t3 = (long) (5000 * animationSpeed);
|
|
|
|
long t4 = (long) (6000 * animationSpeed);
|
2015-08-02 06:58:35 +00:00
|
|
|
for (LivingEntity lent : targets) {
|
|
|
|
final LivingEntity target = lent;
|
|
|
|
if (dt < t1) {
|
2016-10-24 06:23:02 +00:00
|
|
|
new SuffocateSpiral(target, steps, radius, delay, 0, 0.25 - (0.25 * (double) dt / (double) t1), 0, SpiralType.HORIZONTAL1);
|
|
|
|
new SuffocateSpiral(target, steps, radius, delay, 0, 0.25 - (0.25 * (double) dt / (double) t1), 0, SpiralType.HORIZONTAL2);
|
2015-08-02 06:58:35 +00:00
|
|
|
} else if (dt < t2) {
|
|
|
|
new SuffocateSpiral(target, steps, radius, delay, 0, 0, 0, SpiralType.HORIZONTAL1);
|
|
|
|
new SuffocateSpiral(target, steps * 2, radius, delay, 0, 0, 0, SpiralType.VERTICAL1);
|
|
|
|
new SuffocateSpiral(target, steps * 2, radius, delay, 0, 0, 0, SpiralType.VERTICAL2);
|
|
|
|
} else if (dt < t3) {
|
|
|
|
new SuffocateSpiral(target, steps, radius, delay, 0, 0, 0, SpiralType.HORIZONTAL1);
|
|
|
|
new SuffocateSpiral(target, steps, radius, delay, 0, 0, 0, SpiralType.VERTICAL1);
|
|
|
|
new SuffocateSpiral(target, steps, radius, delay, 0, 0, 0, SpiralType.VERTICAL2);
|
|
|
|
} else if (dt < t4) {
|
2016-10-24 06:23:02 +00:00
|
|
|
new SuffocateSpiral(target, steps, radius - Math.min(radius * 3 / 4, (radius * 3.0 / 4 * ((double) (dt - t3) / (double) (t4 - t3)))), delay, 0, 0, 0, SpiralType.HORIZONTAL1);
|
|
|
|
new SuffocateSpiral(target, steps, radius - Math.min(radius * 3 / 4, (radius * 3.0 / 4 * ((double) (dt - t3) / (double) (t4 - t3)))), delay, 0, 0, 0, SpiralType.VERTICAL1);
|
|
|
|
new SuffocateSpiral(target, steps, radius - Math.min(radius * 3 / 4, (radius * 3.0 / 4 * ((double) (dt - t3) / (double) (t4 - t3)))), delay, 0, 0, 0, SpiralType.VERTICAL2);
|
2015-08-02 06:58:35 +00:00
|
|
|
} else {
|
|
|
|
new SuffocateSpiral(target, steps, radius - (radius * 3.0 / 4.0), delay, 0, 0, 0, SpiralType.HORIZONTAL1);
|
|
|
|
new SuffocateSpiral(target, steps, radius - (radius * 3.0 / 4.0), delay, 0, 0, 0, SpiralType.VERTICAL1);
|
|
|
|
new SuffocateSpiral(target, steps, radius - (radius * 3.0 / 4.0), delay, 0, 0, 0, SpiralType.VERTICAL2);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Stops an entity from being suffocated **/
|
|
|
|
public void breakSuffocateLocal(Entity entity) {
|
2016-01-13 21:14:34 +00:00
|
|
|
if (targets.contains(entity)) {
|
2015-08-02 06:58:35 +00:00
|
|
|
targets.remove(entity);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Removes this instance of the ability **/
|
2016-01-13 21:14:34 +00:00
|
|
|
@Override
|
2015-08-02 06:58:35 +00:00
|
|
|
public void remove() {
|
2016-01-13 21:14:34 +00:00
|
|
|
super.remove();
|
2015-08-02 06:58:35 +00:00
|
|
|
for (int i = 0; i < tasks.size(); i++) {
|
|
|
|
tasks.get(i).cancel();
|
|
|
|
tasks.remove(i);
|
|
|
|
i--;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-10-24 06:23:02 +00:00
|
|
|
* Animates a Spiral of air particles around a location or a targetted
|
|
|
|
* entity. The direction of the spiral is determined by SpiralType, and each
|
|
|
|
* type is calculated independently from one another.
|
2015-08-02 06:58:35 +00:00
|
|
|
*/
|
|
|
|
public class SuffocateSpiral extends BukkitRunnable {
|
|
|
|
private Location startLoc;
|
|
|
|
private Location loc;
|
|
|
|
private LivingEntity target;
|
|
|
|
private int totalSteps;
|
|
|
|
private double radius;
|
|
|
|
private double dx, dy, dz;
|
|
|
|
private SpiralType type;
|
|
|
|
private int i;
|
|
|
|
|
|
|
|
/**
|
2015-08-03 04:48:54 +00:00
|
|
|
* @param lent The entity to animate the spiral around
|
|
|
|
* @param totalSteps Amount of times it will be animated
|
|
|
|
* @param radius The radius of the spiral
|
|
|
|
* @param interval The speed of the animation
|
|
|
|
* @param dx x offset
|
|
|
|
* @param dy y offset
|
|
|
|
* @param dz z offset
|
|
|
|
* @param type Spiral animation direction
|
2015-08-02 06:58:35 +00:00
|
|
|
*/
|
2016-10-24 06:23:02 +00:00
|
|
|
public SuffocateSpiral(LivingEntity lent, int totalSteps, double radius, long interval, double dx, double dy, double dz, SpiralType type) {
|
2015-08-02 06:58:35 +00:00
|
|
|
this.target = lent;
|
|
|
|
this.totalSteps = totalSteps;
|
|
|
|
this.radius = radius;
|
|
|
|
this.dx = dx;
|
|
|
|
this.dy = dy;
|
|
|
|
this.dz = dz;
|
|
|
|
this.type = type;
|
2016-01-13 21:14:34 +00:00
|
|
|
this.loc = target.getEyeLocation();
|
|
|
|
this.i = 0;
|
2015-08-02 06:58:35 +00:00
|
|
|
this.runTaskTimer(ProjectKorra.plugin, 0L, interval);
|
|
|
|
tasks.add(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-08-03 04:48:54 +00:00
|
|
|
* @param startLoc Initial location
|
|
|
|
* @param totalSteps Amount of times it will be animated
|
|
|
|
* @param radius The radius of the spiral
|
|
|
|
* @param interval The speed of the animation
|
|
|
|
* @param dx x offset
|
|
|
|
* @param dy y offset
|
|
|
|
* @param dz z offset
|
|
|
|
* @param type Spiral animation direction
|
2015-08-02 06:58:35 +00:00
|
|
|
*/
|
2016-10-24 06:23:02 +00:00
|
|
|
public SuffocateSpiral(Location startLoc, int totalSteps, double radius, long interval, double dx, double dy, double dz, SpiralType type) {
|
2015-08-02 06:58:35 +00:00
|
|
|
this.startLoc = startLoc;
|
|
|
|
this.totalSteps = totalSteps;
|
|
|
|
this.radius = radius;
|
|
|
|
this.dx = dx;
|
|
|
|
this.dy = dy;
|
|
|
|
this.dz = dz;
|
|
|
|
this.type = type;
|
2016-01-13 21:14:34 +00:00
|
|
|
this.loc = startLoc.clone();
|
|
|
|
this.i = 0;
|
2015-08-02 06:58:35 +00:00
|
|
|
this.runTaskTimer(ProjectKorra.plugin, 0L, interval);
|
|
|
|
tasks.add(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Starts the initial animation, and removes itself when it is finished.
|
|
|
|
*/
|
|
|
|
public void run() {
|
|
|
|
Location tempLoc;
|
|
|
|
if (target != null) {
|
|
|
|
tempLoc = target.getEyeLocation();
|
|
|
|
tempLoc.setY(tempLoc.getY() - 0.5);
|
|
|
|
} else {
|
|
|
|
tempLoc = startLoc.clone();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (type == SpiralType.HORIZONTAL1) {
|
|
|
|
loc.setX(tempLoc.getX() + radius * Math.cos(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
loc.setY(tempLoc.getY() + dy * i);
|
|
|
|
loc.setZ(tempLoc.getZ() + radius * Math.sin(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
} else if (type == SpiralType.HORIZONTAL2) {
|
|
|
|
loc.setX(tempLoc.getX() + radius * -Math.cos(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
loc.setY(tempLoc.getY() + dy * i);
|
|
|
|
loc.setZ(tempLoc.getZ() + radius * -Math.sin(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
} else if (type == SpiralType.VERTICAL1) {
|
|
|
|
loc.setX(tempLoc.getX() + radius * Math.sin(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
loc.setY(tempLoc.getY() + radius * Math.cos(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
loc.setZ(tempLoc.getZ() + dz * i);
|
|
|
|
} else if (type == SpiralType.VERTICAL2) {
|
|
|
|
loc.setX(tempLoc.getX() + dx * i);
|
|
|
|
loc.setY(tempLoc.getY() + radius * Math.sin(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
loc.setZ(tempLoc.getZ() + radius * Math.cos(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
} else if (type == SpiralType.DIAGONAL1) {
|
|
|
|
loc.setX(tempLoc.getX() + radius * Math.cos(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
loc.setY(tempLoc.getY() + radius * Math.sin(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
loc.setZ(tempLoc.getZ() + radius * -Math.cos(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
} else if (type == SpiralType.DIAGONAL2) {
|
|
|
|
loc.setX(tempLoc.getX() + radius * Math.cos(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
loc.setY(tempLoc.getY() + radius * Math.sin(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
loc.setZ(tempLoc.getZ() + radius * Math.cos(Math.toRadians((double) i / (double) totalSteps * 360)));
|
|
|
|
}
|
|
|
|
|
2016-01-13 21:14:34 +00:00
|
|
|
getAirbendingParticles().display(loc, (float) 0, (float) 0, (float) 0, 0, 1);
|
|
|
|
if (i == totalSteps + 1) {
|
2015-08-02 06:58:35 +00:00
|
|
|
this.cancel();
|
2016-01-13 21:14:34 +00:00
|
|
|
}
|
2015-08-02 06:58:35 +00:00
|
|
|
i++;
|
|
|
|
}
|
|
|
|
}
|
2016-01-13 21:14:34 +00:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getName() {
|
|
|
|
return "Suffocate";
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public Location getLocation() {
|
|
|
|
if (targets.size() > 0) {
|
|
|
|
return targets.get(0).getLocation();
|
|
|
|
} else if (player != null) {
|
|
|
|
return player.getLocation();
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public long getCooldown() {
|
|
|
|
return cooldown;
|
|
|
|
}
|
2016-10-24 06:23:02 +00:00
|
|
|
|
2016-01-13 21:14:34 +00:00
|
|
|
@Override
|
|
|
|
public boolean isSneakAbility() {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean isHarmlessAbility() {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2016-10-24 06:23:02 +00:00
|
|
|
@Override
|
|
|
|
public List<Location> getLocations() {
|
|
|
|
ArrayList<Location> locations = new ArrayList<>();
|
|
|
|
locations.add(player.getLocation());
|
|
|
|
return locations;
|
|
|
|
}
|
|
|
|
|
2016-01-13 21:14:34 +00:00
|
|
|
public boolean isStarted() {
|
|
|
|
return started;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setStarted(boolean started) {
|
|
|
|
this.started = started;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isRequireConstantAim() {
|
|
|
|
return requireConstantAim;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setRequireConstantAim(boolean requireConstantAim) {
|
|
|
|
this.requireConstantAim = requireConstantAim;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isCanSuffocateUndead() {
|
|
|
|
return canSuffocateUndead;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setCanSuffocateUndead(boolean canSuffocateUndead) {
|
|
|
|
this.canSuffocateUndead = canSuffocateUndead;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int getParticleCount() {
|
|
|
|
return particleCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setParticleCount(int particleCount) {
|
|
|
|
this.particleCount = particleCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
public long getChargeTime() {
|
|
|
|
return chargeTime;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setChargeTime(long chargeTime) {
|
|
|
|
this.chargeTime = chargeTime;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getRange() {
|
|
|
|
return range;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setRange(double range) {
|
|
|
|
this.range = range;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getRadius() {
|
|
|
|
return radius;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setRadius(double radius) {
|
|
|
|
this.radius = radius;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getDamage() {
|
|
|
|
return damage;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setDamage(double damage) {
|
|
|
|
this.damage = damage;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getDamageDelay() {
|
|
|
|
return damageDelay;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setDamageDelay(double damageDelay) {
|
|
|
|
this.damageDelay = damageDelay;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getDamageRepeat() {
|
|
|
|
return damageRepeat;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setDamageRepeat(double damageRepeat) {
|
|
|
|
this.damageRepeat = damageRepeat;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getSlow() {
|
|
|
|
return slow;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setSlow(double slow) {
|
|
|
|
this.slow = slow;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getSlowRepeat() {
|
|
|
|
return slowRepeat;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setSlowRepeat(double slowRepeat) {
|
|
|
|
this.slowRepeat = slowRepeat;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getSlowDelay() {
|
|
|
|
return slowDelay;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setSlowDelay(double slowDelay) {
|
|
|
|
this.slowDelay = slowDelay;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getConstantAimRadius() {
|
|
|
|
return constantAimRadius;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setConstantAimRadius(double constantAimRadius) {
|
|
|
|
this.constantAimRadius = constantAimRadius;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getBlind() {
|
|
|
|
return blind;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setBlind(double blind) {
|
|
|
|
this.blind = blind;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getBlindDelay() {
|
|
|
|
return blindDelay;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setBlindDelay(double blindDelay) {
|
|
|
|
this.blindDelay = blindDelay;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getBlindRepeat() {
|
|
|
|
return blindRepeat;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setBlindRepeat(double blindRepeat) {
|
|
|
|
this.blindRepeat = blindRepeat;
|
|
|
|
}
|
|
|
|
|
|
|
|
public double getAnimationSpeed() {
|
|
|
|
return animationSpeed;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setAnimationSpeed(double animationSpeed) {
|
|
|
|
this.animationSpeed = animationSpeed;
|
|
|
|
}
|
|
|
|
|
|
|
|
public ArrayList<BukkitRunnable> getTasks() {
|
|
|
|
return tasks;
|
|
|
|
}
|
|
|
|
|
|
|
|
public ArrayList<LivingEntity> getTargets() {
|
|
|
|
return targets;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setCooldown(long cooldown) {
|
|
|
|
this.cooldown = cooldown;
|
|
|
|
}
|
2015-08-02 06:58:35 +00:00
|
|
|
}
|