当前位置:首页设计教程Flash AS3教程:帧循环学习实例
Flash AS3教程:帧循环学习实例
°
  • 素材类型: 资源-素材
  • 上传时间:

本例为Flash AS3.0菜鸟学飞系列教程,在上一讲中我们学习了含有多个类的AS3类文件的写法,在这一讲中我们来学习帧循环的运用,希望能给初学Flash AS编程的朋友带来帮助~~

本例为Flash AS3.0菜鸟学飞系列教程,在上一讲中我们学习了含有多个类的AS3类文件的写法,在这一讲中我们来学习帧循环的运用,希望能给初学Flash AS编程的朋友带来帮助~~

学习AS3菜鸟起飞吧之帧循环

多帧循环

Flash中的帧在默认情况下是循环执行的,租用gotoAndPlay()函数可以实现简单的帧循环,而实现代码的重复执行。
 gotoAndPlay()函数的用途是控制或改变影片剪辑的播放流程,如果在影片的第1帧画面中放置需要重复执行的程序,然后在第2帧加入gotoAndPlay(1)语句。反复执行第1帧画面的程序,那么gotoAndPlay()函数就构成了一个循环程序结构。
 gotoAndPlay()函数没有条件判断功能,是无条件重复的循环结构。但可以和if语句一起使用。形成具有判断终止条件功能的循环。

下面用帧循环制作匀速运动:

1、新建Flash文档
2、在图层1的第一帧创建一个实例名为mc的影片剪辑实例
3、新建as层,单击第1帧输入代码:

//得到mc的横坐标
  var dx:Number = mc.x;
//定义速度
  var speed:Number = 10;
4、在as层的第2帧插入空白帧,输入代码;
  //横坐标加上速度
dx += speed;
//设置mc的横坐标
  mc.x = dx;
5、在as层的第3帧插入空白帧,输入代码:
  //判断是否超出舞台边界
  if(dx < stage.stageWidth)
{
//跳到第2帧并播放
  this.gotoAndPlay(2);
//如超出舞台的右边界
 } else
{
//停止播放
 this.stop(); 
}

stage是Stage类的实例,Stage类有名为stageWidth的属性,表示舞台的宽度。

6、测试影片,可以看到影片实例会一直运动到舞台的右边界。

 从测试结果看,影片的运动并不流畅,这与帧频和帧循环结构有关。Flash默认帧频是12FPS,就是一秒播放12帧。上面的程序由于使用了帧跳转语句,实际需要每播放两帧才会执行第2帧的代码一次,这就是说第2帧的代码执行频率是6FPS,所以动画效果会显得不流畅。

图层结构图示:

Flash AS3教程:帧循环学习实例

上面的例子执行代码的速度只有帧频的一半,而且代码分散,不适合制作复杂的应用程序。我们可以利用enterFrame事件以帧频的速度执行代码,而且代码可以集中在一帧。

用enterFrame事件制作匀速运动:

1、新建Flash文档
2、在图层1创建一个实例名为mc的影片剪辑
3、新建as图层,单击第1帧,输入代码:

//动态更改帧频
  stage.frameRate = 30;
//获取mc初始位置
  var dx:Number = mc.x;
//定义速度
  var speed:Number = 5;
//注册侦听器
  mc.addEventListener(Event.ENTER_FRAME,onMove);
//定义事件接收函数
  function onMove(e:Event)
{
//坐标加速度
    dx += speed;
//影片剪辑的坐标
   e.target.x = dx; 
//如果影片运动到舞台右边界
   if(ds > stage.stageWidth)
{
//移除enterFrame事件
    mc.removeEventListener(Event.ENTER_FRAME,onMove);
}
}

代码使用了Event类的ENTER_FRAME属性,接收函数中参数e是Event类的实例,它具有target属性,target表示事件发送者mc。

进入论坛参与讨论:http://www.missyuan.com/viewthread.php?tid=425913

4、测试影片
使用enterFrame事件可实现代码的重复执行,它执行的速度与帧频有关。
提示:当不需要使用enterFrame事件时,一定要用removeEventListener()函数来删除enterFrame事件。

温馨提示:

文章标题:Flash AS3教程:帧循环学习实例

文章链接:https://www.4tu.cn/design/43638.html

更新时间:2024年09月02日

文章版权声明
1、本网站名称:思图创意
2、本站永久网址:https://www.4tu.cn
3、本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行删除处理。
4、本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
5、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报

本站资源大多存储在云盘,如发现链接失效,请联系我们我们会第一时间更新。本站仅提供信息存储空间,不拥有所有权,不承担相关法律责任。

给TA打赏
共{{data.count}}人
人已打赏
设计教程

Maya建模系列之教程立体字建模

2024-9-2 11:06:54

设计教程

3D MAX+PS练手制作V酷风格视觉照片效果

2024-9-2 11:07:04

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧