1.onKeyDown 方法

onKeyDown 方法是KeyEvent.Callback 接口中的一个抽象方法,重写onKeyDown 方法能够监听到按键被按下的事件,我们先看看onKeyDown方法的函数原型。

第一个參数为键值,手机中每个button都拥有一个全然独立的键值 通过按键键值就能够确定当前按下的是那一个按键。

第二个參数为按键事件,  该对象中保存着当前按键的全部信息 比方 按键发生的时间 按键发生的次数  按键发生的类型等等。

通过以上两个參数就能够拿到当前按键事件的所附带的一切信息。对太鼓达人游戏感兴趣的看Android研究之游戏开发太鼓达人游戏

返回值 为true的时候表示完毕了一次按键事件 这样回调方法就会处理一些事情,举一个简单的样例 我们在一个新activity中 代码中根本就没有重写onKeyDown这种方法但是点返回button的时候发现当前这个activity自己关闭了。这是为什么呢??

首先假设没有重写onKeyDown方法的话 父类就会默认调用自己的onKeyDown方法这样假设按下按键了父类就会返回true 所以回调方法系统会关闭当前activity ,假设说我们把onKeyDown的返回值直接写成false 这样系统就不知道你点击了返回键 回调方法也不会帮我们finish掉当前的activity。


1
2
3
4
5
    @Override
    public
boolean onKeyDown(int
keyCode,
KeyEvent event)
{
 
    return
super.onKeyDown(keyCode,
event);
    }

假设长按某一个按键的话 onKeyDown方法会重复调用 并非仅仅调用一次  直到松开该按键为止。

2.onKeyUp 方法



onKeyUp  方法和 onKeyDown 同属于KeyEvent.Callback 接口中的一个抽象方法 ,重写onKeyUp  方法能够监听到按键被抬起的事件,当然抬起的前提肯定是先被按下后才会被抬起,也就是说onKeyUp  方法假设运行那也肯定是先运行过 onKeyDown 方法。我们先看看onKeyUp 的函数原型。

它和onKeyDown 方法的原理全然一样 连參数都一样, 差别就是一个处理按下事件 一个处理抬起时间。


1
2
3
4
5
    @Override
    public
boolean onKeyUp(int
keyCode,
KeyEvent event)
{
        // TODO Auto-generated method stub
        return
super.onKeyUp(keyCode,
event);
    }

这里强调一下 因为android手机的种类越来越多所以不同厂商的手机的键值可能会不一样的,并且有些手机根本都没有按键  这样适配型就大打折扣,不可能每款手机都写以套代码吧,呵呵 ,所以如今普遍的游戏都是使用全触摸的形式在做开发,当然作为学习来说将我们能够先无论这个。

以下我给出一个简单demo说明一下

在View中需要监听按键的话必需在构造方法中给当前View 设置控制焦点 需要调用 setFocusable(true); 假设没有设置的话 onKeyDown 与onKeyUp 等跟按键有关的 永远无法监听到按键事件。 在onKeyDown 与onKeyUp 通过keyCode 的值就能够推断当前按下那一个按键 ,然后依据event 事件对象就能够拿到当前触发事件的时间等等。

代码中我在Activity 和View中同一时候重写onKeyDown 与onKeyUp方法,他们的调用顺序是先是调用自己定义View中的 onKeyDown 与onKeyUp方法  然后才是 调用Activity中的onKeyDown 与onKeyUp方法,所以我们能够在对应的方法中做出对应的事情。

在按键监听的这个activity中点击返回键  由于它重写方法 onKeyDown 与onKeyUp 所以返回值 会调用父类onKeyDown方法  return super.onKeyDown(keyCode, event); 这种话父类就会返回true 所以系统拿到返回事件后就直接帮我们把activity关闭掉了,假设把这一句改成false 我们当前的这个activity就不会被系统finish掉除非我们自己手动finish掉。
所以能够通过设置返回值的方式来拦截按键信息喔。

postInvalidate(); 方法就是通知UI线程重绘 也就是说我们调用 postInvalidate();  后 紧接着系统就会调用onDraw方法来刷新屏幕。

以下贴出代码


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
package
cn.m15.xys;
 
import
android.app.Activity;
import android.content.Context;
import
android.graphics.Canvas;
import android.graphics.Color;
import
android.graphics.Paint;
import android.os.Bundle;
import
android.view.KeyEvent;
import android.view.View;
import
android.view.Window;
import android.view.WindowManager;
 
public class
SurfaceViewAcitvity
extends Activity
{
 
    AnimView mAnimView
= null;
 
    @Override
    public
void onCreate(Bundle
savedInstanceState)
{
    super.onCreate(savedInstanceState);
    // 全屏显示窗体
    requestWindowFeature(Window.FEATURE_NO_TITLE);
    getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
        WindowManager.LayoutParams.FLAG_FULLSCREEN);
    // 显示自己定义的游戏View
    mAnimView
= new
AnimView(this);
    setContentView(mAnimView);
    }
 
    public
class AnimView
extends View
{
 
     String
mKeyDownEvent
= "点击键盘方向键";
    
String mKeyDownTime
= "";
     String
mKeyUpEvent =
"";
    
String mKeyUpTime
= "";
 
    
Paint mPaint
= null;
     /**
     * 构造方法
     *
     * @param context
     */
    public
AnimView(Context
context)
{
        super(context);
        mPaint
= new
Paint();
        /**设置控制焦点 **/
        setFocusable(true);
    }
 
    @Override
    protected
void onDraw(Canvas
canvas)
{
        /**显示内容**/
        mPaint.setColor(Color.WHITE);
        canvas.drawText(mKeyDownEvent,
100,
20,
mPaint);
        canvas.drawText(mKeyDownTime,
100,
40,
mPaint);
        canvas.drawText(mKeyUpEvent,
100,
60,
mPaint);
        canvas.drawText(mKeyUpTime,
100,
80,
mPaint);
        super.onDraw(canvas);
    }
 
    @Override
    public
boolean onKeyDown(int
keyCode,
KeyEvent event)
{
        switch
(keyCode)
{
        case
KeyEvent.KEYCODE_DPAD_UP:
        mKeyDownEvent
= "按下了上键";
        break;
        case
KeyEvent.KEYCODE_DPAD_DOWN:
        mKeyDownEvent
= "按下了下键";
        break;
        case
KeyEvent.KEYCODE_DPAD_LEFT:
        mKeyDownEvent
= "按下了左键";
        break;
        case
KeyEvent.KEYCODE_DPAD_RIGHT:
        mKeyDownEvent
= "按下了右键";
        break;
        case
KeyEvent.KEYCODE_DPAD_CENTER:
        mKeyDownEvent
= "按下了中键";
        break;
        case
KeyEvent.KEYCODE_1:
        mKeyDownEvent
= "按下了数字键1";
        break;
        case
KeyEvent.KEYCODE_3:
        mKeyDownEvent
= "按下了数字键2";
        break;
        case
KeyEvent.KEYCODE_7:
        mKeyDownEvent
= "按下了数字键7";
        break;
        default:
        mKeyDownEvent
= String.valueOf(keyCode);
        break;
        }
        mKeyDownTime
= "触发当前事件的时间为"
+ event.getEventTime();
        /**通知UI线程重绘**/
        postInvalidate();
        return
super.onKeyDown(keyCode,
event);
    }
 
    @Override
    public
boolean onKeyUp(int
keyCode,
KeyEvent event)
{
        switch
(keyCode)
{
        case
KeyEvent.KEYCODE_DPAD_UP:
        mKeyUpEvent
= "抬起了上键";
        break;
        case
KeyEvent.KEYCODE_DPAD_DOWN:
        mKeyUpEvent
= "抬起了下键";
        break;
        case
KeyEvent.KEYCODE_DPAD_LEFT:
        mKeyUpEvent
= "抬起了左键";
        break;
        case
KeyEvent.KEYCODE_DPAD_RIGHT:
        mKeyUpEvent
= "抬起了右键";
        break;
        case
KeyEvent.KEYCODE_DPAD_CENTER:
        mKeyUpEvent
= "抬起了中键";
        break;
        case
KeyEvent.KEYCODE_1:
        mKeyUpEvent
= "抬起了数字键1";
        break;
        case
KeyEvent.KEYCODE_3:
        mKeyUpEvent
= "抬起了数字键2";
        break;
        case
KeyEvent.KEYCODE_7:
        mKeyUpEvent
= "抬起了数字键7";
        break;
        default:
        mKeyUpEvent
= String.valueOf(keyCode);
        break;
        }
 
        mKeyUpTime
= "触发当前事件的时间为"
+ event.getEventTime();
        /**通知UI线程重绘**/
        postInvalidate();
        return
super.onKeyUp(keyCode,
event);
    }
    }
 
    @Override
    public
boolean onKeyDown(int
keyCode,
KeyEvent event)
{
 
    return
super.onKeyDown(keyCode,
event);
    }
    @Override
    public
boolean onKeyUp(int
keyCode,
KeyEvent event)
{
        // TODO Auto-generated method stub
        return
super.onKeyUp(keyCode,
event);
    }
}

整体来说这章内容还是比較简单的,老规矩每篇文章都会附带源码,最后假设你还是认为我写的不够具体 看的不够爽 不要紧我把源码的下载地址贴出来 欢迎大家一起讨论学习。

源代码下载:Android_keyEvent

Android研究之游戏开发处理按键的响应的更多相关文章

  1. Android研究之游戏开发摄像头更新

     游戏中摄像头的原理介绍        在游戏开发中更新摄像头的位置能够决定屏幕显示的内容,尤其是RPG类游戏摄像头有着很关键的数据.我举一个样例 有时候我们在玩RPG游戏的时候进入一个新的场景 ...

  2. Android安卓手机游戏开发

    成都传智播客Java培训,免费学Android安卓手机游戏开发,安卓android开发课程包括Android安卓应用开发和Android安卓游戏开发两个方向,可是偏向游戏开发. 依据"199 ...

  3. Android——Cocosd2d-x手机游戏开发学习思路

    手机APP应用如雨后春笋般冒了出来,而在众多的APP应用中,游戏占据了半壁江山.它丰富着人们的业余生活,增进了人们之间的沟通交流.也有许多开发的朋友对游戏开发情有独钟,他们不止是享受着有很多的人们去下 ...

  4. Coco2d-x android win7 Python 游戏开发环境的搭建

    1:我用的电脑配置 win7 3 核 内存8G 桌面.一直想学习Coco2d 游戏开发,所以,一个星期后,需要找到,最终建立了一个良好的环境 2:我使用的版本号版本号,至于建筑android开发环境略 ...

  5. 基于Intel x86 Android的RAD游戏开发

    zip文件还包含编译的"MonkeyGame-debug".可以在模拟器中运行的二进制文件.在"game.build"文件夹中有一个HTML5 build.在C ...

  6. Android游戏开发研究帧动画实现

     1.动画的原则框架        帧的动画帧的动画顾名思义,画就是帧动画. 帧动画和我们小时候看的动画片的原理是一样的,在同样区域高速切换图片给人们呈现一种视觉的假象感觉像是在播放动画,事实上只 ...

  7. Android游戏开发研究与主角在地图滚动

     让人感动的地图过程平滑滚动         玩过rpg朋友应该都知道RPG的游戏地图一般都比較大 今天我和大家分享一下在RPG游戏中怎样来处理超出手机屏幕大小的游戏地图. 如图所看到的为程序效果 ...

  8. 【读书笔记《Android游戏编程之从零开始》】19.游戏开发基础(游戏音乐与音效)

    在一款游戏中,除了华丽的界面 UI 直接吸引玩家外,另外重要的就是游戏的背景音乐与音效:合适的背景音乐以及精彩的音效搭配会令整个游戏上升一个档次. 在 Android 中.常用于播放游戏背景音乐的类是 ...

  9. 【读书笔记《Android游戏编程之从零开始》】11.游戏开发基础(SurfaceView 游戏框架、View 和 SurfaceView 的区别)

    1. SurfaceView 游戏框架实例 实例效果:就是屏幕上的文本跟着点击的地方移动,效果图如下: 步骤: 新建项目“GameSurfaceView”,首先自定义一个类"MySurfac ...

随机推荐

  1. Linux下如何查看高CPU占用率线程 LINUX CPU利用率计算(转)

    Java 系统性能分析 命令 1. cpu分析 top , pidstat(sysstat) pid -p PID -t 1 10 vmstat 1 CPU上下文切换.运行队列.利用率 ps Hh - ...

  2. leetcode第一刷_Merge Sorted Array

    水题,只是思想还是实用的. 当然能够新建出一个数组.比較着拷贝过去.可是没有必要啊亲.想想为什么用源数组会麻烦,由于确定了前面的数.为了后面的数字不被覆盖,要依次往后移,转念一想,先确定后面的数字.就 ...

  3. gerrit git使用

    有关git的參考资料 pro git中文版, 最好的git书籍 http://git-scm.com/book/zh 图解git http://marklodato.github.com/visual ...

  4. IOS基金会_ UICollectionView简单易用

    和表格视图类似 UICollectionView的使用有两种方法 一种是继承UICollectionViewController,这个Controller会自带一个UICollectionView. ...

  5. HDU2159 研发费用背包

    主题链接:FATE 状态转移方程: dp[ren][num] =max(dp[ren-耐久值][num-1]+ 经验值,dp[ren][num]) dp表示:当前忍耐度ren下杀敌数为num的经验值 ...

  6. 中颖电子AD操作

    #define ADC_DIS 0 #define ADC_ENB 1 //ADC通道号定义 #define ADC_Chanel0 (unsigned char)(0x00<<1) #d ...

  7. 它们的定义actionbar 并删除留空

    通过他们自己的定义actionbar布局变化actionbar样式,简单而美丽.但有一个细节需要注意的是,高分辨率的问题留空.一般720上述决议,下一次你发现,无论什么样的变化总是会有一个小的布局文件 ...

  8. .NET反编译之Reflector基础示例

    这几日由于公司需要, 看了些.NET反编译技巧,特地和大家分享下 .NET反编译工具很多,Reflector是其中一个很优秀的工具,所以就用它来进行反编译工作了.今天我们就用"繁星代码生成器 ...

  9. Android特效 五种Toast具体解释

    Toast是Android中用来显示显示信息的一种机制,和Dialog不一样的是,Toast是没有焦点的,并且Toast显示的时间有限,过一定的时间就会自己主动消失. 1.默认效果: 代码: Toas ...

  10. MEF实现设计上的“松耦合”

    C#进阶系列——MEF实现设计上的“松耦合”(二)   前言:前篇 C#进阶系列——MEF实现设计上的“松耦合”(一) 介绍了下MEF的基础用法,让我们对MEF有了一个抽象的认识.当然MEF的用法可能 ...