| Package | mx.effects |
| Class | public class Effect |
| Inheritance | Effect EventDispatcher Object |
| Implements | IEffect |
| Subclasses | AddAction, AddChildAction, AddItemAction, Animate, CallAction, CompositeEffect, MaskEffect, RemoveAction, RemoveChildAction, RemoveItemAction, SetAction, SetPropertyAction, SetStyleAction, SoundEffect, TweenEffect, UnconstrainItemAction |
| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
You do not create an instance of the Effect class itself in an application. Instead, you create an instance of one of the subclasses, such as Fade or WipeLeft.
MXML Syntax
Hide MXML SyntaxThe Effect class defines the following properties, which all of its subclasses inherit:
<mx:tagname
Properties
customFilter=""
duration="500"
filter=""
hideFocusRing="false"
perElementOffset="0"
repeatCount="1"
repeatDelay="0"
startDelay="0"
suspendBackgroundProcessing="false|true"
target="effect target"
targets="array of effect targets"
Events
effectEnd="No default"
efectStart="No default"
/>
More examples
Using the Effect.target and Effect.targets properties
Applying effects by using data binding
Playing an effect backward
Ending an effect
Creating effects in ActionScript
Setting effect durations
Delaying effect start
Repeating effects
Handling effect events
Creating composite effects
Using embedded fonts with effects
Suspending background processing
Disabling container layout for effects
Handling Spark effect events
Using Spark easing classes
Example: Defining a simple effect
Example: Passing parameters to effects
Writing an effect for a transition
Defining a custom effect trigger for MX effects
Learn more
About effects
About applying Spark effects
About applying MX effects
About factory and instance classes
Working with effects
Using MX effects
Handling MX effect events
About transitions
Improving effect performance
About creating a custom effect
Related API Elements
| Property | Defined By | ||
|---|---|---|---|
| className : String [read-only]
The name of the effect class, such as "Fade". | Effect | ||
![]() | constructor : Object
A reference to the class object or constructor function for a given object instance. | Object | |
| customFilter : mx.effects:EffectTargetFilter
Specifies a custom filter object, of type EffectTargetFilter,
used by the effect to determine the targets
on which to play the effect. | Effect | ||
| duration : Number
Duration of the effect in milliseconds. | Effect | ||
| effectTargetHost : mx.effects:IEffectTargetHost
A property that lets you access the target list-based control
of a data effect. | Effect | ||
| filter : String
Specifies an algorithm for filtering targets for an effect. | Effect | ||
| hideFocusRing : Boolean
Determines whether the effect should hide the focus ring
when starting the effect. | Effect | ||
| instanceClass : Class
An object of type Class that specifies the effect
instance class class for this effect class. | Effect | ||
| isPlaying : Boolean [read-only]
A read-only flag which is true if any instances of the effect
are currently playing, and false if none are. | Effect | ||
| perElementOffset : Number
Additional delay, in milliseconds, for effect targets
after the first target of the effect. | Effect | ||
| playheadTime : Number
Current time position of the effect. | Effect | ||
![]() | prototype : Object [static]
A reference to the prototype object of a class or function object. | Object | |
| relevantProperties : Array
An Array of property names to use when performing filtering. | Effect | ||
| relevantStyles : Array
An Array of style names to use when performing filtering. | Effect | ||
| repeatCount : int = 1
Number of times to repeat the effect. | Effect | ||
| repeatDelay : int = 0
Amount of time, in milliseconds, to wait before repeating the effect. | Effect | ||
| startDelay : int = 0
Amount of time, in milliseconds, to wait before starting the effect. | Effect | ||
| suspendBackgroundProcessing : Boolean = false
If true, blocks all background processing
while the effect is playing. | Effect | ||
| target : Object
The object to which this effect is applied. | Effect | ||
| targets : Array
An Array of objects that are targets for the effect. | Effect | ||
| triggerEvent : Event
The Event object passed to this Effect
by the EffectManager when an effect is triggered,
or null if the effect is not being
played by the EffectManager. | Effect | ||
| Property | Defined By | ||
|---|---|---|---|
| applyTransitionEndProperties : Boolean
This flag controls whether the effect, when run in a transition,
automatically applies the property values according to the end
state, as opposed to leaving values as set by the effect itself. | Effect | ||
| endValuesCaptured : Boolean = false
A flag containing true if the end values
of an effect have already been determined,
or false if they should be acquired from the
current properties of the effect targets when the effect runs. | Effect | ||
| Method | Defined By | ||
|---|---|---|---|
Constructor. | Effect | ||
![]() | addEventListener(type:String, listener:Function, useCapture:Boolean = false, priority:int = 0, useWeakReference:Boolean = false):void
Registers an event listener object with an EventDispatcher object so that the listener
receives notification of an event. | EventDispatcher | |
Captures the current values of the relevant properties
on the effect's targets and saves them as end values. | Effect | ||
Captures the current values of the relevant properties
of an additional set of targets
Flex uses this function when a data change
effect is run.
| Effect | ||
Captures the current values of the relevant properties
on the effect's targets. | Effect | ||
Creates a single effect instance and initializes it. | Effect | ||
Takes an Array of target objects and invokes the
createInstance() method on each target. | Effect | ||
Removes event listeners from an instance
and removes it from the list of instances. | Effect | ||
![]() |
Dispatches an event into the event flow. | EventDispatcher | |
Interrupts an effect that is currently playing,
and jumps immediately to the end of the effect. | Effect | ||
Returns an Array of Strings, where each String is the name
of a property changed by this effect. | Effect | ||
![]() |
Checks whether the EventDispatcher object has any listeners registered for a specific type
of event. | EventDispatcher | |
![]() |
Indicates whether an object has a specified property defined. | Object | |
![]() |
Indicates whether an instance of the Object class is in the prototype chain of the object specified
as the parameter. | Object | |
Pauses the effect until you call the resume() method. | Effect | ||
Begins playing the effect. | Effect | ||
![]() |
Indicates whether the specified property exists and is enumerable. | Object | |
![]() |
Removes a listener from the EventDispatcher object. | EventDispatcher | |
Resumes the effect after it has been paused
by a call to the pause() method. | Effect | ||
Plays the effect in reverse, if the effect is currently playing,
starting from the current position of the effect. | Effect | ||
![]() |
Sets the availability of a dynamic property for loop operations. | Object | |
Stops the effect, leaving the effect targets in their current state. | Effect | ||
![]() |
Returns the string representation of this object, formatted according to locale-specific conventions. | Object | |
![]() |
Returns the string representation of the specified object. | Object | |
![]() |
Returns the primitive value of the specified object. | Object | |
![]() |
Checks whether an event listener is registered with this EventDispatcher object or any of
its ancestors for the specified event type. | EventDispatcher | |
| Method | Defined By | ||
|---|---|---|---|
Used internally by the Effect infrastructure. | Effect | ||
Called when an effect instance has finished playing. | Effect | ||
This method is called when the effect instance starts playing. | Effect | ||
Called when an effect instance has stopped by a call
to the stop() method. | Effect | ||
Determines the logic for filtering out an effect instance. | Effect | ||
Called by the captureStartValues() method to get the value
of a property from the target. | Effect | ||
Copies properties of the effect to the effect instance. | Effect | ||
| Event | Summary | Defined By | ||
|---|---|---|---|---|
![]() | [broadcast event] Dispatched when the Flash Player or AIR application gains operating system focus and becomes active. | EventDispatcher | ||
![]() | [broadcast event] Dispatched when the Flash Player or AIR application operating loses system focus and is becoming inactive. | EventDispatcher | ||
| Dispatched when one of the effect's instances finishes playing, either when the instance finishes playing or when the effect is interrupted by a call to the end() method. | Effect | |||
| Dispatched when the effect starts playing. | Effect | |||
| Dispatched when the effect has been stopped, which only occurs when the effect is interrupted by a call to the stop() method. | Effect | |||
applyTransitionEndProperties | property |
protected var applyTransitionEndProperties:Boolean| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
This flag controls whether the effect, when run in a transition, automatically applies the property values according to the end state, as opposed to leaving values as set by the effect itself.
The default value is true.
className | property |
className:String [read-only] | Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
The name of the effect class, such as "Fade".
This is a short, or unqualified, class name
that does not include the package name.
If you need the qualified name, use the
getQualifiedClassName() method
in the flash.utils package.
Implementation
public function get className():StringcustomFilter | property |
customFilter:mx.effects:EffectTargetFilter| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Specifies a custom filter object, of type EffectTargetFilter, used by the effect to determine the targets on which to play the effect.
Target filtering is only performed if you call the
captureStartValues() method before playing the effect.
Flex automatically calls the captureStartValues() method
when the effect is part of a transition.
Use the filter property for simple filtering.
If the customFilter property is non-null,
the filter property is ignored.
Implementation
public function get customFilter():mx.effects:EffectTargetFilter public function set customFilter(value:mx.effects:EffectTargetFilter):voidduration | property |
duration:Number| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Duration of the effect in milliseconds.
In a Parallel or Sequence effect, the duration
property sets the duration of each effect.
For example, if a Sequence effect has its duration
property set to 3000, each effect in the Sequence takes 3000 ms
to play.
For a repeated effect, the duration property
specifies the duration of a single instance of the effect.
Therefore, if an effect has a duration property
set to 2000, and a repeatCount property set to 3,
the effect takes a total of 6000 ms (6 seconds) to play.
Implementation
public function get duration():Number public function set duration(value:Number):voideffectTargetHost | property |
effectTargetHost:mx.effects:IEffectTargetHost| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
A property that lets you access the target list-based control of a data effect. This property enables an instance of an effect class to communicate with the list-based control on which the effect is playing.
Implementation
public function get effectTargetHost():mx.effects:IEffectTargetHost public function set effectTargetHost(value:mx.effects:IEffectTargetHost):voidendValuesCaptured | property |
protected var endValuesCaptured:Boolean = false| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
A flag containing true if the end values
of an effect have already been determined,
or false if they should be acquired from the
current properties of the effect targets when the effect runs.
This property is required by data effects because the sequence
of setting up the data effects, such as DefaultListEffect
and DefaultTileListEffect, is more complicated than for
normal effects.
The default value is false.
filter | property |
filter:String| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Specifies an algorithm for filtering targets for an effect.
A value of null specifies no filtering.
Target filtering is only performed if you call the
captureStartValues() method before playing the effect.
Flex automatically calls the captureStartValues() method
when the effect is part of a transition, or part of a data effect
for a list-based control.
Use this property for simple filtering.
Use the customFilter property for more complex filtering.
If the customFilter property has a non-null value,
this property is ignored.
You can use the following values for the filter
property:
- A value of
"add"plays the effect on any targets that are added as a child to a container. - A value of
"addItem"plays the effect on the item renderer for any list items added to a List or TileList control. - A value of
"hide"plays the effect on any targets whose visible property changed fromtruetofalse. - A value of
"move"plays the effect on any targets that changed theirxoryproperties. - A value of
"remove"plays the effect on any targets that are removed as a child of a container. - A value of
"removeItem"plays the effect on the item renderer for any list items removed from a List or TileList control. - A value of
"replacedItem"plays the effect on the item renderer for any list items replaced in a List or TileList control by a new item. - A value of
"replacementItem"plays the effect on the item renderer for any list items added to a List or TileList control that replaces an existing item. - A value of
"resize"plays the effect on any targets that changed theirwidthorheightproperties. - A value of
"show"plays the effect on any targets whose visible property changed fromfalsetotrue. - A value of
""specifies no filtering.
Implementation
public function get filter():String public function set filter(value:String):voidhideFocusRing | property |
hideFocusRing:Boolean| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Determines whether the effect should hide the focus ring when starting the effect. The effect target is responsible for the hiding the focus ring. Subclasses of the UIComponent class hide the focus ring automatically. If the effect target is not a subclass of the UIComponent class, add functionality to it to hide the focus ring.
Set this property to true
to hide the focus ring during the effect.
For subclasses of Effect, the default value is false.
For subclasses of MaskEffect, the default value is true.
Implementation
public function get hideFocusRing():Boolean public function set hideFocusRing(value:Boolean):voidinstanceClass | property |
public var instanceClass:Class| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
An object of type Class that specifies the effect instance class class for this effect class.
All subclasses of the Effect class must set this property in their constructor.
isPlaying | property |
perElementOffset | property |
perElementOffset:Number| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Additional delay, in milliseconds, for effect targets
after the first target of the effect.
This value is added to the value
of the startDelay property.
Implementation
public function get perElementOffset():Number public function set perElementOffset(value:Number):voidplayheadTime | property |
playheadTime:Number| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Current time position of the effect.
This property has a value between 0 and the total duration,
which includes the Effect's startDelay,
repeatCount, and repeatDelay.
Implementation
public function get playheadTime():Number public function set playheadTime(value:Number):voidrelevantProperties | property |
relevantProperties:Array| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
An Array of property names to use when performing filtering. This property is used internally and should not be set by effect users.
The default value is equal to the Array returned by
the getAffectedProperties() method.
Implementation
public function get relevantProperties():Array public function set relevantProperties(value:Array):voidrelevantStyles | property |
relevantStyles:Array| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
An Array of style names to use when performing filtering. This property is used internally and should not be set by effect users.
The default value is equal to the Array returned by
the getAffectedProperties() method.
Implementation
public function get relevantStyles():Array public function set relevantStyles(value:Array):voidrepeatCount | property |
public var repeatCount:int = 1| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Number of times to repeat the effect.
Possible values are any integer greater than or equal to 0.
A value of 1 means to play the effect once.
A value of 0 means to play the effect indefinitely
until stopped by a call to the end() method.
The default value is 1.
repeatDelay | property |
public var repeatDelay:int = 0| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Amount of time, in milliseconds, to wait before repeating the effect. Possible values are any integer greater than or equal to 0.
The default value is 0.
startDelay | property |
public var startDelay:int = 0| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Amount of time, in milliseconds, to wait before starting the effect.
Possible values are any int greater than or equal to 0.
If the effect is repeated by using the repeatCount
property, the startDelay is only applied
to the first time the effect is played.
The default value is 0.
suspendBackgroundProcessing | property |
public var suspendBackgroundProcessing:Boolean = false| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
If true, blocks all background processing
while the effect is playing.
Background processing includes measurement, layout, and
processing responses that have arrived from the server.
The default value is false.
You are encouraged to set this property to
true in most cases, because it improves
the performance of the application.
However, the property should be set to false
if either of the following is true:
- User input can arrive while the effect is playing, and the application must respond to the user input before the effect finishes playing.
- A response can arrive from the server while the effect is playing, and the application must process the response while the effect is still playing.
The default value is false.
target | property |
target:Object| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
The object to which this effect is applied.
When an effect is triggered by an effect trigger,
the target property is automatically set to be
the object that triggers the effect.
Implementation
public function get target():Object public function set target(value:Object):voidtargets | property |
targets:Array| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
An Array of objects that are targets for the effect.
When the effect is playing, it performs the effect on each target
in parallel.
Setting the target property replaces all objects
in this Array.
When the targets property is set, the target
property returns the first item in this Array.
Implementation
public function get targets():Array public function set targets(value:Array):voidtriggerEvent | property |
triggerEvent:Event| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
The Event object passed to this Effect
by the EffectManager when an effect is triggered,
or null if the effect is not being
played by the EffectManager.
Implementation
public function get triggerEvent():Event public function set triggerEvent(value:Event):voidEffect | () | Constructor |
public function Effect(target:Object = null)| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Constructor.
Starting an effect is usually a three-step process:
- Create an instance of the effect object
with the
newoperator. - Set properties on the effect object,
such as
duration. - Call the
play()method or assign the effect to a trigger.
target:Object (default = null) — The Object to animate with this effect.
|
applyValueToTarget | () | method |
protected function applyValueToTarget(target:Object, property:String, value:*, props:Object):void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Used internally by the Effect infrastructure.
If captureStartValues() has been called,
then when Flex calls the play() method, it uses this function
to set the targets back to the starting state.
The default behavior is to take the value captured
using the getValueFromTarget() method
and set it directly on the target's property. For example:
target[property] = value;
Only override this method if you need to apply
the captured values in a different way.
Note that style properties of a target are set
using a different mechanism.
Use the relevantStyles property to specify
which style properties to capture and apply.
Parameters
target:Object — The effect target.
| |
property:String — The target property.
| |
value:* — The value of the property.
| |
props:Object — Array of Objects, where each Array element contains a
start and end Object
for the properties that the effect is monitoring.
|
captureEndValues | () | method |
public function captureEndValues():void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Captures the current values of the relevant properties on the effect's targets and saves them as end values.
Flex automatically calls the captureEndValues() method
when the effect is part of a data change effect.
captureMoreStartValues | () | method |
public function captureMoreStartValues(targets:Array):void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Captures the current values of the relevant properties of an additional set of targets
Flex uses this function when a data change effect is run.
Parameters
targets:Array — Array of targets for which values are captured
|
captureStartValues | () | method |
public function captureStartValues():void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Captures the current values of the relevant properties
on the effect's targets.
Flex automatically calls the captureStartValues()
method when the effect is part of a transition.
Use this function when you want the effect to figure out the start and end values of the effect. The proper usage of this function is to use it in the following steps:
- Call the
captureStartValues()method. The effect captures the starting effect values. - Make changes to your effect targets, such as adding/removing children, altering properties, changing location, or changing dimensions.
- Call the
play()method. The effect captures the end values. This function populates theEffectInstance.propertyChangesproperty for each effect instance created by this effect. Effect developers can use thepropertyChangesproperty to retrieve the start and end values for their effect.
createInstance | () | method |
public function createInstance(target:Object = null):IEffectInstance| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Creates a single effect instance and initializes it.
Use this method instead of the play() method
to manipulate the effect instance properties
before the effect instance plays.
The effect instance is created with the type
specified in the instanceClass property.
It is then initialized using the initInstance() method.
If the instance was created by the EffectManager
(when the effect is triggered by an effect trigger),
the effect is further initialized by a call to the
EffectInstance.initEffect() method.
Calling the createInstance() method
does not play the effect.
Call the startEffect() method
on the returned effect instance.
This function is automatically called by the
Effect.play() method.
Parameters
target:Object (default = null) — Object to animate with this effect.
|
IEffectInstance — The effect instance object for the effect.
|
createInstances | () | method |
public function createInstances(targets:Array = null):Array| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Takes an Array of target objects and invokes the
createInstance() method on each target.
Parameters
targets:Array (default = null) — Array of objects to animate with this effect.
|
Array — Array of effect instance objects, one per target,
for the effect.
|
deleteInstance | () | method |
public function deleteInstance(instance:IEffectInstance):void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Removes event listeners from an instance and removes it from the list of instances.
Parameters
instance:IEffectInstance — The effect instance.
|
effectEndHandler | () | method |
protected function effectEndHandler(event:EffectEvent):void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Called when an effect instance has finished playing. If you override this method, ensure that you call the super method.
Parameters
event:EffectEvent — An event object of type EffectEvent.
|
effectStartHandler | () | method |
protected function effectStartHandler(event:EffectEvent):void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
This method is called when the effect instance starts playing. If you override this method, ensure that you call the super method.
Parameters
event:EffectEvent — An event object of type EffectEvent.
|
effectStopHandler | () | method |
protected function effectStopHandler(event:EffectEvent):void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Called when an effect instance has stopped by a call
to the stop() method.
If you override this method, ensure that you call the super method.
Parameters
event:EffectEvent — An event object of type EffectEvent.
|
end | () | method |
public function end(effectInstance:IEffectInstance = null):void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Interrupts an effect that is currently playing,
and jumps immediately to the end of the effect.
Calling this method invokes the EffectInstance.end()
method.
The effect instance dispatches an effectEnd event
when you call this method as part of ending the effect.
If you pass an effect instance as an argument, just that instance is interrupted. If no argument is passed in, all effect instances currently spawned from the effect are interrupted.
Parameters
effectInstance:IEffectInstance (default = null) — EffectInstance to terminate.
|
filterInstance | () | method |
protected function filterInstance(propChanges:Array, target:Object):Boolean| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Determines the logic for filtering out an effect instance. The CompositeEffect class overrides this method.
Parameters
propChanges:Array — The properties modified by the effect.
| |
target:Object — The effect target.
|
Boolean — Returns true if the effect instance should play.
|
getAffectedProperties | () | method |
public function getAffectedProperties():Array| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Returns an Array of Strings, where each String is the name
of a property changed by this effect.
For example, the Move effect returns an Array that contains
"x" and "y".
Every subclass of Effect must implement this method. The EffectManager uses this method to ensure that no two effects are trying to animate the same property of the same object at the same time.
ReturnsArray — An Array of Strings specifying the names of the
properties modified by this effect.
|
More examples
getValueFromTarget | () | method |
protected function getValueFromTarget(target:Object, property:String):*| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Called by the captureStartValues() method to get the value
of a property from the target.
This function should only be called internally
by the effects framework.
The default behavior is to simply return target[property].
Effect developers can override this function
if you need a different behavior.
Parameters
target:Object — The effect target.
| |
property:String — The target property.
|
* — The value of the target property.
|
initInstance | () | method |
protected function initInstance(instance:IEffectInstance):void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Copies properties of the effect to the effect instance.
Flex calls this method from the Effect.createInstance()
method; you do not have to call it yourself.
When you create a custom effect, override this method to
copy properties from the Effect class to the effect instance class.
In your override, call super.initInstance().
Parameters
instance:IEffectInstance — The effect instance to initialize.
|
More examples
pause | () | method |
public function pause():void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Pauses the effect until you call the resume() method.
play | () | method |
public function play(targets:Array = null, playReversedFromEnd:Boolean = false):Array| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Begins playing the effect.
You typically call the end() method
before you call the play() method
to ensure that any previous instance of the effect
has ended before you start a new one.
All subclasses must implement this method.
Parameters
targets:Array (default = null) — Array of target objects on which to play this effect.
If this parameter is specified, then the effect's targets
property is not used.
| |
playReversedFromEnd:Boolean (default = false) — If true,
play the effect backwards.
|
Array — Array of EffectInstance objects, one per target,
for the effect.
|
resume | () | method |
public function resume():void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Resumes the effect after it has been paused
by a call to the pause() method.
reverse | () | method |
public function reverse():void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Plays the effect in reverse, if the effect is currently playing, starting from the current position of the effect.
stop | () | method |
public function stop():void| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Stops the effect, leaving the effect targets in their current state.
Unlike a call to the pause() method,
you cannot call the resume() method after calling
the stop() method.
However, you can call the play() method to restart the effect.
The effect instance dispatches an effectEnd event
when you call this method as part of ending the effect.
For mask effects, the mask is not removed automatically when the effect is stopped. Running further mask effects on the same target(s) without first removing the mask can produce unexpected results.
effectEnd | Event |
mx.events.EffectEventproperty EffectEvent.type =
mx.events.EffectEvent.EFFECT_END| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Dispatched when one of the effect's instances finishes playing,
either when the instance finishes playing or when the effect
is interrupted by a call to the end() method.
EffectEvent.EFFECT_END constant defines the value of the
type property of the event object for an
effectEnd event.
The properties of the event object have the following values:
| Property | Value |
|---|---|
bubbles | false |
cancelable | false |
currentTarget | The Object that defines the
event listener that handles the event. For example, if you use
myButton.addEventListener() to register an event listener,
myButton is the value of the currentTarget. |
effectInstance | The effect instance object for the event. |
target | The Object that dispatched the event;
it is not always the Object listening for the event.
Use the currentTarget property to always access the
Object listening for the event. |
effectStart | Event |
mx.events.EffectEventproperty EffectEvent.type =
mx.events.EffectEvent.EFFECT_START| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Dispatched when the effect starts playing.
TheEffectEvent.EFFECT_START constant defines the value of the
type property of the event object for an
effectStart event.
The properties of the event object have the following values:
| Property | Value |
|---|---|
bubbles | false |
cancelable | false |
currentTarget | The Object that defines the
event listener that handles the event. For example, if you use
myButton.addEventListener() to register an event listener,
myButton is the value of the currentTarget. |
effectInstance | The effect instance object for the event. |
target | The Object that dispatched the event;
it is not always the Object listening for the event.
Use the currentTarget property to always access the
Object listening for the event. |
effectStop | Event |
mx.events.EffectEventproperty EffectEvent.type =
mx.events.EffectEvent.EFFECT_STOP| Language Version: | ActionScript 3.0 |
| Product Version: | Flex 3 |
| Runtime Versions: | Flash Player 9, AIR 1.1 |
Dispatched when the effect has been stopped,
which only occurs when the effect is
interrupted by a call to the stop() method.
The EFFECT_END event is also dispatched to indicate that
the effect has ended. This extra event is sent first, as an
indicator to listeners that the effect did not reach its
end state.
EffectEvent.EFFECT_STOP constant defines the value of the
type property of the event object for an
effectStop event.
The properties of the event object have the following values:
| Property | Value |
|---|---|
bubbles | false |
cancelable | false |
currentTarget | The Object that defines the
event listener that handles the event. For example, if you use
myButton.addEventListener() to register an event listener,
myButton is the value of the currentTarget. |
effectInstance | The effect instance object for the event. |
target | The Object that dispatched the event;
it is not always the Object listening for the event.
Use the currentTarget property to always access the
Object listening for the event. |
<?xml version="1.0"?>
<!-- Simple example to demonstrate the Effect class. -->
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx">
<fx:Script>
<![CDATA[
import mx.controls.Alert;
// Event handler for the effectEnd event.
private function endEffectHandler():void {
Alert.show("Effect Ended!");
}
// Event handler for the reset button.
private function resetHandler():void {
expand.end();
img.width=30;
img.height=60;
button1.enabled=true;
}
]]>
</fx:Script>
<fx:Declarations>
<mx:Resize id="expand" target="{img}" widthTo="100" heightTo="200"
duration="10000" effectEnd="endEffectHandler();"/>
</fx:Declarations>
<s:Panel title="Resize Effect Example" width="100%" height="100%" >
<s:VGroup left="20" right="20" top="20" bottom="20">
<s:Label width="100%" color="blue"
text="Use the Button controls to control the Resize effect."/>
<mx:Image id="img" width="30" height="60"
source="@Embed(source='assets/Nokia_6630.png')"/>
<s:Button id="button1" label="Start" click="expand.play(); button1.enabled=false;"/>
<s:Button label="Pause" click="expand.pause();"/>
<s:Button label="Resume" click="expand.resume();"/>
<s:Button label="Reverse" click="expand.reverse();"/>
<s:Button label="End" click="expand.end();"/>
<s:Button label="Reset" click="resetHandler();"/>
</s:VGroup>
</s:Panel>
</s:Application>
Mon Nov 28 2011, 06:48 AM -08:00
Show MXML Syntax