egret.Tween跳跃缓动效果实现

阅读: 评论:0

egret.Tween跳跃缓动效果实现

egret.Tween跳跃缓动效果实现

今日在工作中遇到一个需求:

  1. 要求目标组件能从一定高度落地并实现弹跳效果
  2. 落地后目标组件变矮变胖
  3. 弹起时目标组件变瘦变高
Tween使用

在实现此需求之前,先学习一下白鹭引擎的Tween。官方文档如是说:

class TweenTest extends egret.DisplayObjectContainer{public constructor(){super();this.addEventListener(egret.Event.ADDED_TO_AddToStage,this);}private onAddToStage(event:egret.Event){var shp:egret.Shape = new egret.Shape();aphics.beginFill( 0x00ff00 );aphics.drawRect( 0, 0, 100, 100 );dFill();shp.x = 50;this.addChild( shp );var tw = ( shp );tw.to( {x:150}, 1000 );}
}

如代码所示,每一个缓动对象是用 来的获得的,该方法需要传入用于缓动的目标对象,即例中的 shp ,然后通过 to 方法来给出需要设置缓动的具体参数。to 的第一个参数用于设置缓动属性以及目标值:例中的属性为 x ,目标值为 150,即会将 shp 从当前 x 坐标位置缓动到 x 坐标为 150;to 的第二个参数为缓动长度,单位为毫秒,例中的缓动长度为 1000毫秒,即 1 秒 。

var tw = ( shp, { loop:true} );      //循环
//在 Tween 执行过程中,也许我们逻辑需要实时做一些变化。
//跟踪这个过程同样可以通过在  的第二个参数中,加入变化事件处理函数的定义来实现。
var obj = { x:0 };var funcChange = function():void{console.log( this.x );
}( obj, { onChange:funcChange, onChangeObj:obj } ).to( {x:600}, 1000 , egret.Ease.backInOut );

对于缓动的控制,可以设定若干其他方法。主要有以下两个:

  1. call 在某个缓动过程结束时,可以用 call 产生一个回调,直接将回调函数作为参数传给call就可以了。
  2. wait 用于多个缓动连续设定中设置中间的等待时间,也是以毫秒为单位。
    ####最终实现如下
    如果想使用缓动动画,你需要使用 Tween 这个类。 Tween 中封装了最常用的缓动动画功能,包括动画时间设定,缓动动画控制, 缓动效果控制等等。
var tw = ( shp );         //捕获shp,shp为目标组件
tw.to( {scaleX:0.8, scaleY:1.1, y:50}, 1 )      //y方向缓动至50,横向变大0.8倍,纵向变大1.1倍,只用一毫秒 .to( {scaleX:1.1, scaleY:0.8, y:0}, 400).to( {scaleX:0.8, scaleY:1.1, y:50}, 400).to( {scaleX:1, scaleY:1, y:0}, 400);                 

本文发布于:2024-02-01 17:36:54,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170678124438339.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:效果   egret   Tween
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23