Members
- 
    <static, readonly> FAIL
- 
    
    Failure reasons for when an ability fails. - Source:
 Properties:Name Type Description UNKNOWNString unknown. COSTString user can't pay cost. TARGETString no target. DISTANCEString target is too far away. COOLDOWNString ability on cooldown. INTERRUPTString casting interrupted. 
- 
    <static, readonly> TYPE
- 
    
    Bitwise flags for abilities to designate types, via ig.Ability#type. 
 - some flags are already defined for convenience
 - up to 32 flags can be defined- Source:
- See:
 Properties:Name Type Description PASSIVEBitflag passive type SPAMMABLEBitflag spoammable type TOGGLEABLEBitflag toggleable type 
- 
    activateCastSettings :Object
- 
    
    Activate cast settings. - Default Value:
- null
 
- Source:
- See:
 
- 
    activated :Boolean
- 
    
    Whether ability has been activated. - Default Value:
- false
 
- Source:
 
- 
    activatePassCastSettings :Object
- 
    
    Activate checks pass cast settings. - Default Value:
- null
 
- Source:
- See:
 
- 
    activateSetupCastSettings :Object
- 
    
    Activate setup cast settings. - Default Value:
- null
 
- Source:
- See:
 
- 
    activateStrict :Boolean
- 
    
    Whether ability should check distance twice during activate process. IMPORTANT: this only applies when casting! - Default Value:
- true
 
- Source:
 
- 
    activateToggle :Boolean
- 
    
    Whether ability should toggle activate / deactivate instead of just activating. - Default Value:
- false
 
- Source:
 
- 
    autoStopMoving :Boolean
- 
    
    Whether ability should automatically force the entity to stop moving so it won't interrupt itself immediately. - Default Value:
- true
 
- Source:
 
- 
    blocking :Boolean
- 
    
    Whether ability blocks other abilities of lower ig.Ability#priority when this ability is activated first via ig.Hierarchy#activate. - Default Value:
- true
 
- Source:
 // if a character has two abilities character.abilityA = new ig.Ability( character ); character.abilityB = new ig.Ability( character ); // and these are added to the character's abilities list character.abilities.addDescendants( [ character.abilityA, character.abilityB ] ); // when abilities are all activated together character.abilities.activate( target ); // we can set abilities to block // the execution of all lower priority abilities // for example, to block B from executing if A is activated successfully // (assuming A priority is > B priority) character.abilityA.blocking = true;
- 
    canFindTarget :Boolean
- 
    
    Whether can find a target in range when has none while executing. - Default Value:
- false
 
- Source:
 
- 
    canTargetFixed :Boolean
- 
    
    Whether can target fixed entities (usually UI elements). - Default Value:
- false
 
- Source:
 
- 
    canTargetOthers :Boolean
- 
    
    Whether can target others. - Default Value:
- true
 
- Source:
 
- 
    canTargetSelf :Boolean
- 
    
    Whether can target self. - Default Value:
- true
 
- Source:
 
- 
    <readonly> casting :Boolean
- 
    
    Whether to ability is casting. - Default Value:
- false
 
- Source:
 
- 
    castTimer :ig.Timer
- 
    
    Timer for casting. 
 - created on init- Source:
 
- 
    channelled :Boolean
- 
    
    Whether ability is channelled after activated. - Default Value:
- false
 
- Source:
 
- 
    <readonly> channelling :Boolean
- 
    
    Whether ability is currently channelling. - Default Value:
- false
 
- Source:
 
- 
    cooldownDelay :Number
- 
    
    Time in seconds ability needs to cooldown between uses. - Default Value:
- 0
 
- Source:
 
- 
    cooldownTimer :ig.Timer
- 
    
    Timer for cooldown. 
 - created on init- Source:
 
- 
    costActivate :Number
- 
    
    Energy cost to activate. - Default Value:
- 0
 
- Source:
 
- 
    costChannel :Number
- 
    
    Energy cost to channel. - Default Value:
- 0
 
- Source:
 
- 
    deactivateCastSettings :Object
- 
    
    Deactivate cast settings. - Default Value:
- null
 
- Source:
- See:
 
- 
    deactivateSetupCastSettings :Object
- 
    
    Deactivate setup cast settings. - Default Value:
- null
 
- Source:
- See:
 
- 
    enabled :Boolean
- 
    
    Whether ability is able to activate. - Default Value:
- true
 
- Source:
 
- 
    entity :ig.EntityExtended
- 
    
    Entity that is using this ability. - Default Value:
- null
 
- Source:
 
- 
    entityOptions :ig.EntityExtended
- 
    
    Entity that provides options / settings for ability use. - Default Value:
- null
 
- Source:
 
- 
    entityTarget :ig.EntityExtended
- 
    
    Entity that is the target of this ability - Default Value:
- null
 
- Source:
 
- 
    faceTarget :Boolean
- 
    
    Whether to face target. - Default Value:
- true
 
- Source:
 
- 
    failCastSettings :Object
- 
    
    Fail cast settings. - Default Value:
- null
 
- Source:
- See:
 
- 
    failReason :String
- 
    
    Reason for ability failure. - Source:
 
- 
    groupTargetable :Number
- 
    
    Flag for groups of entities that can be targeted. Tip: a target must match ALL groups in this flag! - Default Value:
- 0
 
- Source:
- See:
- 
        - ig.utils#addType
- ig.EntityExtended
 
 // target any group except for own group ability.groupTargetable = 0; // target enemy ig.utils.addType( ig.EntityExtended, ability, 'typeTargetable', 'ENEMY', 'GROUP' ); // target enemy zombies ig.utils.addType( ig.EntityExtended, ability, 'typeTargetable', 'ENEMY ZOMBIES', 'GROUP' );
- 
    id :String
- 
    
    Unique instance id. - Source:
 
- 
    movable :Boolean
- 
    
    Whether ability can be used while moving. - Default Value:
- false
 
- Source:
 
- 
    name :String
- 
    
    Unique instance name. 
 - usually names are used to map instances for faster searching.- Source:
 
- 
    needsDeactivate :Boolean
- 
    
    Whether ability needs deactivate. - Default Value:
- false
 
- Source:
 
- 
    onActivated :ig.Signal
- 
    
    Signal dispatched when ability activates. 
 - created on init.- Source:
 
- 
    once :Boolean
- 
    
    Whether ability should activate once and stay activated. - Default Value:
- false
 
- Source:
 
- 
    onDeactivated :ig.Signal
- 
    
    Signal dispatched when ability deactivates. 
 - created on init.- Source:
 
- 
    onFailed :ig.Signal
- 
    
    Signal dispatched when ability fails a check. 
 - created on init.- Source:
 
- 
    paused :Boolean
- 
    
    Whether ability is paused. - Default Value:
- false
 
- Source:
 
- 
    priority :Number
- 
    
    Priority of ability where higher is activated sooner when using ig.Hierarchy#activate. - Default Value:
- 0
 
- Source:
 // if a character has two abilities character.abilityA = new ig.Ability( character ); character.abilityB = new ig.Ability( character ); // and these are added to the character's abilities list character.abilities.addDescendants( [ character.abilityA, character.abilityB ] ); // when these abilities are all activated together character.abilities.activate( target ); // there is no guaranteed order of execution // though in this case it would likely be A then B // to change this order (or to guarantee order) use priorities // for example, to guarantee execution order of B then A character.abilityA.priority = 1; character.abilityB.priority = 0; // this only applies when these abilities are all activated together character.abilities.activate( target );
- 
    rangeX :Number
- 
    
    Horizontal distance for finding targets from ability user, or to determine if ability user is close enough to target. - Default Value:
- 0
 
- Source:
 // does not find targets and treats all targets as if within range ability.rangeX = 0;
- 
    rangeY :Number
- 
    
    Vertical distance for finding targets from ability user, or to determine if ability user is close enough to target. - Default Value:
- 0
 
- Source:
 // does not find targets and treats all targets as if within range ability.rangeY = 0;
- 
    rank :Number
- 
    
    Upgrade rank. - Default Value:
- 0
 
- Source:
 
- 
    regenBlocking :Boolean
- 
    
    Whether blocks user from regenerating while channelling. - Default Value:
- true
 
- Source:
 
- 
    requiresTarget :Boolean
- 
    
    Whether needs target to activate. - Default Value:
- false
 
- Source:
 
- 
    retainTarget :Boolean
- 
    
    Whether to retain target after execution. - Default Value:
- false
 
- Source:
 
- 
    type :Number
- 
    
    Flag for type of ability. - Default Value:
- 0
 
- Source:
- See:
- 
        - ig.utils#addType
 
 
- 
    typeTargetable :Number
- 
    
    Flag for types of entities that can be targeted. Tip: a target must match ALL types in this flag! - Default Value:
- 0
 
- Source:
- See:
- 
        - ig.utils#addType
- ig.EntityExtended
 
 // target any type ability.typeTargetable = 0; // target characters ig.utils.addType( ig.EntityExtended, ability, 'typeTargetable', 'CHARACTER' ); // target characters that are zombies ig.utils.addType( ig.EntityExtended, ability, 'typeTargetable', 'CHARACTER ZOMBIE' );
- 
    upgrades :Array
- 
    
    Upgrades to apply, where each index corresponds to a rank. - Source:
 
Methods
- 
		activate()
- 
    
    
    Activates ability and starts activation process. Can also toggle between activate and deactivate using ig.Ability#activateToggle property. Tip: for best results, your custom ability should do all of its activate magic by overriding the ig.Ability#activateComplete method! - Source:
 
- 
		activateComplete()
- 
    
    
    Completes activate. Step 4 of activate process. Tip: for best results, your custom ability should do all of its activate magic by overriding the ig.Ability#activateComplete method! IMPORTANT: If overriding, always call this.parent() at the end of overriding method as target is dropped at the end of this method. - Source:
 
- 
		activatePass()
- 
    
    
    Called when activate checks passed. Step 3 of activate process. Tip: for best results, your custom ability should do all of its activate magic by overriding the ig.Ability#activateComplete method! - Source:
 
- 
		activatePlain()
- 
    
    
    Activate without any parameters, used when setting entity to activate passive abilities. - Source:
 
- 
		activateSetup()
- 
    
    
    Sets up ability to activate. Step 1 of activate process. Tip: for best results, your custom ability should do all of its activate magic by overriding the ig.Ability#activateComplete method! - Source:
 
- 
		activateTry()
- 
    
    
    Tries to activate by doing checks. Step 2 of activate process. Tip: for best results, your custom ability should do all of its activate magic by overriding the ig.Ability#activateComplete method! - Source:
 
- 
		addUpgrades(upgrades)
- 
    
    
    Adds upgrades to the upgrades list, where each upgrade is mapped by index to a rank. Parameters:Name Type Description upgradesObject | function | Array object with properties to merge into this, a function to call upon upgrade, or an array of the previous. - Source:
 
- 
		assert(checkResult, failReason) → {Boolean}
- 
    
    
    Evaluates a check result and triggers fail if a check is false. Parameters:Name Type Description checkResult* result of a check evaluated as truthy or falsy. failReasonString reason assert may fail. - Source:
 { Boolean } Whether a check is true.
- 
		blockRegen(entity)
- 
    
    
    Blocks energy regeneration in entity. Parameters:Name Type Description entityig.EntityExtended block regeneration in this entity. - Source:
 
- 
		canPayCost() → {Boolean}
- 
    
    
   
    
    
    
    
    
    
- Source:
 { Boolean } Whether entity can pay energy cost.
- 
		cast(settings, internalCallback, internalArgs)
- 
    
    
    Casts using delay and/or animation and then does callback. IMPORTANT: casting only works when ability is also updated. Parameters:Name Type Argument Description settingsObject settings for casting. internalCallbackfunction <optional> 
 internal callback. internalArgsArray <optional> 
 internal arguments. - Source:
 // cast settings is a plain object castSettings = {}; // casts based on 1 second delay castSettings.delay = 1; // add an animation to casting // which will loop until delay complete // if no delay is provided // cast will only last as long as animation castSettings.animName = 'casting'; // if the game is in top down mode // the anim name may be changed // based on the casting entity facing // i.e. "shoot" becomes "shootX" when facing x // i.e. "shoot" becomes "shootY" when facing y and can flip y // i.e. "shoot" becomes "shootUp" when facing up and CANNOT flip y // i.e. "shoot" becomes "shootDown" when facing down and CANNOT flip y // this behavior can be overriden by making the anim omni directional castSettings.animOmniDirectional = true; // casting is by default interrupted by any movement // but this can be changed in 2 ways // either set the ability to movable ability.movable = true; // or set the particular cast to movable castSettings.movable = true; // sometimes we want to cast // but we don't want the cast to block the ability activation process // i.e. this cast should be asynchronous castSettings.async = true; // when casting is complete, we can call a function castSettings.callback = function () { ... }; // in a context castSettings.context = someObject; // and pass a settings object to that callback castSettings.settings = {...}; // while casting, we can also add a list of effects castSettings.effects = [ // where each effect is spawned by a plain object { // that consists of an entity class to spawn as the effect // which will be automatically killed when casting is ended // (usually effects should be particles, so they are garaunteed to die) entityClass: ig.EntityClass // a settings object that will be merged into the spawned entity effect settings: {...}, // effect can ignore the duration of the cast // and live beyond the casting time ignoreDuration: true, // effect can be automatically faded // i.e. it will fade slowly from 1 to 0 over its life fade: true, // effects will default to follow the ability user // if follow settings are included // and these settings map to ig.EntityExtended's moveTo settings followSettings: {...}, // and effects can also follow the ability target followTarget: true } // and we can create as many effects as needed (but don't be a jerk and overload) ... ];
- 
		castComplete()
- 
    
    
    Completes casting. - Source:
 
- 
		castEffects(settings)
- 
    
    
    Shows all effects for effects settings. Parameters:Name Type Description settingsObject effects settings (i.e. castSettings.effects). - Source:
 
- 
		castEnd()
- 
    
    
    Ends casting. - Source:
 
- 
		castStart(settings, internalCallback, internalArgs)
- 
    
    
    Starts casting. Parameters:Name Type Argument Description settingsObject settings object. internalCallbackfunction <optional> 
 internal callback. internalArgsArray <optional> 
 internal arguments. - Source:
 
- 
		castUpdate()
- 
    
    
    Updates casting. - Source:
 
- 
		changegrade(rank)
- 
    
    
    Shifts current upgrade rank up or down based on current vs passed. Parameters:Name Type Description rankNumber rank to upgrade to. - Source:
 
- 
		channel()
- 
    
    
    Channels ability. Step 2 of channel process. - Source:
 
- 
		channelStop()
- 
    
    
    Stops channelling ability. - Source:
 
- 
		channelTry(args)
- 
    
    
    Trys to channel ability by doing checks. Step 1 of channel process. Parameters:Name Type Argument Description argsArray <optional> 
 arguments to use in channel process. - Source:
 
- 
		cleanup()
- 
    
    
    Cleans up ability by immediately and silently deactivating. - Source:
 
- 
		cleanupPlain()
- 
    
    
    Cleanup without parameters. - Source:
 
- 
		clone(c) → {ig.Ability}
- 
    
    
    Clones this ability object. IMPORTANT: any class that extends ig.Ability must define ig.Ability#clone and call parent last. Parameters:Name Type Argument Description cig.Ability <optional> 
 ability object to clone into. - Source:
 { ig.Ability } copy of this.
- 
		closeEnough() → {Boolean}
- 
    
    
   
    
    
    
    
    
    
- Source:
 { Boolean } if entity is close enough to entityTarget
- 
		cooledDown() → {Boolean}
- 
    
    
    Gets whether ability is finished cooling down. - Source:
 { Boolean } whether cooled down.
- 
		deactivate()
- 
    
    
    Deactivates ability and stops channelling. Tip: for best results, your custom ability should do all of its deactivate magic by overriding the ig.Ability#deactivateComplete method! - Source:
 
- 
		deactivateComplete()
- 
    
    
    Finishes deactivate. Step 2 of deactivate process. Tip: for best results, your custom ability should do all of its deactivate magic by overriding the ig.Ability#deactivateComplete method! IMPORTANT: If overriding, always call this.parent() at the end of overriding method as target is dropped at the end of this method. - Source:
 
- 
		deactivateSetup()
- 
    
    
    Sets up ability to deactivate. Step 1 of deactivate process. Tip: for best results, your custom ability should do all of its deactivate magic by overriding the ig.Ability#deactivateComplete method! - Source:
 
- 
		disable()
- 
    
    
    Disables ability, disallowing it to ig.Ability#activate and deactivating it if activated. - Source:
 
- 
		downgrade(rank)
- 
    
    
    Downgrades ability to rank, or, if no rank passed, to previous rank possible. NOTE: Be cautious when using this on abilities that upgrade with a function and not properties. Parameters:Name Type Argument Default Description rankNumber | Boolean <optional> 
 this.rank-1 rank to upgrade to, where boolean true downgrades to min rank. - Source:
 
- 
		dropEntityTarget()
- 
    
    
    Retains or drops current entityTarget automatically. - Source:
 
- 
		effectEnd(effect)
- 
    
    
    Ends an effect. Parameters:Name Type Description effectig.Effect effect. - Source:
 
- 
		effectStart(effect)
- 
    
    
    Creates an effect. Parameters:Name Type Description effectig.Effect effect. - Source:
 
- 
		enable()
- 
    
    
    Enables ability, allowing it to ig.Ability#activate. - Source:
 
- 
		execute()
- 
    
    
    DEPRECATED: please use ig.Ability#activate instead. - Source:
 
- 
		extractCost()
- 
    
    
    Makes entity pay energy cost. - Source:
 
- 
		fail(failReason)
- 
    
    
    Called when ability fails assert. Parameters:Name Type Argument Default Description failReasonString <optional> 
 unknown reason for failure. - Source:
 
- 
		getActivelyUsing() → {Boolean}
- 
    
    
    Whether ability is in active use (i.e. activated or cast or channel). - Source:
 { Boolean } whether in use.
- 
		getInterrupted() → {Boolean}
- 
    
    
    Whether ability is interrupted (currently only by movement) - Source:
 { Boolean } whether interrupted (currently only by movement).
- 
		getUsing() → {Boolean}
- 
    
    
    Whether ability is in use (i.e. cast or channel). - Source:
 { Boolean } whether in use.
- 
		hasTarget() → {Boolean}
- 
    
    
   
    
    
    
    
    
    
- Source:
 { Boolean } if this has entityTarget. May also attempt to find target if possible.
- 
		hasValidTarget()
- 
    
    
    Checks if entityTarget is a valid target, as opposed to if is targetable. - Source:
 
- 
		init(entity, settings)
- 
    
    
    Initializes ability, called upon construction. Parameters:Name Type Argument Description entityig.EntityExtended entity using ability. settingsObject <optional> 
 settings object. - Source:
 
- 
		initProperties()
- 
    
    
    Initializes ability properties. - Source:
 
- 
		initTypes()
- 
    
    
    Initializes ability types. - Source:
 
- 
		initUpgrades()
- 
    
    
    Initializes upgrades. - Source:
 
- 
		isEntityTargetable(entity) → {Boolean}
- 
    
    
   
    
    
    
    
        Parameters:
        
Name Type Description entityig.EntityExtended entity target. - Source:
 { Boolean } Whether entity can (or should) be targeted.
- 
		isEntityTargetDroppable() → {Boolean}
- 
    
    
   
    
    
    
    
    
    
- Source:
 { Boolean } Whether current entityTarget can (or should) be dropped.
- 
		pause()
- 
    
    
    Pauses ability. - Source:
 
- 
		setClosestEntityTarget()
- 
    
    
    Finds and sets closest targetable entity. - Source:
 
- 
		setEnabled(enabled)
- 
    
    
    Sets enabled state ability. Parameters:Name Type Argument Default Description enabledBoolean <optional> 
 true whether enabled. - Source:
 
- 
		setEntity(entity)
- 
    
    
    Sets the entity that is using this ability. Parameters:Name Type Description entityig.EntityExtended ability user. - Source:
 
- 
		setEntityOptions(entity)
- 
    
    
    Sets the entity for passing to bindings as options. Normally the entity that the ability originated with. Parameters:Name Type Description entityig.EntityExtended options provider. - Source:
 
- 
		setEntityTarget(entity)
- 
    
    
    Sets the entity for use as a target. Parameters:Name Type Description entityig.EntityExtended entity target. - Source:
 
- 
		setEntityTargetFirst(entities)
- 
    
    
    Sets first targetable entity from a list. Parameters:Name Type Description entitiesArray array of entities to test. - Source:
 
- 
		unblockRegen(entity)
- 
    
    
    Unblocks energy regeneration in entity. Parameters:Name Type Description entityig.EntityExtended block regeneration in this entity. - Source:
 
- 
		unpause()
- 
    
    
    Unpauses ability. - Source:
 
- 
		update()
- 
    
    
    Updates ability. - Source:
 
- 
		upgrade(rank)
- 
    
    
    Upgrades ability to rank, or, if no rank passed, to next rank possible. Parameters:Name Type Argument Default Description rankNumber | Boolean <optional> 
 this.rank+1 rank to upgrade to, where boolean true will upgrade to max rank. - Source:
 

 
			 Impact++
 Impact++