To download the code, you must agree to the following license:

Copyright 2009, GreenSock, Inc.

"NO CHARGE" NON-EXCLUSIVE SOFTWARE LICENSE AGREEMENT

-----------------------------------------------------------------------------
PLAIN ENGLISH SUMMARY:

-----------------------------------------------------------------------------

LEGALESE:

This is a legal agreement between you (either an individual or a single entity) and GreenSock, Inc. ("GREENSOCK") for the proprietary GreenSock ActionScript code known as TweenLite, TweenMax, TweenNano, TimelineLite, TimelineMax, OverwriteManager, and other code that is freely available for download at http://blog.greensock.com or http://www.greensock.com (this code and documentation, as well as any updates which may at GREENSOCK's sole discretion be provided to you from time to time, are referred to in this Agreement as "PROGRAM") By downloading, copying, or otherwise using the PROGRAM, you agree to the terms and conditions of this Agreement. If you do not agree to the terms and conditions of this Agreement, please do not download or use the PROGRAM.

I. LICENSE
A. Subject to the terms and conditions of this Agreement, GREENSOCK hereby grants you a non-exclusive, worldwide, non-transferable right to use the PROGRAM in web sites, games, applications, components and other software for which the end user is NOT charged any fees. If you would like to use the code in a commercially licensed software product for which end users are charged a fee (either for usage or access), simply sign up for a corporate Club GreenSock membership at http://blog.greensock.com/club/.

II. LIMITATION OF LICENSE AND RESTRICTIONS
A. You agree that you will not disclose, sell, rent, or license the PROGRAM's source code or any derivative works thereof to any third party without the prior written consent of GREENSOCK. Derivative works are defined as modifications that add substantive functionality to the PROGRAM and do not include bug fixes or other minor modifications required to operate the PROGRAM as originally intended. Distribution of the source code as part of your Work Product is acceptable so long as the recipients agree to the terms of this Agreement. You agree not to modify or delete GreenSock's existing copyright notice located in the source code.

B. You may use, duplicate, and distribute the compiled object code as embedded in a Work Product created by you, either for your own use or for distribution to a third party so long as end users of the Work Product are not charged a fee for usage. Please see http://blog.greensock.com/licensing/ for descriptions of Work Products that qualify for the "No Charge" license.

III. CONSIDERATION
A. The license rights granted to you under this Agreement are at no charge, but only in the following circumstances: If, either on your own behalf or on behalf of a third party, you incorporate the Software into a web site, software application, program or any component thereof (collectively, "Work Product"), which in the case of a web site, must be accessible to internet users without payment of a fee of any kind by a user, and in the case of a software application, program or component, neither you nor anyone to whom you distribute the Work Product charges a user a fee of any kind to use such Work Product or application, program or component into which such Work Product is embedded. The foregoing shall apply regardless of whether you are paid to create such Work Product.

B. In the event your intended use of the Software does not meet the criteria for the "no charge" license rights set forth in the immediately preceding paragraph, then you are not licensed to use the PROGRAM under this Agreement and must license the PROGRAM under GreenSockŐs separate fee-based Software License Agreement which is granted to corporate Club GreenSock members (see http://blog.greensock.com/club/ for details).

IV. TITLE AND OWNERSHIP
A. The PROGRAM is licensed, not sold, and is protected by copyright laws and international treaty provisions. You acknowledge that no title to the intellectual property in the PROGRAM is transferred to you. You further acknowledge that title and full ownership rights to the PROGRAM, including all intellectual property rights therein, will remain the exclusive property of GreenSock and you will not acquire any rights to the PROGRAM except as expressly set forth in this Agreement. You agree that any copies of the PROGRAM you make will contain the same proprietary notices which appear on and in the PROGRAM.

V. DISCLAIMER OF WARRANTY AND LIMITATION OF LIABILITY
A. THE PROGRAM IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. GREENSOCK DOES NOT WARRANT THAT THE FUNCTIONS CONTAINED IN THE PROGRAM WILL MEET YOUR REQUIREMENTS OR THAT OPERATION WILL BE UNINTERRUPTED OR ERROR FREE. GREENSOCK shall not be liable for special, indirect, incidental, or consequential damages with respect to any claim on account of or arising from this Agreement or use of the PROGRAM, even if GREENSOCK has been or is hereafter advised of the possibility of such damages. Because some states do not allow certain exclusions or limitations on implied warranties or of liability for consequential or incidental damages, the above exclusions may not apply to you. In no event, however, will GREENSOCK be liable to you, under any theory of recovery, in an amount in excess of the license fee paid by you under this Agreement. Notwithstanding anything else in this agreement, you agree to indemnify GREENSOCK, its assignees, and licensees, and hold each of them harmless from and against any and all claims, demands, losses, damages, liabilities, costs, and expenses, including legal fees.

B. GREENSOCK may, at its sole discretion, provide support services related to the PROGRAM, but has no obligation to do so.

VI. TERMINATION
GreenSock may terminate this Agreement at any time if you fail to comply with the terms and conditions of this Agreement.

VII. MISCELLANEOUS
A. This Agreement shall be construed in accordance with the laws of the State of Illinois. Should you for any reason bring a claim, demand, or other action against GREENSOCK, its agents or employees, arising out of this Agreement or the PROGRAM licensed herein, you agree to bring said claim only in the Illinois Court of Claims.

B. THIS AGREEMENT REPRESENTS THE COMPLETE AND EXCLUSIVE STATEMENT OF THE AGREEMENT BETWEEN GREENSOCK AND YOU AND SUPERSEDES ALL PRIOR AGREEMENTS, PROPOSALS, REPRESENTATIONS AND OTHER COMMUNICATIONS, VERBAL OR WRITTEN, BETWEEN THEM WITH RESPECT TO USE OF THE PROGRAM. THIS AGREEMENT MAY BE MODIFIED ONLY WITH THE MUTUAL WRITTEN APPROVAL OF AUTHORIZED REPRESENTATIVES OF THE PARTIES.

C. The terms and conditions of this Agreement shall prevail notwithstanding any different, conflicting, or additional terms or conditions which may appear in any purchase order or other document submitted by you. You agree that such additional or inconsistent terms are deemed rejected by GREENSOCK.

D. GREENSOCK and you agree that any xerographically or electronically reproduced copy of this Agreement shall have the same legal force and effect as any copy bearing original signatures of the parties.

I'd like to donate & get bonus plugins, update notifications, SVN access, and more.
To join Club GreenSock, you must agree to the following license:
Copyright 2009, GreenSock, Inc. 1936 Pleasant Ave. Saint Charles, IL 60174 NON-EXCLUSIVE SOFTWARE LICENSE AGREEMENT (1-DEVELOPER) This is a legal agreement between you (either an individual or a single entity) and GreenSock, Inc. ("GREENSOCK") for the proprietary GreenSock ActionScript code known as TweenLite, TweenMax, TweenNano, TimelineLite, TimelineMax, OverwriteManager, TweenProxy, TweenProxy3D, CustomEase, and LiquidStage (this code and documentation, as well as any updates which may at GREENSOCK's sole discretion be provided to you from time to time, are referred to in this Agreement as "PROGRAM"). By clicking the "I Agree" button, you agree to the terms and conditions of this Agreement. If you do not agree to the terms and conditions of this Agreement, please click "I Disagree". I. LICENSE Subject to the terms and conditions of this Agreement, GREENSOCK hereby grants you a non-exclusive, worldwide, non-transferable right to use the PROGRAM in commercial or non-commercial software applications including but not limited to: web sites, components, games, or any other software application. II. LIMITATION OF LICENSE AND RESTRICTIONS A. You agree that you will not sell, rent, or license the PROGRAM's source code or any derivative works thereof to any third party without the prior written consent of GREENSOCK. Derivative works are defined as modifications that add substantive functionality to the PROGRAM and do not include bug fixes or other minor modifications required to operate the PROGRAM as originally intended. Distribution of the source code as part of your Work Product is acceptable so long as the recipients agree to honor the terms of use set forth at http://www.greensock.com/terms_of_use.html. You agree not to modify or delete GreenSock's existing copyright notice located in the source code. You will not assign this Agreement, and any attempt by you to assign it shall be void from the beginning. B. You may use, duplicate, and distribute the compiled object code in a Work Product created by you, either for your own use or for distribution to a third party. C. You agree that at any given time, no more than 1 developer will be in possession of or have access to the PROGRAM's source code including employees, freelancers, contractors, consultants and any other developers associated with your organization. III. CONSIDERATION A. You agree to pay to GREENSOCK the following license royalties annually: $150.00 USD B. Your Club GreenSock Corporate membership along with this Agreement will be automatically renewed each year and you will be charged for the license royalties at the time of the renewal. Failure to pay such fees within 30 days of their due date constitutes a breach of the Agreement, causing the termination of your membership and this Agreement. You may cancel your membership anytime but refunds are only available for 30 days after payment is rendered each year. Cancelation of your corporate Club GreenSock membership terminates this Agreement. IV. TITLE AND OWNERSHIP A. The PROGRAM is licensed, not sold, and is protected by copyright laws and international treaty provisions. You acknowledge that no title to the intellectual property in the PROGRAM is transferred to you. You further acknowledge that title and full ownership rights to the PROGRAM, including all intellectual property rights therein, will remain the exclusive property of GreenSock and you will not acquire any rights to the PROGRAM except as expressly set forth in this Agreement. You agree that any copies of the PROGRAM you make will contain the same proprietary notices which appear on and in the PROGRAM. V. DISCLAIMER OF WARRANTY AND LIMITATION OF LIABILITY A. THE PROGRAM IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. GREENSOCK DOES NOT WARRANT THAT THE FUNCTIONS CONTAINED IN THE PROGRAM WILL MEET YOUR REQUIREMENTS OR THAT OPERATION WILL BE UNINTERRUPTED OR ERROR FREE. GREENSOCK shall not be liable for special, indirect, incidental, or consequential damages with respect to any claim on account of or arising from this Agreement or use of the PROGRAM, even if GREENSOCK has been or is hereafter advised of the possibility of such damages. Because some states do not allow certain exclusions or limitations on implied warranties or of liability for consequential or incidental damages, the above exclusions may not apply to you. In no event, however, will GREENSOCK be liable to you, under any theory of recovery, in an amount in excess of the license fee paid by you under this Agreement. Notwithstanding anything else in this agreement, you agree to indemnify GREENSOCK, its assignees, and licensees, and hold each of them harmless from and against any and all claims, demands, losses, damages, liabilities, costs, and expenses, including legal fees. B. GREENSOCK may, at its sole discretion, provide support services related to the PROGRAM, but has no obligation to do so. VI. TERMINATION If you at any time fail to abide by the terms of this Agreement, GREENSOCK shall have the right to immediately terminate the license granted herein, require the return or destruction of all copies of the PROGRAM from you and certification in writing as to such return or destruction, and pursue any other legal or equitable remedies available. VII. MISCELLANEOUS A. This Agreement shall be construed in accordance with the laws of the State of Illinois. Should you for any reason bring a claim, demand, or other action against GREENSOCK, its agents or employees, arising out of this Agreement or the PROGRAM licensed herein, you agree to bring said claim only in the Illinois Court of Claims. B. THIS AGREEMENT REPRESENTS THE COMPLETE AND EXCLUSIVE STATEMENT OF THE AGREEMENT BETWEEN GREENSOCK AND YOU AND SUPERSEDES ALL PRIOR AGREEMENTS, PROPOSALS, REPRESENTATIONS AND OTHER COMMUNICATIONS, VERBAL OR WRITTEN, BETWEEN THEM WITH RESPECT TO USE OF THE PROGRAM. THIS AGREEMENT MAY BE MODIFIED ONLY WITH THE MUTUAL WRITTEN APPROVAL OF AUTHORIZED REPRESENTATIVES OF THE PARTIES. C. The terms and conditions of this Agreement shall prevail notwithstanding any different, conflicting, or additional terms or conditions which may appear in any purchase order or other document submitted by you. You agree that such additional or inconsistent terms are deemed rejected by GREENSOCK. D. GREENSOCK and you agree that any xerographically or electronically reproduced copy of this fully-executed agreement shall have the same legal force and effect as any copy bearing original signatures of the parties.

TweenLite – A Lightweight, FAST Tweening Engine

  • Version: 11.12, Updated 11/25/2009
  • File size added to compressed SWF: about 4.7kb

What's new in v11?
v11 represents the biggest update to the platform ever, by far. Please check out the official announcement page for details about the changes and new features.

Description

TweenLite is an extremely fast, lightweight, and flexible tweening engine that serves as the foundation of the GreenSock Tweening Platform. A TweenLite instance handles tweening one or more numeric properties of any object over time, updating them on every frame. Sounds simple, but there's a wealth of capabilities and conveniences at your fingertips with TweenLite. With plenty of other tweening engines to choose from, here's why you might want to consider TweenLite:

  • SPEED - TweenLite has been highly optimized for maximum performance. See some speed comparisons yourself at http://blog.greensock.com/tweening-speed-test/
  • Feature set - In addition to tweening any numeric property of any object, TweenLite can tween filters, hex colors, volume, tint, frames, and even do bezier tweening, plus LOTS more. TweenMax extends TweenLite and adds even more capabilities like repeat, yoyo, repeatDelay, timeScale, event dispatching, on-the-fly destination value updates, rounding and more. Overwrite management is an important consideration in a tweening engine as well which is another area where the GreenSock Tweening Platform shines. You have options for AUTO overwriting or you can manually define how each tween will handle overlapping tweens of the same object.
  • Expandability - With its plugin architecture, you can activate as many (or as few) features as your project requires. Write your own plugin to handle particular special properties in custom ways. Minimize bloat, and maximize performance.
  • Sequencing, grouping, and management features - TimelineLite and TimelineMax make it surprisingly simple to create complex sequences or groups of tweens that you can control as a whole. play(), pause(), restart(), or reverse(). You can even tween a timeline's currentTime or currentProgress property to fastforward or rewind the entire timeline. Add labels, gotoAndPlay(), change the timeline's timeScale, nest timelines within timelines, and lots more.
  • Ease of use - Designers and Developers alike rave about how intuitive the platform is.
  • Updates - Frequent updates and feature additions make the GreenSock Tweening Platform reliable and robust.
  • AS2 and AS3 - Most other engines are only developed for AS2 or AS3 but not both.

Getting started

If you're new to the GreenSock Tweening Platform, check out the "getting started" page. You'll be up and running in no time.

Documentation

Please view full ASDoc documentation here. For your convenience, the special properties are listed below as well, but to read up on all the methods and properties, definitely check the ASDocs.

Interactive demo - tweening basics

Special properties

You can pass any of the following special properties in through the constructor's "vars" parameter like new TweenLite(mc, 1, {x:100, delay:1.5, paused:true, onComplete:myFunction}) to control various aspects of the tween:

  • delay : Number - Number of seconds (or frames if useFrames is true) that should elapse before the tween begins.
  • paused : Boolean - Sets the initial paused state of the timeline (by default, tweens automatically begin playing)
  • useFrames : Boolean - If useFrames is set to true, the tween's timing mode will be based on frames. Otherwise, it will be based on seconds/time. NOTE: a tween's timing mode is always determined by its parent timeline.
  • ease : FunctionUse any standard easing equation to control the rate of change. For example, Elastic.easeOut. The Default is Quad.easeOut.
  • easeParams : Array An Array of extra parameters to feed the easing equation (beyond the standard first 4). This can be useful when using an ease like Elastic and want to control extra parameters like the amplitude and period. Most easing equations, however, don't require extra parameters so you won't need to pass in any easeParams.
  • immediateRender : Boolean Normally when you create a tween, it begins rendering on the very next frame (when the Flash Player dispatches an ENTER_FRAME event) unless you specify a delay. This allows you to insert tweens into timelines and perform other actions that may affect its timing. However, if you prefer to force the tween to render immediately when it is created, set immediateRender to true. Or to prevent a tween with a duration of zero from rendering immediately, set this to false.
  • overwrite : int Controls how (and if) other tweens of the same target are overwritten by this tween. There are several modes to choose from, but only the first two are available in TweenLite unless OverwriteManager.init() has been called (please see http://blog.greensock.com/overwritemanager/ for details and a full explanation of the various modes):
    • NONE (0) (or false)
    • ALL_IMMEDIATE (1) (or true) - this is the default mode for TweenLite.
    • AUTO (2) - this is the default mode if TweenMax, TimelineLite, or TimelineMax is used in the swf. (these classes automatically init() OverwriteManager if you haven't done so already)
    • CONCURRENT (3) (requires OverwriteManager)
    • ALL_ONSTART (4) (requires OverwriteManager)
    • PREEXISTING (5) (requires OverwriteManager)

    Example: TweenLite.to(mc, 1, {x:100, overwrite:0});

  • onStart : Function - A function that should be called when the tween begins (the tween won't necessarily be at the beginning when onStart is called. For example, if the tween is created and then its currentTime property is set to something other than zero, onStart will still get fired because it is the first time the tween is getting rendered.)
  • onStartParams : Array - An Array of parameters to pass the onStart function.
  • onUpdate : Function A function that should be called every time the tween's time/position is updated (on every frame while the tween is active)
  • onUpdateParams : Array - An Array of parameters to pass the onUpdate function
  • onComplete : Function - A function that should be called when the tween has completed. To sense when a tween has reached its starting point again after having been reversed, use onReverseComplete.
  • onCompleteParams : Array - An Array of parameters to pass the onComplete function
  • onReverseComplete : Function - A function that should be called when the tween has reached its starting point again after having been reversed
  • onReverseCompleteParams : Array - An Array of parameters to pass the onReverseComplete function

PLUGINS

Plugins allow you to expand the capabilities of TweenLite/Max by handling specific properties in unique ways. Each plugin is associated with a special property name and it takes responsibility for handling that property. For example, the FrameLabelPlugin is associated with the "frameLabel" special property so if it is activated it will intercept the "frameLabel" property in the following tween and manage it uniquely:

Actionscript:
  1. TweenLite.to(mc, 1, {frameLabel:"myLabel"});

If the FrameLabelPlugin wasn't activated, TweenLite would act as though you were trying to literally tween the mc.frameLabel property (and there is no such thing).

Activating a plugin requires a single line of code and you only need to do it ONCE in your application, so it's pretty easy. Simply pass an Array containing the names of all the plugins you'd like to activate to the TweenPlugin.activate() method, like this:

Actionscript:
  1. import com.greensock.plugins.*;
  2. TweenPlugin.activate([FrameLabelPlugin, ColorTransformPlugin]);

To make it even easier, I created the Plugin Explorer which writes the code for you. All you need to do is select the plugins and copy/paste the code from the bottom of the tool. It also shows interactive examples of each plugin and the assocaited code so that it's easy to see the correct syntax.

TweenLite does not activate any plugins by default, but TweenMax does. When a plugin is activated, it affects both TweenLite and TweenMax. You can activate plugins directly inside the TweenLite class if you prefer by commenting or uncommenting the necessary lines towards the top of the class (clearly labeled).

Sample AS3 code

NOTE: All sample code is in AS3, but the AS2 version works exactly the same except the property names may be different, like "_x" instead of "x", "_alpha" instead of "alpha", etc. And in AS3, alpha/scaleX/scaleY go from 0-1 whereas in AS2, _alpha/_xscale/_yscale go from 0-100. This has nothing to do with TweenLite/Max - it's just a change Adobe made in the AS3 language.

Actionscript:
  1. //import the GreenSock classes
  2. import com.greensock.*;
  3. import com.greensock.easing.*;
  4.  
  5. //tween the MovieClip named "mc" to an alpha of 0.5 over the course of 3 seconds
  6. TweenLite.to(mc, 3, {alpha:0.5});
  7.  
  8. //scale myButton to 150% (scaleX/scaleY of 1.5) using the Elastic.easeOut ease for 2 seconds
  9. TweenLite.to(myButton, 2, {scaleX:1.5, scaleY:1.5, ease:Elastic.easeOut});
  10.  
  11. //tween mc3 in FROM 100 pixels above wherever it is now, and an alpha of 0. (notice the vars object defines the starting values instead of the ending values)
  12. TweenLite.from(mc3, 1, {y:"-100", alpha:0});
  13.  
  14. //after a delay of 3 seconds, tween mc for 5 seconds, sliding it across the screen by changing its "x" property to 300, using the Back.easeOut ease to make it shoot past it and come back, and then call the onFinishTween() function, passing two parameters: 5 and mc
  15. TweenLite.to(mc, 5, {delay:3, x:300, ease:Back.easeOut, onComplete:onFinishTween, onCompleteParams:[5, mc]});
  16. function onFinishTween(param1:Number, param2:MovieClip):void {
  17.     trace("The tween has finished! param1 = " + param1 + ", and param2 = " + param2);
  18. }
  19.  
  20. //call myFunction() after 2 seconds, passing 1 parameter: "myParam"
  21. TweenLite.delayedCall(2, myFunction, ["myParam"]);
  22.  
  23. //use the object-oriented syntax to create a TweenLite instance and store it so we can reverse, restart, or pause it later.
  24. var myTween:TweenLite = new TweenLite(mc2, 3, {y:200, alpha:0.5, onComplete:myFunction});
  25.  
  26. //some time later (maybe in by a ROLL_OUT event handler for a button), reverse the tween, causing it to go backwards to its beginning from wherever it is now.
  27. myTween.reverse();
  28.  
  29. //pause the tween
  30. myTween.pause();
  31.  
  32. //restart the tween
  33. myTween.restart();
  34.  
  35. //make the tween jump to exactly its 2-second point
  36. myTween.currentTime = 2;

FAQ

  1. Is the new version of TweenLite backwards compatible with v10?
    The short answer is "yes, mostly", but I'd strongly encourage you to check out the official announcement page for details because a few things have changed.
  2. I don't want to use v11 - can I get a legacy copy of v10?
    Sure. But I do not plan to update previous versions. v10 was very stable and you can get it here: Download AS2 | Download AS3
  3. How do I activate extra plugins?
    Check out the Plugin Explorer above. Not only does it provide interactive examples of each plugin, but it also writes the activation code for you and shows how many kb the plugins will cost.
  4. How do I install the class? Do I have to import it on every frame?
    Please refer to the "getting started" page.
  5. Why do my tweens keep getting overwritten? How can I prevent that?
    By default, when you create a tween, TweenLite looks for all existing tweens of the same object and kills them immediately. However, you can add advanced management of overwriting (including AUTO overwriting of only overlapping properties) using the OverwriteManager class. Or pass "overwrite:false" in your tween's vars object to ignore overwriting completely (be careful).
  6. Can I set up a sequence of tweens so that they occur one after the other?
    Of course! That's precisely what TimelineLite and TimelineMax are for. But if file size is a big concern and you don't need all the fancy extras those tools offer, you could just use the delay property in TweenLite. Here's an example where we fade a MovieClip to an alpha of 0.5 over the course of 2 seconds, and then move it to a y coordinate of 300 over the course of 1 second:

    Actionscript:
    1. import com.greensock.TweenLite;
    2. TweenLite.to(mc, 2, {alpha:0.5});
    3. TweenLite.to(mc, 1, {y:300, delay:2, overwrite:false});

  7. Do the properties have to be in a specific order?
    Nope. So TweenLite.to(mc, 1, {x:100, y:200, alpha:0.5}) is the same as TweenLite.to(mc, 1, {alpha:0.5, y:200, x:100});
  8. Why are TweenLite and TweenMax split into 2 classes instead of building all the functionality into one class?
    1. File size. The majority of tweening doesn't require the extra features in TweenMax like setDestination(), timeScale, repeat, repeatDelay, etc. so TweenLite is perfectly sufficient. TweenLite prioritizes efficiency and small file size whereas TweenMax prioritizes a rich feature set.
    2. Speed. TweenLite is slightly faster than TweenMax because it requires less code, although you'd probably never notice any difference unless you're tweening multiple thousands of instances. See the speed test.
  9. Is there a way I can get code hinting and strict datatyping in the vars object I pass to TweenLite/TweenMax?
    Sure, I developed some utility classes to do just that. Learn more here.
  10. Do I have to purchase a license to use this code? Can I use it for commercial purposes?
    You may use the code at no charge in commercial or non-commercial web sites, games, components, applications, and other software as long as end users are not charged a fee of any kind to use your product or gain access to it. If your client pays you a one-time fee to create the site/product, that's perfectly fine and qualifies under the "no charge" license. If multiple end users are charged a usage/access/license fee of any kind, please simply sign up for a corporate Club GreenSock membership which comes with a special commercial license granting you permission to do so. See http://blog.greensock.com/club/ for details. Club GreenSock members get several nifty bonus plugins, classes, update notifications, SVN access, and more. Your donations keep this project going. Please see the licensing page for details on licensing.

Need help?

Feel free to post your question on the forums. You'll increase your chances of getting a prompt answer if you provide a brief explanation and include a simplified FLA file (and any class files) that clearly demonstrates the problem.

Donate
Author: Jack Doyle
Copyright 2009, GreenSock (This work is subject to the terms here.)

Comments (81) RSS

Posted by ian h on July 24, 2007

Hi,

This class is great, I have been using it extensively throughout my newest project. One thing I would like to do, which has given me problems, is something like:

TweenLite.to(fader, 2, {alpha: 0});
TweenLite.to(fader, 2, {alpha:1, delay: 2});

Just a fade out, and then back in. Is this the correct implementation, because it seems to do nothing.

Anyways, thanks again,
ian

Posted by jack on July 24, 2007

ian, keep in mind that by default, TweenLite will overwrite tweens of the same object (to avoid conflicts) unless you specify overwrite:false. So your second tween was overwriting your first one. It should be more like:

TweenLite.to(fader, 2, {alpha:0});
TweenLite.to(fader, 2, {delay:2, alpha:1, overwrite:false});

Good luck ian!

Posted by Doug on August 1, 2007

This class is fantastic. Much better than Tweener and better documentation too.

Posted by felix on August 7, 2007

bravo! this is load of functionality to squeeze into 2k!

I love the fact that it overwrites previous tweens on the same object by default. This means if you apply many tweens to the same object (for example a button color tween on rollover/rollout), you don’t start leaking memory due to piling up tween objects (which I think may happen using Tweener?)

Posted by dave on August 10, 2007

The class works great!
How can the params of the ‘ease:Elastic.easeOut’ be changed so the ‘bouce is either less or more of a bounce?

e.g. TweenLite.to(myMovie2, 1, {y:300, delay:4, ease:Elastic.easeOut, overwrite:false});

As above to make the easeOut less of a bounce?

regards,

Dave

Posted by jack on August 10, 2007

Dave, good news: the new release of TweenLite indeed supports passing extra parameters to your easing equation. You just need to use the special easeParams property, like:

TweenLite.to(my_mc, 2, {_x:200, ease:Elastic.easeOut, easeParams:[1.5, 2.45]});

Posted by John Battagline on August 13, 2007

I’m pretty new to flash, but I tried out TweenLite…and I love it already. It’s exactly what I’m looking for: powerful, lightweight, and miraculously easy to use.

Just wanted to say thanks.

Posted by Make on August 14, 2007

it´s a incredible job! :) thank u! it´s much clearer than the Tween class of AS3… :)

Make

Posted by Mike on August 22, 2007

Jack, I was wondering if it is possible include additional properties like Blur, etc?

This looks soo cool by the way, thanks for developing such an amazing resourrce!

Posted by jack on August 22, 2007

Mike, yes, absolutely you can tween filter effects like blurs, drop shadows, and a whole lot more with TweenLite’s “big brother” TweenFilterLite. It extends TweenLite, so the file size hit is incredibly small for the power it packs. You probably just didn’t notice the link to it on the TweenLite page. Check it out at http://www.tweenfilterlite.com. It’s available in AS2 and AS3 flavors.

Posted by snowboardfoo on August 30, 2007

Awesome, awesome, awesome.

I have been developing my own animation library for years and switching it over to AS3 is a pain for sure.

You’ve done a really great job so far, keep up the good work!

Posted by Kristofer on August 30, 2007

This is exactly what I was looking for. YOU ARE THE MAN!
Thank you for all your work.

Posted by Rick Jones on September 17, 2007

Excellent job fixing Macradobe’s tween problem. I kept banging my head thinking that I was doing something wrong when using Adobe’s Tween class, due to the tweens hanging on me. Found out that it is a current bug. You can read this blog here to see others who are experiencing this issue: http://alvinzhang.info/?p=4

Oh and btw sent you some cash for your hard work. Really do appreciate it.

Posted by Ken Carpenter on October 21, 2007

Hi Jack,

Just playing around with TweenLite and loving it so far. My mind if overflowing with ideas!

I tried to add both a “from” and a “to” tween to your second example with the text as shown below. I wanted to drop the words in the same way, but have them tween “to” a random color at the same time: You can drop this into your Sample_2.fla. Here is the code again:

//Drop the words into place
for (i = 1; i <= 7; i++) {
mc = this["word"+i+"_mc"];
// var color:int = (Math.random() * 0xFFFFFF) + 0xFF000000;
var color:int = 0xFF;
TweenLite.from(mc, 2, {y:mc.y – 140, autoAlpha:0, ease:Elastic.easeOut, delay:i * 0.35});
TweenLite.to(mc, 2, {tint:color, overwrite:false, delay:i * 0.35});
}

Posted by jack on October 22, 2007

Ken, You can do a TweenLite.to() and a TweenLite.from() on the same object BUT here’s the reason your tweens looked like they didn’t work (they actually did – just not the way you expected):

When you tween the tint (what used to be mcColor), it must factor in the alpha value because the ColorTransform affects it. For example, if you set a MovieClip’s alpha to 0.5 and then use a ColorTransform to make it 0xFF0000, the alpha will end up being 1 unless you factor in the alphaMultiplier. TweenLite tries to accommodate this by looking to see if the same TweenLite instance is also tweening alpha. If it is, it uses that alpha value in the alphaMultiplier, otherwise it uses the MovieClip’s current alpha. In your case, when the TweenLite.to() started to run, the alpha was zero, and since there was no alpha being tweened in that same instance, it used that “current” value so your MovieClips had an alpha of zero the whole time. It would be possible to add code to TweenLite to look through all the other tweens of an object to see if there are any other instances affecting the alpha, but I’ve resisted doing so because it would increase the Kb and slow things down slightly, not to mention there’s an easy workaround:

To get around it, all you need to do is make sure you tween the alpha in the same TweenLite as the tint, like so:

TweenLite.from(mc, 2, {y:mc.y – 140, autoAlpha:0, ease:Elastic.easeOut, delay:i * 0.35});
TweenLite.to(mc, 2, {tint:color, autoAlpha:100, overwrite:false, delay:i * 0.35});

Posted by dzedward on October 24, 2007

I’ve found the built in Tween class in AS3 to be inconsistent, I switched to your class, and have yet to have a problem. Excellent work I must say.

Posted by Brendan on October 26, 2007

Jack, I totally agree with your reasoning here and have implemented my own ENTER_FRAME event listener and it works great.

The code i’m using:

onStart:function(){container.addEventListener(Event.ENTER_FRAME, render)}, onComplete:function(){container.removeEventListener(Event.ENTER_FRAME, render)}

would you recommend using onStartParams/onCompleteParams to do this instead of the way i’m currently doing it?

Thanks for the help and the speedy reply!

Posted by jack on October 26, 2007

Brendan, that looks like a great solution! Thanks for sharing.

Posted by Steve on November 19, 2007

Hi Jack,

This thing is absolutely mind blowing!!

I’m trying to use TweenLite to make a masked movieClip that contains many thumbnails to scroll left/right (scrolling gallery).

Is there a way for me to set the codes to tween the movieClip 50 pixels to the left or right instead of moving it to a specific X value on the stage??

In other words, I want to make it so that each time a user click on either the PREV or NEXT button, the movieClip will tween 50 pixels to the left or to the right.

Thanks a million for sharing it!!

Posted by jack on November 19, 2007

Steve, all you need to do is put quotes around your values to make them relative. So to move your MovieClip 50 pixels to the left, you’d do:
TweenLite.to(my_mc, 2, {x:”-50″});

Posted by Ignazio on November 22, 2007

Hi,
I’m also trying this very good class.
How can I do a relative movement using a variable as value?

TweenLite.to(my_mc, 2, {x:”+offset″});
doesn’t work.

Posted by jack on November 22, 2007

Ignazio, you can use a variable for relative offsets by coercing it into a String, like:
TweenLite.to(my_mc, 2, {x:String(offset)});

Posted by Wondering on November 27, 2007

Hi jack, a little question.

Is there any way to set up a sequence of Tweens, and set it up so when the sequence of tweens is finished, it calls another function?

Lets say I have a Sprite full of movieclips which all individually motion-tween into place. when i move to a next section of the website, i have tweens set up that make all of the movieclips fly back out of the screen.

however, i want it so only once every Tween has finished, then the function will be called to load in the next section of the website.

the only thing i can think of is having all my Tweens onComplete each call some function, which counts a number, and when the number hits a certain amount, it calls my load function.

however, is there a more elegant way of doing this, or is that just about it?

Posted by jack on November 27, 2007

“Wondering”, sure, you certainly can set up a sequence of tweens and then call a function when they’re all done. The answer is simpler than you may think. Just use delays and then use the onComplete of the LAST tween in the sequence to trigger the function. Like so:

TweenLite.to(mc1, 2, {x:100});
TweenLite.to(mc1, 1, {y:100, delay:2, overwrite:false});
TweenLite.to(mc1, 3, {x:300, delay:3, overwrite:false, onComplete:onFinish});

function onFinish():void {
trace(”The sequence has finished!”);
}

Or you could use the TweenLite.delayedCall() to call a function after a set amount of time (when you know the tweens will be finished).

Or even better, check out TweenMax’s sequence() and multiSequence() methods! http://www.TweenMax.com

Posted by Aaron on December 3, 2007

Just wondering about bezier tweens. I cant seem to find any information about how to do it or even if they are supported. but everything else seems great and i use tween lite for pretty much everything i do now.

thanks

Posted by jack on December 5, 2007

Aaron, TweenLite doesn’t support bezier tweens at this point. One of the primary goals of the class is to keep it extremely lightweight, so I have to protect the file size diligently. But I just released TweenMax which does include that feature (and many more). check it out at http://www.TweenMax.com.

Posted by sean on December 14, 2007

I’m new to tweenlite and have yet to play with it (I will when I get some time), but was wondering if with tweenlite you still need to worry about garbage collection like you do with built-in AS3 tween class or if you put something in to handle this.
Thanks

Posted by jack on December 14, 2007

Sean, there’s no need to worry about garbage collection. It’s all built into the class. Just tween away to your heart’s content. Check out the speed test I whipped together and crank up the number of tweens – you should see that it scales very well and doesn’t bog down after a while (which you’d expect if there were garbage collection issues).

Posted by Matthew Wallace on December 18, 2007

Dude,

Thanks so much for this code. I use it on all my projects. I was one that used the Fuse Kit all the time but started doing all my projects in AS3 and this saves the day and works way better.

thanks

Posted by kneural on December 21, 2007

got it!, thank you so much jack! TweenLite is amazing and makes things so much easier. esp with. TweenLite.from and the “” relative values. saves me so much more time and brain power when writing code. Its light-weightness is just what i need!

Your the best!

Posted by Pierce on January 5, 2008

Jack,

Thanks for the great work; it’s been a life- and project-saver.

Posted by Scott Gibson on January 15, 2008

Just wanted to say that you have made my life so much easier – thanks so much for working so hard on it. Now if you can just apply this simplistic logic to textfield creation and formatting… or maybe a component library…

Posted by Jeroen on January 21, 2008

Jack,

I came across your class while searching around for fixes for the standard Tween class’s! It was a big relief to implement your class! Everything was going so much faster! I really like it and I certainly will use it in other projects too!

I’ve used it for a school-project. This is my first Flash-based website actually. Most of the site is self-study. I’m not a Flash pro (yet) :D I like the project, but I want to move on to bigger/better things!

Annyways, you can take a look when clicking my name, it’s not perfect, but I’m quite happy with it, knowing it was only three months ago that I used Flash for the first time!

Thanks for you great work! I’ve given it further to some friends from school, they were really exited! :)

Jeroen.

Posted by Justin on January 22, 2008

Bless your heart Jack.

I think this might offer everything I need. I especially like being able to add a delay before starting tweens, and it’s also great to see that this offers built in garbage collection so I don’t have to push my tweens to an array and then clear out the array every time.

Posted by Matthew on January 29, 2008

Jack, this is absolutely fantastic, just did some tests of my own, TweenLite as3 is even getting along really well with Papervision3D.

Would you ever consider implementing bezier functionality? Or adding an extended class that supports it? It’s the only reason we would have to need tweener over TweenLite now.

Posted by jack on January 30, 2008

Yep, Matthew, wish granted. Bezier tweening is now available in TweenMax :-)
http://www.TweenMax.com

Posted by David on February 11, 2008

I’m glad I found this tweening engine on google, I am new to actionscript and this makes things easy for me, thanks for all your hard work. I wanted to ask about tweening many items in a row. I have 6 movieclips that I tween one right after the other. After the tween completes, am I supposed to remove the tween from memory somehow to make upcoming events run smooth? Like my_mc = null; or something?

Posted by jack on February 11, 2008

Nope, David, you don’t need to worry about memory management or “garbage collection” tasks with TweenLite. It handles it all for you. Once a tween has finished (actually, within about 2 seconds), it’ll delete itself. Tween with reckless abandon. Go crazy.

Posted by ashim on February 20, 2008

Jack, this is absolutely brilliant. I even feel like going over old project to shift from my earlier engine. Wish I could convince clients to pay me for it.
I was wondering however, how hard it would be to extends this to allow pause and resume of Tweens. Haven’t started looking through your code yet as I’m really busy and more than a little scared to try. But maybe there was a reason you haven’t built this in.
Cheers, and thank you very much.

Posted by jack on February 21, 2008

Well, Ashim, I’ve got good news and bad news for you…

First the bad news: Since one of my top priorities is keeping file size down and speed up, I don’t plan to add pause/resume functionality to TweenLite. A lot of agencies and developers have standardized on TweenLite because it is very lightweight and nimble, so I feel an obligation to diligently guard the file size. Many other tweening engines have suffered from “feature bloat” over time and I’m trying to avoid that.

Now for the good news: TweenMax is exactly what you need. It’s available now at http://www.TweenMax.com

Same syntax, same core. Just a bunch of extra features like bezier tweening, pause/resume, isTweening(myObject), sequencing, and getTweensOf(myObject).

Posted by Ive on February 26, 2008

Great Job! I like TweenLite full hearted and it helps me a lot in craeting a AS3 game! It tooks me 10 mins to read and understand before I make my object moves!!

Thanks for this great engine!! Keep the good work!

Posted by Daniel on March 4, 2008

is it possible to only put 50% on the tint so that the whole object doesnt change colour?
thanks

Posted by jack on March 13, 2008

Daniel, TweenLite doesn’t tint to percents, but there are a few options you have:

1) Use TweenFilterLite to colorize it (using the ColorMatrixFilter). See the interactive sample at http://www.tweenfilterlite.com for more info. This can be a really cool effect, and it does allow for various percents (amount).

2) Sign up for Club GreenSock and to get the bonus ColorTransformProxy utility class I created for use in conjunction with TweenLite for tweening all the various ColorTransform-related properties, including redOffset, greenOffset, blueOffset, redMultiplier, greenMultiplier, blueMultiplier, tint, and even tintPercent and brightness!. Sign up at http://blog.greensock.com/club/

Posted by AmerSoft on March 17, 2008

Do you know what the loveliest thing is for me? (Beside its great features, free one)?
It is that you keep developing both AS2 & AS3 versions for both TweenLite , TweenFilterLite. This makes me depend on the same amazing twining class in both cases whether I want to develop a AS2 or AS3 project…

Thank you , you are live saver.

Posted by Antonio Lea on March 18, 2008

This is extremely useful. I really appreciate for making this available to public.

Posted by felixz on March 21, 2008

when applying this code, nothing happens…
this.soundChannel=this.sound.play();
TweenLite.from(this.soundChannel,2.5,{volume:0});

Posted by jack on March 21, 2008

felixz, I’m not exactly sure what your “this.sound” refers to, but I tried this and it worked perfectly:

var snd = new Sound();
snd.load(new URLRequest(”myMusic.mp3″));
this.soundChannel = this.snd.play();
TweenLite.from(this.soundChannel, 5, {volume:0});

Keep in mind, though, that this was a local test and I didn’t add any code that would wait to start the tween until the sound loaded (if you try this over a web connection, there will be some lag time in the MP3 load, and if you start the tween right away it might finish before the sound even loaded)

Posted by anoxamoon on March 26, 2008

TWEENLITE is the best thing that happened to me this year!

I JUST LOVE it…. I can’t get enough of it. I am making effects that would’ve been rendered impossible using other tween engines!

Posted by MadTea on March 28, 2008

Heya!

Just wanted to pop by and thank you for making my life easier. Tweenlite has been with me for a bit over 4 months now, and I’ve loved every second of time spent with its smooth algorithmic self. It makes me wobbly, but in a good way. ;)

So keep up the good work, it is well appreciated!

Cheers
MadTea

Posted by Andrew Merskin on March 28, 2008

Hey!

I had a quick question about killing tweens.

My problem is, I have TweenLite tweens in my ROLL_OVER, ROLL_OUT, and CLICK events. When I click on my object, it plays the tween inside of my CLICK handler, which has overwrite set to false. When I roll out of my object, the CLICK tween gets overwritten anyway.

I don’t have overwrite: false set on the ROLL_OVER, and ROLL_OUT tweens because I want them to overwrite each other when I roll over or roll out of the object, but I don’t want them overwriting my CLICK tween ever.

What can I do?

Thanks,
Andy

Posted by jack on March 31, 2008

Yeah, Andrew, that’s a unique challenge. Not impossible to overcome, though. You can selectively remove tweens with the complete() or removeTween() methods. You’d just need to keep track of your TweenLite instances to know which ones to delete. For example, maybe you store the ROLL_OVER and ROLL_OUT tweens in a variable and then kill it when necessary, kinda like:

var rollTween:TweenLite;
function onRollOver($e:MouseEvent):void {
TweenLite.removeTween(rollTween);
rollTween = TweenLite.to(my_mc, 1, {scaleX:1.2, overwrite:false});
}
function onRollOut($e:MouseEvent):void {
TweenLite.removeTween(rollTween);
rollTween = TweenLite.to(my_mc, 1, {scaleX:1, overwrite:false});
}
function onClick($e:MouseEvent):void {
TweenLite.to(my_mc, 1, {scaleX:2});
}

Posted by happyMan on April 30, 2008

wow. i was just starting to look at the liveDocs on the tween class with a heavy heart when i found this and my day got brighter. If i use this as much as i think i will i’ll be donating for sure. you just saved me a half days head scratching at least. thanks muchly.

Posted by Bentley on June 8, 2008

Thanks for the awesome tweening engine :D
I have been using the built-in tween class for ages, but recently (today :) ) changed to TweenLite.

Not only has it been extremely simple to use, but it’s also much faster (which initially surprised me, as I expected the less dynamic built-in class to be faster) and it’s great not having to work with garbage collection e.t.c.

Thanks again,
Bentley

Posted by xenix on June 24, 2008

Man this tween class saved me!!! Actionscript 3 Tween class should be as successful as TweenLite.. really disappointed in adobe…

Posted by Anony on July 26, 2008

Hi,

I like the tint feature, but what if I want my movieclip to only tint to a color just a little bit? Like I’m trying to let someone know their mouse is over it. My image turns bloodshot red, I’d like it to be just a tiny bit redder.

Posted by jack on July 27, 2008

Anony, you’ve got several options:

1) Use TweenFilterLite’s (or TweenMax’s) colorMatrixFilter to colorize your clip slightly, like:
TweenFilterLite.to(my_mc, 1, {colorMatrixFilter:{colorize:0xFF0000, amount:0.2}});

2) Use the ColorTransformProxy class I created as a membership benefit for all Club GreenSock members. It has a tintPercent property, so you can control how much of a tint your MovieClip gets. See http://blog.greensock.com/colortransformproxy/ for an interactive demo. Join Club GreenSock at http://blog.greensock.com/club/

Posted by furkan on July 30, 2008

This documentation is the best and useful docementation thanks jack.

Posted by viktor hesselbom on August 6, 2008

Hi,

Just wanted to say that I got really used to using the ActionScript 3.0 built-in Tween class and was sceptical at first when I got told it’s better to make the switch to a custom built.

But I had to look it up and when I found this class all I really needed to look at was the syntax and functionality and I was hooked! And the speed increase is just a neat bonus.

Expect some donations in a near future. ;)

Posted by Bryant Miano on October 3, 2008

This amazing. Thank you for your hard work and for sharing such an immensely useful tool!

Posted by Tomer on October 5, 2008

Amazing work. Seriously this has saved me so much time and effort, and I’m sure the same is for hundreds of other developers.

As soon as I get payed for this project I’m working on, I’ll be sure to donate.

Posted by Rob on October 23, 2008

Wow. Brilliant.

Was getting increasingly unhappy with the bloat of Adobe’s built-in Tweening class. Thanks so much. I get paid at the end of the month, will definately drop a donation in your paypal.

Posted by Agustin on October 24, 2008

I’m completely sold!!!
I’ve just tried replacing Adobe’s Tween for your TweenLite on some camera movements, and all of the sudden everything rendered ridiculously fast!!!
and I have been blaming away3D for ALL the slugishness… (still, having performance issues with the renderer) but man! it made a huge difference, I don’t care if it’s a few bites heavier and not strict typing, I just saved about 100 lines of code and that was just one of the camera’s Classes.

Oh, by the way… non-coding designers in my office appreciated the speed more than anyone else. Now they hate me for not showing them this sooner.

thanks for all. I’m blown away

Posted by snel on October 27, 2008

Class is really good. a lot better than Tweener and the documentation is really awesome

Posted by reaper on November 8, 2008

Wow
Wow
WOOOOOOOOOOOOOOOW!!!

Posted by grabek on November 25, 2008

the more I use it, the more I’m addicted to it!

and this time, addiction is not a bad thing!

Posted by Jeremy Glover on February 13, 2009

Thank you so much for this awesome code. It saves me a ton of time and is soooo efficient and flexible. Great work!

Posted by Sheena on February 14, 2009

Just saved me so much time trying to do the simplest thing from scratch. You are amazing! Thank you for taking the time to do this and share it with the rest of us, awesome work!

Posted by Sean on February 27, 2009

Great utility — I’m replacing Tweener with this in my code.

I guarantee I’ll be purchasing a license for this for my current and future products — good work!

Posted by FinancialServicesRenoNV on March 28, 2009

Greetings all members,

I would just like to say hello and let you know that I’m happy to be a member – been a lurker long enough :)

Hope to contribute some and gain some knowledge along the way….

Posted by AmerSoft on April 24, 2009

Congratulation Jack !! it was my real pleasure when I saw “Todd Perkins” the Flash specialist and Adobe Certified Instructor recommends your TweenLite as the “powerful and favorite tween engine” in his “Flash CS4 Professional OOP” video tutorial at Lynda.com:
http://www.lynda.com/home/DisplayCourse.aspx?lpk2=759
Yes , I vote with him too , your engine is the best , Thank you for sharing this great engine with us , YOU ROCK !! :)

Posted by Jk_ on June 12, 2009

Todd Perkins recommended your website and ever since I found it, I fell in love with your engine. Each day I discover something new, something which eases my life as a web-developer! Thank you very much for it.

Posted by Chris on July 8, 2009

I was having some issues with IE7 maxing out the CPU at 100% using the default Adobe Tweens – just swapped them out for TweenLite and literally doubled the performance! Now it spikes up to around 70% and drops to 5% between tweens – and that’s easily the worst performing browser. Excellent tween engine, I noticed an instant performance increase across all browsers. Good work!

Posted by Bauke Regnerus on July 11, 2009

The TweenLite class and all related classes are keep on getting better and better. Congratulations! Just hoping to see a amount value for the tint plugin in v11 just like in the old TweenFilterLite class.

Posted by Bauke on July 14, 2009

To correct myself, the tint ammount can be achieved with the colorTransform plugin. Thank you Jack for the e-mail, I really appriciate it!

Posted by Ben Fisher on September 4, 2009

Having only just discovered this engine I am very impressed!

So easy to use and very effective. A minute after download I had my movieclips dancing across the stage, all of my colleagues are in the process of installing it :)

I’ll harass my boss and see if we can allocate you some of the budget as a small donation!

Excellent work Jack.

Posted by Rich Brill on September 16, 2009

This is an incredibly easy to use Tweening platform!

I have used it for several Papervision3D projects and it has been more or less flawless so far.

Good work Jack!

R

Posted by Larry McCauley on September 22, 2009

I just wanted to say thank you for such an amazing class! It has really given me all teh elements I need in an easy to understand and use way to achieve what my imagination sees.

Greensocks rocks, and I am well grateful. Will donate when I can (credit crunch stuff).

Posted by Justin on September 27, 2009

Love your work man! Definitely my fav tweening platform!

Posted by Doug Burnett on October 22, 2009

Congrats on the new v11. Very exciting for the entire Tween Engine users community.

Posted by Hicham on October 27, 2009

Thank’s a million Jack you did a great job!

Posted by Bob on November 4, 2009

Jack-

You’re amazing. I love you for what you’ve done. You will be getting a donation shortly :) Stuff like this deserves money.