码迷,mamicode.com
首页 > 移动开发 > 详细

android按键复用

时间:2014-09-01 00:14:52      阅读:389      评论:0      收藏:0      [点我收藏+]

标签:android   style   blog   color   os   io   使用   div   cti   

  最近做android电视系统定制,上面安排我做一个按键板按键复用的功能:当电视的OSD菜单显示出来时按键板上的 ch+/ch- 复用为方向键上/下,vol+/vol- 复用为方向键 右/左。  OSD 菜单是使用一个Fragment实现,所以选择在 OSD 菜单显示(onResume)触发按键复用功能,在 OSD 菜单消失(onStop)时取消按键复用功能。实现的思路是合理的了,我们知道应用程序处理按键事件 KeyEvnet 通常是通过事件的keyCode值决定程序要做什么事,所以只需在处理按键函数 onKey,onKeyUp,onKeyDown 等处理按键事件前修改事件的keyCode值就可以实现按键的复用了,具体到这里就是把 KEYCODE_CHANNEL_UP/KEYCODE_CHANNEL_DOWN 改为 KEYCODE_DPAD_UP/KEYCODE_DPAD_DOWN 同样的把 KEYCODE_VOLUME_UP/KEYCODE_VOLUME_DOWN 改为 KEYCODE_DPAD_RIGHT/KEYCODE_DPAD_LEFT。 要在上面提到的函数前修改键值就需要用到 dispatchKeyEvent(KeyEvent event) 了,官方对该方法的解释是在按键事件被分发到窗口前将其拦截。好了闲话少说代码如下:  

 1 public boolean dispatchKeyEvent(KeyEvent event) {
 2         long downTime= event.getDownTime();
 3         long eventTime = event.getEventTime();
 4         int  action = event.getAction();
 5         int  code = event.getKeyCode();
 6         int repeat = event.getRepeatCount();
 7         int metaState = event.getMetaState();
 8         switch (code) {
 9         case KeyEvent.KEYCODE_CHANNEL_UP:
10                 event = new KeyEvent(downTime, eventTime, action, KeyEvent.KEYCODE_DPAD_UP, repeat, metaState);
11             break;
12         case KeyEvent.KEYCODE_CHANNEL_DOWN:
13             event = new KeyEvent(downTime, eventTime, action, KeyEvent.KEYCODE_DPAD_DOWN, repeat, metaState);
14             break;
15         case KeyEvent.KEYCODE_VOLUME_UP:
16             event = new KeyEvent(downTime, eventTime, action, KeyEvent.KEYCODE_DPAD_RIGHT, repeat, metaState);
17             break;
18         case KeyEvent.KEYCODE_VOLUME_DOWN:
19             event = new KeyEvent(downTime, eventTime, action, KeyEvent.KEYCODE_DPAD_LEFT, repeat, metaState);
20             break;
21         }
22 
23         return super.dispatchKeyEvent(event);
24     }

 

 

android按键复用

标签:android   style   blog   color   os   io   使用   div   cti   

原文地址:http://www.cnblogs.com/chxj/p/3948346.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!