`
madfroghe
  • 浏览: 122168 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Flash/Flex学习笔记(34):弹性运动

阅读更多

动画中的弹性运动 从视觉效果上接近 物理经典力学中的单摆运动或弹簧(胡克定律F=Kx)振动

先看下面的模拟演示:

规律:
小球先从出发点(初始为最左侧)向目标点(中心点)加速狂奔,奔的过程中速度越来越大,但加速度越来越小,等经过目标点时,发现速度太大刹不住车(此时速度达到最大值,但加速度减为0),奔过头了!于是加速度发生逆转,从0开始变为负值,从而导致速度越来越小,等速度减到0时,也奔到了最右侧(此时负加速度也达到最大值),然后在负加速度的影响下,开始掉头又狂奔....这样不断下去,直接摩擦力让它筋疲力尽,最终瘫倒在目标点 :)

公式:胡克定律F=Kx,而合外力F根据牛二定律 F=ma,这二者结合起来换算一下,也就是 ma = kx,即a = (k/m)x .用代码体现出来,即加速度与位移成(正比)线性关系。


package {


import flash.display.Sprite;

import flash.events.Event;

import flash.events.MouseEvent;

import flash.geom.Rectangle;

 
import flash.ui.Mouse;

import flash.ui.MouseCursor;

 
public class Spring1 extends Sprite {

 
private var ball:Ball;

 
private var spring:Number=0.02;


private var targetX:Number=stage.stageWidth/2;

 
private var rect:Rectangle;

 
private var vx:Number=0;

 
private var isDragging=false;

 
public function Spring1() {


init();

 
}

 
private function init():void {


ball=new Ball(10);

 
addChild(ball);

 
ball.x=20;

 
ball.y=stage.stageHeight/2;

 
addEventListener(Event.ENTER_FRAME, onEnterFrame);


ball.addEventListener(MouseEvent.MOUSE_DOWN,MouseDownHandler);

 
ball.addEventListener(MouseEvent.MOUSE_OVER,function(){Mouse.cursor = MouseCursor.HAND});

 
ball.addEventListener(MouseEvent.MOUSE_OUT,MouseOutHandler);

 
stage.addEventListener(MouseEvent.MOUSE_UP,MouseUpHandler);

 
//画辅助线

 
graphics.lineStyle(1);

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

 
graphics.lineTo(stage.stageWidth-ball.x,ball.y);

 
graphics.moveTo(stage.stageWidth/2,ball.y-10);

 
graphics.lineTo(stage.stageWidth/2,ball.y+10);


rect=new Rectangle(ball.x,ball.y,stage.stageWidth-2*ball.x,0);


}

 
private function MouseOutHandler() {


if (! isDragging) {


Mouse.cursor=MouseCursor.AUTO;

 
}


}

 
//开始拖动

 
private function MouseDownHandler(e:MouseEvent):void {


ball.startDrag(true,rect);

 
Mouse.cursor=MouseCursor.HAND;

removeEventListener(Event.ENTER_FRAME, onEnterFrame);

isDragging=true;


}

 
//结束拖动

 
private function MouseUpHandler(e:MouseEvent):void {

 
ball.stopDrag();


addEventListener(Event.ENTER_FRAME, onEnterFrame);

 
Mouse.cursor=MouseCursor.AUTO;

 
isDragging=false;

 
}

 
private function onEnterFrame(event:Event):void {

 
var dx:Number = targetX-ball.x;


var ax:Number = dx*spring;//加速度与位移成正(反)比关系

 
vx += ax;

 
vx *= 0.97;//摩擦系数

 
trace(ax,vx);

 
ball.x+=vx;

 
}

 
}

 
}

上面演示是一维的弹性运动,当然也可以同时在x轴和y轴上进行

代码:

 
package {


import flash.display.Sprite;

 
import flash.events.Event;

 
import flash.events.MouseEvent;

 
import flash.ui.Mouse;

 
import flash.ui.MouseCursor;

 
public class Spring2 extends Sprite {

 
private var ball:Ball;

 
private var spring:Number=0.1;

 
private var targetX:Number=stage.stageWidth/2;

 
private var targetY:Number=stage.stageHeight/2;

 
private var vx:Number=0;

 
private var vy:Number=0;

 
private var friction:Number=0.95;

 
public function Spring2() {

 
init();

 
}

 
private function init():void {

 
ball = new Ball(5);

 
ball.x = Math.random() * stage.stageWidth;

 
ball.y = Math.random() * stage.stageHeight;         

 
addChild(ball);

 
addEventListener(Event.ENTER_FRAME, EnterFrameHandler);

 
stage.addEventListener(MouseEvent.MOUSE_DOWN,MouseDownHandler); 

 
MouseDownHandler(null);

 
Mouse.cursor = MouseCursor.BUTTON;

 
}

 
function MouseDownHandler(e:MouseEvent):void{

 
graphics.clear();

 
ball.x = Math.random() * stage.stageWidth;

 
ball.y = Math.random() * stage.stageHeight;

 
ball.vx = (Math.random()*2-1) * 50;


ball.vy = (Math.random()*2-1) * 50;


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

 
}

 
private function EnterFrameHandler(event:Event):void {

 
//去掉下面的注释,就变成鼠标跟随的弹性运动

 
//targetX = mouseX;

 
//targetY = mouseY;

 
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;


graphics.lineStyle(0.3,0xbbbbbb,1);

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

 
}

 
}

 
}

接下来:用代码模仿一根猴皮筋儿


package {


import flash.display.Sprite;

 
import flash.events.Event;

 
import flash.ui.Mouse;

 
import flash.ui.MouseCursor;

 
public class Spring3 extends Sprite {


private var ball:Ball;

 
private var spring:Number=0.1;

 
private var vx:Number=0;

 
private var vy:Number=0;


private var friction:Number=0.95;

 
public function Spring3() {

 
init();


}

 
private function init():void {

 
ball = new Ball(10);

 
addChild(ball);

 
addEventListener(Event.ENTER_FRAME, onEnterFrame);


Mouse.cursor = MouseCursor.HAND;

 
}

 
private function onEnterFrame(event:Event):void {

 
var dx:Number = mouseX-ball.x;

 
var dy:Number = mouseY-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;


graphics.clear();

 
graphics.lineStyle(1);          

 
graphics.moveTo(mouseX, mouseY);

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

 
}

 
}

 
}

上面的例子只有一个球,如果考虑更多的小球,第一球以鼠标所在位置为目标做弹性运动,而第二个以第一个球为目标做弹性运动,第三球又跟着第二个... 这会是什么效果呢?

 
package {

 
import flash.display.Sprite;

 
import flash.events.MouseEvent;

import flash.events.Event;

 
public class ArrayChain extends Sprite {

 
var arrBall:Array;      

 
var spring:Number=0.12;

 
var firstBall:Ball;

 
var gravity:Number=6;

 
var friction:Number=0.8;

 
public function ArrayChain() {          


init();

 
}

 
private function init():void {

 
arrBall=new Array(5);

 
for (var i:uint=0,j:uint=arrBall.length; i<j; i++) {

 
arrBall[i]=new Ball(10,Math.random()*0xffffff);


addChild(arrBall[i]);


}

 
firstBall=arrBall[0];

 
firstBall.x=Math.random()*stage.stageWidth;

 
firstBall.y=Math.random()*stage.stageHeight;    

 
addEventListener(Event.ENTER_FRAME,EnterFrameHandler);

 
}

 
private function EnterFrameHandler(e:Event):void {

 
//第一个球以鼠标所在位置为目标做弹性运动

 
firstBall.vx += (mouseX - firstBall.x) * spring;


firstBall.vy += (mouseY - firstBall.y) * spring;

 
firstBall.vy+=gravity;

 
firstBall.vx*=friction;

 
firstBall.vy*=friction;


firstBall.x+=firstBall.vx;

 
firstBall.y+=firstBall.vy;

 
//准备画连线


graphics.clear();

 
graphics.lineStyle(0.2,0x666666);

 
graphics.moveTo(mouseX,mouseY);

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

 
//后面的小球依次以前一个的位置为目标做弹性运动

 
for (var i=1,j=arrBall.length; i<j; i++) {


var ball:Ball=arrBall[i];

 
ball.vx += (arrBall[i-1].x-ball.x)*spring;


ball.vy += (arrBall[i-1].y-ball.y)*spring;

 
ball.vy+=gravity;

 
ball.vx*=friction;


ball.vy*=friction;

 
ball.x+=ball.vx;

 
ball.y+=ball.vy;

 
graphics.lineTo(ball.x,ball.y);//画出连线将各球连在一起


}

 
}


}

 
}

ok,我们得到了一个"弹簧链",当然这里面还考虑了重力的因素,通过上面的几个例子可以总结一下:第一个示例中一维弹性运动可以看作为x方向的加速度随位移的影响,而第二个示例可以看作是x,y二个方向加速度随位移影响的叠加,而第三个示例,则可以看作是任何方向这种影响再叠加重力的综合效果。总之:任何方向的弹性运动,都可以认为是该方向的加速度(或力)随位移的影响,而且这种影响可以在多个方向上叠加。下面这个是多点控制弹性运动的示例:

分享到:
评论

相关推荐

    Flash/Flex 框架应用 Cairngorm、Mate、PureMVC以及Swiz 的典型例子

    附件是关于 Flash/Flex 几个重要框架 Cairngorm、Mate、PureMVC以及Swiz 的典型例子,由 Tony Hillerson 提供 Homepage: http://insideria.com

    flex/Flash开发系列书籍:WEB3D应用研究

    flex/Flash开发系列书籍:基于FLASH的WEB3D应用研究

    flash/flex画曲线,绘图板

    在IT行业中,Flash/Flex是一种基于ActionScript编程语言和Adobe Flex框架的开发工具,用于创建交互式的、富媒体的Web应用程序。"Flash/Flex画曲线,绘图板"这个主题涉及的是如何使用这些技术来创建一个允许用户自由...

    RE/flex lexical analyzer generator:以正则表达式为中心的快速词法分析器生成器,用于C ++-开源

    语言:C ++许可证:BSD-3代码质量:A + https://lgtm.com/projects/g/Genivia/RE-flex/context:cpp文档:https://www.genivia.com/doc/reflex/html /index.html存储库:https://github.com/Genivia/RE-flex更改日志...

    [Flash/Flex] 使用css定义文本样式

    xmlns:s="library://ns.adobe.com/flex/spark" applicationStyleSheet="@Embed('path/to/your/styles.css')"&gt; ... &lt;/s:Application&gt; ``` 然后在`styles.css`中定义样式,如: ```css .myTextStyle { color: #FF...

    FDT-flash/flex devtoolkit for eclipse.

    **FDT - 一款强大的Flash/Flex开发工具集** FDT(Flash Development Tool)是一款专为Adobe Flash和Flex开发者设计的集成开发环境(IDE),它基于Eclipse平台,提供了高效、专业的开发工具和服务。FDT的出现极大地...

    flash/flex 的aqua皮肤

    在IT行业中,Flash/Flex是一种广泛使用的开发工具,主要用于创建交互式、富媒体的Web应用程序。Flex是基于ActionScript和MXML的开放源代码框架,它允许开发者构建可自定义的用户界面,而Flash则是其背后的动画和...

    FLEX安装方法 集成到eclipse中

    FLEX 安装方法 集成到 eclipse 中 ...* 汉化 FLEX 尤其是 FLEX/AIR 方面的中文资料 * 原创的关于 FLEX 的博客:http://liguoliang.com/ * Adobe 公司 FLEX 主页:http://www.adobe.com/cn/products/flex/

    Flex:登录

    标题“Flex:登录”指的是使用Adobe Flex技术实现用户登录功能的一种方法。Flex是Adobe公司推出的一款基于ActionScript的开源框架,主要用于...压缩包中的"Flex Login"可能包含示例代码或项目结构,供读者学习和参考。

    flex学习笔记 flex学习总结 flex学习教程

    Flex Builder(现已被Adobe Flash Builder取代)是一个集成开发环境,提供了代码提示、调试和项目管理等功能,使得开发更加高效。 3. **Flex组件库**:Flex提供了丰富的预定义组件,如Button、Label、Canvas等,可...

    RTMP直播例子--基于FLASH/FLEX(含源代码) 下载

    在这个“RTMP直播例子--基于FLASH/FLEX(含源代码) 下载”中,我们可以深入探讨RTMP直播的基本原理、FLEX编程以及如何在实际项目中应用这些技术。 首先,RTMP协议的工作原理是通过建立一个持久性的TCP连接,允许...

    解决flash/flex/as3 访问中文域名时的流错误示例

    在《潮汕IT男》网站的文章《解决flash/flex/as3 访问中文域名时的流错误》中,作者陈林生提供了详细的步骤和代码示例,帮助开发者理解和解决这个问题。文章地址是:[http://chenlinsheng.com/?p=990]...

    FLEX学习笔记

    《FLEX学习笔记》 FLEX,全称为Flex Builder,是由Adobe公司开发的一款基于MXML和ActionScript的开源框架,用于构建富互联网应用程序(RIA)。它允许开发者创建具有交互性、响应性和丰富用户体验的Web应用。FLEX的...

    Flex学习笔记.rar

    本压缩包“Flex学习笔记.rar”显然是一份针对初学者的教程资料,旨在帮助新接触Flex的开发者快速上手。 在“FlexBeginner.pdf”这份文档中,你可以期待找到以下关键知识点: 1. **Flex概述**:介绍Flex技术的基本...

    flex开源项目介绍.doc

    Flex开源项目介绍 Flex是一种用于构建富互联网应用程序(RIA)的开源框架,它基于ActionScript 3(AS3)编程语言和MXML标记语言。这些开源项目为开发者提供了丰富的组件库、工具和框架,帮助他们扩展Flex的功能,...

    4个简单的Flex例子(包含custom-class-mapping)共享

    总共有4个例子: 1.http://127.0.0.1:8080/flexDemo/HelloWorld/HelloWorld.html ...如果你的数据库配置和我的不一样,请修改flexDemo\WEB-INF\classes\下的DBSetting.properties文件,数据库建表的sql语句是user.sql

    flex4cookbook

    xmlns:s="library://ns.adobe.com/flex/spark" xmlns:mx="library://ns.adobe.com/flex/mx" creationComplete="app_creationCompleteHandler(event)"&gt; &lt;fx:Script&gt; &lt;![CDATA[ import mx.events.FlexEvent; ...

    flex actionscript学习笔记

    Flex ActionScript 学习笔记是关于使用Adobe Flex技术并结合ActionScript 3.0进行开发的知识总结。ActionScript 3.0是随着Flash CS3一起推出的一种强大的编程语言,相较于之前的ActionScript版本,它有着显著的提升...

    flex学习笔记,技巧学习

    根据提供的信息,我们可以总结出以下关于Flex学习笔记中的关键技术知识点: ### 1. Flex 基础设置 在Flex开发中,通常会涉及到基础样式的设置。例如,在给定的部分内容中提到了字体大小、颜色及背景色的设置。虽然...

    Flex与Java的交互

    Flex与Java的交互是跨平台应用开发中的常见技术组合,允许前端用户界面(UI)与后端业务逻辑进行高效沟通。在本文中,我们将深入探讨如何使用Flex 4与Java进行通信,并通过三种不同的方法实现这一目标:RemoteObject...

Global site tag (gtag.js) - Google Analytics