Flash动画教程学习(三)--高级运动

第三部分 高级运动

第八章 缓动和弹性

  1. 缓动:越是靠近目标越慢

                            var vx:Number = (targetX - ball.x) * easing;

                            var vy:Number = (targetY - ball.y) * easing;

                            ball.x += vx;

                                ball.y += vy;

何时停止缓动?

If(Math.abs(dx)<1){

  Ball.x = target;

  removeEventListener(Event.ENTER_FRAME);

  trace(“done”);

}

跟随目标移动:

                            var vx:Number = (mouseX - ball.x) * easing;

                            var vy:Number = (mouseY - ball.y) * easing;

                            ball.x += vx;

                                ball.y += vy;

  1. 缓动不只是应用于运动:

透明度:ball.alpha += (targetAlpha-ball.alpha)*easing;

旋转:arrow.rotation += (targetRotation-arrow.rotation)*easing;

颜色:red += (redTarget - red)*easing;

  1. 弹性:(一维弹性)越是靠近目标越快(初始位置和目标位置保持一定距离,以便加速)

                            var dx:Number = targetX - ball.x;

                            var ax:Number = dx * spring;

                            vx += ax;

                                ball.x += vx;

加入摩擦值:

                            var dx:Number = targetX - ball.x;

                            var ax:Number = dx * spring;

                            vx += ax;

                            vx *= friction;//0.95

                                ball.x += vx;

二维弹性:带摩擦力

                            var dx:Number = targetX - ball.x;

                            var dy:Number = targetY - ball.y;

                            var ax:Number = dx * spring;

                            var ay:Number = dy * spring;

                            vx += ax;

                            vy += ay;

                            vx *= friction;

                            vy *= friction;

                            ball.x += vx;

                                ball.y += vy;

移动目标点的弹性:跟随鼠标弹动(将targetX更改为mouseX就OK了)

                            var dx:Number = mouseX - ball.x;

                                var dy:Number = mouseY - ball.y;

画出求与鼠标间的线:

                            graphics.clear();

                            graphics.lineStyle(1);

                            graphics.moveTo(mouseX, mouseY);

                                graphics.lineTo(ball.x, ball.y);

多目标点弹性:

利用函数调用、循环、数组实现

转载于:https://www.cnblogs.com/tinytiny/archive/2012/04/05/2432835.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值