Flex 自动获取焦点 监听全局键盘事件

 更新时间:2009年07月13日 00:03:02   作者:  
Flex 编程注意之自动获取焦点、监听全局键盘事件
这是《Flex第一步》QQ群里面一个朋友问我的问题,特此拿出分享一下。或许问题比较简单,还是将其记录一下比较好。
需求如下:
当AIR启动后,监听全局键盘事件,即this.addEventListener( KeyboardEvent.KEY_DOWN, keydownHandler );
运行后效果:
当AIR运行后,虽然正确监听了KeyboardEvent.KEY_DOWN event,但是必须要鼠标点击一下AIR才可以获取keydownHandler。
原因:
1、keydownHandler的获取需要监听的对象获得焦点,当mouse click AIR后,则相当于获取焦点。
2、只有当监听的对象获取焦点后,才能出接收到KeyboardEvent.KEY_DOWN event。
因此问题根结:
如何让监听对象自动获取焦点。
解决方案:(步骤)
1、
this.dispatchEvent( new MouseEvent( MouseEvent.CLICK ));
通过以上的方式即可让程序“自动点击”dispatchEvent的对象。
2、
获取焦点方式:
this.stage.focus = this; 

<s:WindowedApplication
xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/halo"
creationComplete="createCompleteHandler (event)">
private function createCompleteHandler( event : FlexEvent ) : void {
//监听ouseEvent.CLICK event
this.addEventListener( MouseEvent.CLICK, clickHandler );
//监听KeyboardEvent.KEY_DOWN
this.addEventListener( KeyboardEvent.KEY_DOWN, keyDownHandler );
}
private function clickHandler( event : MouseEvent ) : void {
this.stage.focus = this;
}
private function keyDownHandler( event : KeyboardEvent ) : void {
//TO DO
}
自动触发mouse click的代码:(以下代码在this.addEventListener( KeyboardEvent.KEY_DOWN, keyDownHandler );的下面)
var timer : Timer = new Timer( 100, 1 );
timer.addEventListener( TimerEvent.TIMER_COMPLETE, function ( event : TimerEvent ) : void {
event.target.stop();
dispatchEvent( new MouseEvent( MouseEvent.CLICK ));
});
timer.start();
之所以用timer来处理是因为当create complete后,直接使用dispatchEvent会发现stage尚未赋值,因此需要延时一段时间处理。
注意:以上代码适用于AIR,在Flex里面按照如下写法仍旧无法获取KeyboardEvent.KEY_DOWN event。
Flex里面是如何自动获取焦点、监听全局键盘事件的呢?
原因:
Flex由于有浏览器的包裹,因此当打开浏览器后,由于SWF尚未获取焦点,因此就算自动获取了焦点(dispatchEvent( new MouseEvent( MouseEvent.CLICK ));)也是没有意义的。
解决方法:
在嵌入SWF的html里面加入如下的功能:
<body onload="document.getElementById('swf id').focus()">
这句话的含义:当onload完毕后,自动设定SWF为焦点状态。
最后再按照AIR的写即可完成自动获取焦点、监听全局键盘事件。
由于代码比较少,因此就不放上demo了,以上的片段代码足以说明问题:)

相关文章

  • Flex dynamic 关键字的用法

    Flex dynamic 关键字的用法

    Flex dynamic 关键字使用实例代码。对于学习flex的朋友也许有所帮助。
    2009-05-05
  • Flex 非常实用的学习资料整理

    Flex 非常实用的学习资料整理

    对于学习flex 的朋友,绝对是个不错的一些资料,大家可以用ctrl+F搜索获取
    2009-01-01
  • 存取flex屏幕快照

    存取flex屏幕快照

    flex 屏幕快照实现代码
    2009-05-05
  • Flex addChild()方法注意事项

    Flex addChild()方法注意事项

    在Flex Application里,是不能直接用addChild添加Sprite,MovieClip等来自flash.display包里的类的。
    2009-08-08
  • Flex程序开发心得小结

    Flex程序开发心得小结

    和Flash的开发环境相比,Flex提供的组件库确实很诱人,但由于功能太全面,导致程序的体积大,有时候使用不当,可能会影响程序运行效率。
    2008-04-04
  • flex编程动态生成图像

    flex编程动态生成图像

    程序需求:动态生成柱形图,柱形条数不确定,柱形字段不确定
    2008-12-12
  • Flex clipContent 编程注意

    Flex clipContent 编程注意

    在做Flex项目的时候,碰到了一个修改,具体请看下面的原型图
    2009-07-07
  • Flex httpservice返回值类型和处理

    Flex httpservice返回值类型和处理

    这两天在考虑flex与后端java服务交互的问题。在采用BlazeDS的Remote Object方式,还是传统的http service方式之间徘徊了一段时间
    2009-02-02
  • Flex Flash的关系分析

    Flex Flash的关系分析

    最近看时学习Flex应用,开始对Flex和Flash的关系有些模糊,读了Oreilly的Programming Flex 2才算是明白些,现记下。
    2009-06-06
  • Flex Data Binding详解

    Flex Data Binding详解

    Data BindIng简单的说就是当绑定源属性发生变化时,Flex 会把绑定源变化后属性的值赋给目的物的属性。做到了数据同步。
    2009-09-09

最新评论