Flash AS 实例进阶 键值捕获实现代码

所属分类: 媒体动画 / Flash教程 阅读数: 96
收藏 0 赞 0 分享

  Flash 动画的交互性是通过鼠标和键盘进行,前面的章节讲的都是鼠标控制,本节开始接触键盘控制,响应键盘的方法有几种,但归根结底可以用一句通俗的话概括,就是程序运行中,发现哪个键被按下了,并执行相应的动作,这里介绍的是通过判断获取的键控代码值来实现键盘控制,还是老套路,使用一个这样的实例,这是去年作的一个练习, 就叫距离产生美吧。

  源文件下载

  点击查看动画效果<实例2-9 键盘控制

  基本思路

  ① 主场景中放置 2 个保持一定距离的 MC 。

  ②再放置一个空 MC 用来写脚本,当然,也可以写到前面的 MC 实例上,这样是便于阅读和理解脚本。

  ③按下↑↓←→键两个 MC 都向同方向运动,并始终保持固定的距离和前后关系,还要保持朝向和移动的方向的一致

  ④设定边线,不向线外运动。

  ⑤松开按键,两 MC 保持原始方向。

  新知识点


复制代码
代码如下:

onClipEvent (keyDown);// 影片的事件处理函数。触发的是按下按键事件 。
onClipEvent (keyUp) ; // 触发的是松开按键事件 。
Key.getCode() // 获得键值。

  本实例只用到了 4 个键值,但为全面了解,将一个别人所写最新教程的键控代码值和键常量表复制下来。

  

  图 2 — 2 键控代码

  

  图 2 — 3 键常量

  实例说明

  好象没什么需要说明,就是 QG 追 QM ,总也追不到。

  编写动作脚本

  ①在空 MC 上输入:

复制代码
代码如下:

onClipEvent (keyDown) {// 按键事件触发
  s = 1;
  if (Key.getCode() == 37) {// 条件为获取的键值为“ 37 ” 即“ ←”的键值。
    _root.qa.play();
    _root.qb.play();
    _root.qa._x -= s;
    _root.qa._xscale = -_xscale;// 令MC“ qa ”水平翻转
    _root.qb._xscale = _xscale;
    _root.qb._x = _root.qa._x-80;// 令MC“ qb ”水平位置到“ qa ”左边
  }
  if (Key.getCode() == 39) {// 条件为获取的键值为“ 39 ” 即“ →”的键值。
    _root.qa._xscale = _xscale;
    _root.qa.play();
    _root.qb.play();
    _root.qa._x += s;
    _root.qb._xscale = -_xscale; // 令MC“ qb ”水平翻转
    _root.qb._x = _root.qa._x+80; 令MC“ qb ”水平位置到“ qa ”右边
  }
  if (Key.getCode() == 38) {// 条件为获取的键值为“ 38 ” 即“ ↑”的键值。
    _root.qa._y -= s*2;
    _root.qb._y = _root.qa._y;
  }
  if (Key.getCode() == 40) {// 条件为获取的键值为“ 40 ” 即“ ↓”的键值。
    _root.qa._y += s*2;
   _root.qb._y = _root.qa._y;
  }
  if (_root.qa._x<100) {// 以下 4 条语句是限制边界
    _root.qa._x = 100;
  }
  if (_root.qa._x>430) {
    _root.qa._x = 430;
  }
  if (_root.qa._y<50) {
    _root.qa._y = 50;
  }
  if (_root.qa._y>320) {
    _root.qa._y = 320;
  }
}
onClipEvent (keyUp) {// 释放键触发
  _root.qa.stop();
  _root.qb.stop();
  if (_root.qa._x<_root.qb._x) {// 依据两个MC“qa”和“qb”的左右位置,确定翻转与否,而保证是相向而立。
    _root.qa._xscale = _xscale;
    _root.qb._xscale = _xscale;
  } else {
   _root.qa._xscale = -_xscale;
   _root.qb._xscale = -_xscale;
  }
}

  要点分析

  ① Key.getCode() == 37 可以写成 Key.getCode() == Key.LEFT ,“ Key.LEFT ”是与左箭头键的键控代码值 (37) 关联的常量,初学或需给别人看,用这样方式写好,直观明了,而直接用键值写能省点劲,我是那里省力写 这里费力说。

  ②这里 onClipEvent (keyDown) 结合 Key.getCode() == () 的脚本,事件触发是主体,而获取键值只是确定该有啥动作的的条件,不要以为 if (Key.getCode() == 37) { _root.qa.play(); }就可以有 _root.qa.play(); 的动作。

  小结

  响应键盘是游戏和课件中普遍应用的,什么物体运动呀 飞行呀,开炮放枪的,都需要键盘来实现人机交互, 根据学习进度的要求,本节只介绍了通过MC的按键事件触发和键值捕获的方法来实现键盘控制,也是比较简单实用的方法,咱们是不用招法多,好用就中。

  课后练习

  大改源文件,让一个Q满场乱跑,另一个Q由键盘控制去追,追上之后出现一个新画面,提示:没准辙的瞎跑当然要用随机函数,追上的语句就用我们学过的知识 用X.Y坐标值的差来判断, MC 的碰撞方法或碰撞检测的组件大家还没学 , 我也不会。范例效果:

  点击查看动画效果<练习2-9

  源文件

  查看全套"Flash AS 实例进阶教程"

更多精彩内容其他人还在看

Flash cs3绘制人物高级行走动画教程

本教程向大家介绍Flash cs3绘制人物高级行走动画效果,教程难度不是很大,绘制方法及过程介绍的也非常详细,教程很实用,转发过来,希望大家喜欢
收藏 0 赞 0 分享

Flash CS4来制作漂亮的气泡动画教程

本教程向脚本之家的朋友介绍用Flash CS4来制作漂亮的气泡动画,制作出来气泡真的很好看,制作效果是采用代码形式实现,觉得很不错,转发过来,感兴趣的朋友可以一起来学习
收藏 0 赞 0 分享

flash基础教程:帧、关键帧、空白帧概念及区别介绍

动画的产生是帧来实现的,那什么是帧?帧、关键帧和空白帧之间又有什么区别?本文就为大家介绍一下三者之间的关系
收藏 0 赞 0 分享

Flash教程:动画背景的绘制方法之透视篇(给新手)

Flash动画在网络上的广泛传播,已经成为上网一族喜闻乐见的一种艺术形式。动画背景的绘制方法有很多,也有很多表现方法。这里将结合透视学的基础知识向大家简单的介绍一下动画背景的绘制。
收藏 0 赞 0 分享

Flash AS入门教程:Flash AS3.0制作有年份有日期的时钟

本教程是向大家介绍利用Flash AS3.0制作有年份有日期的时钟,虽然制作时钟老套了点,但它确可以较全面地应用到时间日期和间隔等知识,仍不失为较好的入门练习,转发给大家,希望对大家有所帮助
收藏 0 赞 0 分享

Flash相册制作大师具体该如何使用 Flash相册制作大师使用教程

在本文中我们将会看到的是Flash相册制作大师的具体使用的方法
收藏 0 赞 0 分享

flash基础教程:混色器面板图文介绍

混色器面板是Flash中用于色彩处理的一个重要面板,熟练地使用该面板,可以帮助用户快速地完成色彩的填充,编辑出色彩丰富的图形。本教程为大家详细介绍一下混色器面板,希望对大家有所帮助
收藏 0 赞 0 分享

25个绝对让你应接不暇的Flash网站创意

在Web设计过程中,运用成熟的Flash技术可以把你任意想到的idea表现到产品页面中。这里为你整理发现了25个绝对让你应接不暇的 Flash网站创意,更好地体现网站的互动应用,同时可以让你大饱眼福,一起来欣赏吧
收藏 0 赞 0 分享

教你用Flash制作非常酷的二进制时钟动画

今天在这个教程中我们将学习用Flash做一个不同寻常的,但非常酷的时钟:一个二进制时钟,中间用到了代码,但介绍地很详细,相信很值得大家学习
收藏 0 赞 0 分享

Flash动画特效制作技巧:制作超酷的文字炸开动画效果

本教程向大家介绍Flash动画特效制作技巧,本实例是制作文字炸开的动画效果,制作效果非常酷,制作过程也比较简单,喜欢的朋友可以过来学习一下这种制作方法
收藏 0 赞 0 分享
查看更多