为什么要用TWEENLITE而不用ADOBE官方的TWEEN?
- 效率(这也是作者所标榜的TWEENLITE2大优点之一,呵呵,“标榜”这个词用得可能有点过了,不过人家确实有那个实力)这里有2者运行效率对比的例子:tweening-speed-test
- onComplete, onStart, onUpdate 等回调方法是TWEEN所没有的(TWEENLITE还可以往这些方法中传递任意个参数)
- 智能的alpha(当alpha达到0时,TWEENLITE会自动将对象的visible设为false)
- 在一次方法调用中就可以缓动多个属性
- 可以设置每一次缓动的延时(对有先后顺序的缓动很有效)
- 实现任何MovieClip/Sprite的变色效果非常简单
- 可以缓动MovieClip的声音
- 唯一的from()方法使你可以使用当前的属性值作为缓动的目标值
- 使用相关联的值
- 在一次方法调用中就可以缓动多个数组的值
- TWEENLITE默认会自动地覆盖同一个对象的缓动以免出现冲突(当然这个特性也是可以关闭的)
- 强大的delayedCall()方法使你可以随意设置延时和延时过后所调用的变量,甚至传递任意个数的参数
- TWEENLITE有一个更加powerful的大哥”TweenFilterLite”,而TWEEN只在孤军奋战…当TWEENLITE有什么搞不定的时候,直接去找他大哥…
用法:
TweenLite.to(target:Object, duration:Number, variables:Object);
Description:将target对象的属性从调用方法时的值缓动到variables中所指定的值
Parameters:
- target:要缓动的对象(这里注意类型是Object,并不仅仅是MovieClip和Sprite)
- duration:持续的时间(单位是秒)
- variables:一个Object,包含你想要缓动的所有属性(在TweenLite.from()方法中,这些变量表示的则是开始缓动时的值),如果你给某个属性加引号,它将关联到当前的值。例如y:”xxx”,无论你引号里指定多少,它只会缓动到当前的值或者从当前的值开始缓动(在TweenLite.from()方法中)
TweenLite.to(mc, 5, {x:"10", y:"20", ease:Elastic.easeOut});
TweenLite.to(mc, 5, {x:"20", y:"30", ease:Elastic.easeOut}); //2者效果是一样的(通常情况下是不需要加引号的)
特殊属性:
- delay:Number-延时几秒后开始缓动,这在有先后顺序的缓动效果中很有用
- ease:Function-应用在variables上的缓动函数,比如gs.easing.Elastic.easeOut。默认值是Regular.easeOut.当然你也可以应用CustomEase来定义自己的缓动函数(CustomEase属于收费内容)
- easeParam:Array-给缓动函数提供额外参数的数组。这在使用Elastic缓动函数时控制其他参数比图振幅和周期会非常有用(ADOBE官方文档中,Elastic.easeXX()方法是可以有6个参数的,但是在TweenLite中只提供4个参数,那么另外2个参数:周期和振幅就可以在这个数组中给定)。大部分的缓动函数是只有4个参数的,所以通常情况下是不需要传入easeParams参数的。
- autoAlpha:Number-效果和改变”alpha”值一样,但是多了一个特性:如果alpha最终变为0,则自动将visible设为false。同样如果autoAlpha的值大于0,则在开始缓动前会自动将visible设为true
- visible:Boolean-缓动效果结束时DisplayObject对象的visible属性
- volume:Number-缓动对象的SoundTransform属性(例如MovieClip/SoundChannel/NetStream等)
- tint:uint-改变DisplayObject对象的色调,设置一个要缓动到的16进制的颜色值(在from()函数中表示起始值)
- removeTint:Boolean-表示是否要取消一个应用在DisplayObject对象的tint属性
- frame:int-缓动MovieClip到指定的帧(在from()函数中表示起始帧)
- onStart:Function-在缓动开始时触发此方法
- onStartParams:Array-数组,装有传递给onStart方法的参数
- onUpdate:Function-当属性值发生改变时(缓动进行中的每一帧,每一秒)触发此方法
- onUpdateParams:Array-数组,装有传递给OnUpdate方法的参数
- onComplete:Function-在缓动效果结束时触发此方法
- onCompleteParams:Array-数组,装有传递给onComplete方法的参数
- persist:Boolean-如果设为true,在缓动效果结束时,TweenLite实例将不会被垃圾回收器自动回收。当然,persist为true的时候,这个缓动效果仍然可以被其他的缓动覆盖。默认值是false
- renderOnStart:Boolean-在调用TweenLite.from()函数并且还有一个延时的时候,如果想要让指定的起始属性值在延时结束之后才展现出来的话,将renderOnStart设为true,相反,如果设为false,在延时开始之时就会立即展现指定的起始属性值。默认值是false
TweenLite.from(mc, 5, {y:20, ease:Elastic.easeOut, delay:3, renderOnStart:false}); //mc会在y=20处停留3秒,然后在5秒内缓动到当前位置
TweenLite.from(mc, 5, {y:20, ease:Elastic.easeOut, delay:3, renderOnStart:true}); //mc会在当前位置置停留3秒,然后跳到y=20的位置开始缓动
- overwrite:Boolean-如果不想让这个缓动效果被应用在同一个对象上的其他缓动效果自动覆盖的话,请将这个值设为false
TweenLite.from(target:Object, duration:Number, variables:Object);
基本上同TweenLite.to()方法一样,唯一不同的是所指定的缓动的属性是起始值
TweenLite.delayedCall(delay:Number, onComplete:Function, onCompleteParams:Array);
提供一个简单的方法来实现在指定的秒数之后调用指定的方法(其作用相当于setTimeout()方法,如果单为了实现setTimeout的功能而给你的代码增加3K的重量,实在不值,但是如果项目中已经引入了TweenLite,使用这个方法是个不错的主意),可以传递任意个数的参数
Parameters:略…
TweenLite.killTweensOf(target:Object, complete:Boolean);
提供一个简单的方法来移除应用在对象上的所有缓动效果,可以指定是否立即强制结束
Parameters:
target:目标对象
complete:如果设为true,目标对象的缓动效果将会立即结束(缓动的属性直接变为缓动效果结束时的值,同时调用onComplete方法如果定义了的话),若设为false,同样会立即结束缓动效果 ,但是属性值将停留在当前缓动到的位置,onComplete函数也不会执行
TweenLite.killDelayedCallsTo(function:Function);
提供一个简单的方法来移除TweenLite.delayedCall方法中设置了的方法(其作用相当于clearTimeout)
Parameters:略..
TweenLite.removeTween(tween:TweenLite):void
回收指定的TweenLite的实例
Parameters:略.
示例:
import gs.TweenLite;import gs.easing.Back;
TweenLite.to(clip_mc, 5, {alpha:0.5, x:120, ease:Back.easeOut, delay:2, onComplete:onFinishTween, onCompleteParams:[5, clip_mc]});
function onFinishTween(parameter1_num:Number, parameter2_mc:MovieClip):void { //注意这里的参数,分别对应前面onCompleteParams数组中的类型,而不是Array型
trace("The tween has finished! parameters: " + parameter1_num + ", and " + parameter2_mc);
}
源码包中也有2个很不错的例子~包含了大部分的用法在里面
About TweenLiteVars
Jack Doyle在7月15日的更新中加入了类TweenLiteVars,目的是为了让人们可以在FB,FD,FDT等编辑器中可以使用代码提示而不用去记众多的属性,并且能提供更加严谨的数据类型控制。TweenLiteVars类可以在TweenMax源码包中找到。
TweenLiteVars的用法如下:
import gs.TweenLite;
import gs.utils.tween.TweenLiteVars;
import gs.easing.*;
var v:TweenLiteVars = new TweenLiteVars();
v.addProps("x", 300, false, "y", 100, true); //with addProps(), you can add up to 15 dynamic properties at a time. addProp() adds one at a time.
v.ease = Elastic.easeOut;
v.onComplete = myFunction;
TweenLite.to(my_mc, 2, v);
分享到:
相关推荐
TweenLite是一个高效的缓动类库,它在动画制作中扮演着重要的角色,尤其在处理复杂的Flash和AS3项目时。相比Adobe官方的Tween类,TweenLite具有诸多优势,使其成为许多开发者的首选。 1. 效率:TweenLite以其卓越的...
TweenLite 是一款高效、功能强大的AS3(ActionScript 3)缓动库,相较于Adobe官方的Tween类,它提供了更多的特性和...在AS3开发中,TweenLite是一个不可或缺的工具,它能够帮助开发者轻松实现复杂、流畅的视觉交互。
### TweenLite中文帮助文档知识点详解 #### 为什么选择TweenLite而非Adobe官方的TWEEN? - **效率提升**:TweenLite以其高效性能著称,作者强调这是其两大优势之一。通过对比测试,可以看出TweenLite在执行动画...
TweenLite是一款广泛应用于动画制作和页面交互的JavaScript库,它能轻松实现对象的平滑过渡效果,常用于网页和Web应用中的动态效果设计。...本中文手册将提供详细的示例和解释,帮助你快速上手并精通TweenLite的使用。
### tweenLite中文手册与参数说明 #### 一、为什么选择tweenLite? 1. **效率提升**:tweenLite在性能方面超越了Adobe官方提供的tween功能,这得益于其内部优化设计。通过以下链接可以查看具体性能对比示例:...
TweenMax 继承 TweenLite , 轻量,快速并增加了新的功能:比如 pause/resume, timeScale, event listeners, reverse(), restart(), setDestination(), yoyo, loop, rounding, 并且能够使用 progress 属性 跳到...
TweenLite中文文档提供了详细的指南,帮助开发者了解如何利用该库创建流畅的动画效果。 首先,TweenLite之所以优于Adobe官方的Tween,是因为其更高的性能和更多元化的功能。通过tweening-speed-test,你可以看到...
1. **平滑动画**:TweenLite能够帮助开发者创建流畅的CSS3、SVG、DOM元素以及JavaScript对象属性的过渡动画,使得页面元素的变化更加自然和吸引人。 2. **性能优化**:TweenLite以其高效的代码执行和内存管理著称,...
通过阅读提供的“FLASH TweenLite/TweenMax 帮助文档”,你可以详细学习如何使用这两个库,包括各种参数、方法和示例,进一步提升你的动画技能。文档中的实例和解释将帮助你更好地理解这些工具的强大之处,并将它们...
AS3缓动类Tweenlite的使用说明,帮助您更方便的使用TweenLite。
TweenLite是ActionScript 3(AS3)编程中的一款强大且高效的动画库,它使得在Flash平台上创建平滑、复杂的动画效果变得简单易行。这个压缩包中的TweenLiteExample文件很可能是包含了一些示例代码,用于展示如何在AS3...
TweenLite.as类TweenLite.as类TweenLite.as类TweenLite.as类TweenLite.as类
TweenLite是Flash动画开发中的一个强大工具,尤其在ActionScript 3.0环境下,它极大地简化了对象渐变动画的创建。这个压缩包"TweenLite在Flash中类包.rar"包含了一系列关于TweenLite的资源,包括动画实例和可能的源...
Tweenlite类库集合是针对ActionScript 3.0开发的一款高效、轻量级的缓动引擎,被广泛...这个压缩包中的“gs”文件可能包含了关于Tweenlite的源码、示例代码、教程文档等,对于深入理解和应用Tweenlite会非常有帮助。
此外,可能还会分享一些实际案例和最佳实践,帮助开发者掌握TweenLite的强大功能。 标签“源码”意味着你可以查看TweenLite的源代码,这对于理解其工作原理、学习动画库的构建方法,或者进行二次开发是非常有价值的...
此外,GSAP社区提供丰富的资源和示例,帮助开发者解决问题和提升技能。 总的来说,AS3版本的TweenLite动画类为ActionScript开发者提供了一套强大且灵活的工具,使他们能够轻松创建出专业级别的动画效果。无论是在...
TweenLite和TweenMax的核心功能就是这个,它们能够帮助开发者轻松地创建出从一个状态到另一个状态的平滑过渡,而无需手动编写复杂的帧动画代码。 TweenLite是一个轻量级的解决方案,适合简单的缓动需求。它可以缓动...