用flex开发互动应用的时候经常会遇到显示对象与键盘鼠标的互动响应,通常的做法是添加侦听器来检测输入事件:
package {
import flash.display.Sprite;
import flash.events.KeyboardEvent;
import flash.ui.Keyboard;
public class FlexTest extends Sprite
{
private var circle_sprite:Sprite;
private var isUp:Boolean;
private var isDown:Boolean;
private var isLeft:Boolean;
private var isRight:Boolean;
private const MOVE_SPEED:int=2;
public function FlexTest()
{
circle_sprite=new Sprite();
circle_sprite.graphics.beginFill(0xff0000);
circle_sprite.graphics.drawCircle(100,100,20);
circle_sprite.graphics.endFill();
addChild(circle_sprite);
stage.addEventListener(KeyboardEvent.KEY_DOWN,key_down);
}
private function key_down(evt:KeyboardEvent):void{
if (evt.keyCode==Keyboard.LEFT){
circle_sprite.x-=MOVE_SPEED;
}
if (evt.keyCode==Keyboard.RIGHT){
circle_sprite.x+=MOVE_SPEED;
}
if (evt.keyCode==Keyboard.UP){
circle_sprite.y-=MOVE_SPEED;
}
if (evt.keyCode==Keyboard.DOWN){
circle_sprite.y+=MOVE_SPEED;
}
}
}
}
以上实现,在使用过程中用方向键控制MC移动的时候为没有那么流畅,MC的移动明显有点卡,这是因为键盘按键如果一直按住不放,它也是间隔开来不断的重复触发按键事件,键盘的键值扫描有一定的间隔频率,因此产生了断断续续的感觉。
要想得到平滑的移动效果,可以通过添加事件侦听器侦听Event.ENTER_FRAME事件来解决
package {
import flash.display.Sprite;
import flash.events.Event;
import flash.events.KeyboardEvent;
import flash.ui.Keyboard;
public class FlexTest extends Sprite
{
private var circle_sprite:Sprite;
private var isUp:Boolean;
private var isDown:Boolean;
private var isLeft:Boolean;
private var isRight:Boolean;
private const MOVE_SPEED:int=2;
public function FlexTest()
{
circle_sprite=new Sprite();
circle_sprite.graphics.beginFill(0x0080c0);
circle_sprite.graphics.drawCircle(100,100,20);
circle_sprite.graphics.endFill();
addChild(circle_sprite);
stage.addEventListener(KeyboardEvent.KEY_DOWN,key_down);
stage.addEventListener(KeyboardEvent.KEY_UP,key_up);
stage.addEventListener(Event.ENTER_FRAME,enter_frame);
}
private function key_down(event:KeyboardEvent):void {
if(event.keyCode==Keyboard.UP){
isUp=true;
}
if (event.keyCode==Keyboard.DOWN) {
isDown=true;
}
if(event.keyCode==Keyboard.LEFT){
isLeft=true;
}
if(event.keyCode==Keyboard.RIGHT){
isRight=true;
}
}
private function key_up(event:KeyboardEvent):void{
if(event.keyCode==Keyboard.UP){
isUp=false;
}
if (event.keyCode==Keyboard.DOWN) {
isDown=false;
}
if(event.keyCode==Keyboard.LEFT){
isLeft=false;
}
if(event.keyCode==Keyboard.RIGHT){
isRight=false;
}
}
public function enter_frame(event:Event):void{
if(isUp){
circle_sprite.y-=MOVE_SPEED;
}
if(isRight){
circle_sprite.x+=MOVE_SPEED;
}
if(isDown){
circle_sprite.y+=MOVE_SPEED;
}
if(isLeft){
circle_sprite.x-=MOVE_SPEED;
}
}
}
}
- swf.rar (2.4 KB)
- 描述: 效果对比
- 下载次数: 533
分享到:
- 2008-02-15 14:15
- 浏览 3211
- 评论(1)
- 论坛回复 / 浏览 (0 / 6195)
- 查看更多
相关推荐
创建第一个Flex应用——设计模式创建第一个Flex应用——设计模式创建第一个Flex应用——设计模式
创建第一个Flex应用——编码模式创建第一个Flex应用——编码模式创建第一个Flex应用——编码模式
《精通Flex 3.0——基于ActionScript 3.0实现》一书源代码。 Flex 3.0 ActionScript 3.0源代码 Flex 3.0源代码。 --------------------------- 第1篇 Flex技术概述 第1章 Flex概述 3 1.1 Flex简介 3 1.2 Flex...
Flex游戏——水果乐园(含源码) 游戏介绍: * 通过键盘方向键控制小熊(游戏主人翁)在迷宫内行走,在指定时间内拾取所有水果就通过游戏否不通过。 * 每次拾取水果必须正确回答问题才能够真正获取水果。 * 游戏中有...
Flex.3事件机制(2)——Event对象视频Flex.3事件机制(2)——Event对象视频Flex.3事件机制(2)——Event对象视频
Flex教程系列之(四) AS3语法——面对对象编程 http://download.csdn.net/source/1161879 Flex教程系列之(五) AS3语法——静态常量继承和接口 http://download.csdn.net/source/1161921 Flex教程系列之(六) AS3...
是学习 ArcGIS Flex 最佳资料源码,供初级人学习使用
博文链接:https://hacker47.iteye.com/blog/235758
细细品味Flex——新Flex学习手册 技术齐全
FLEX——blazeDS原理.pdfFLEX——blazeDS原理.pdf
博文链接:https://hacker47.iteye.com/blog/182364
博文链接:https://hacker47.iteye.com/blog/182371
教程 博文链接:https://hacker47.iteye.com/blog/183081