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. Android Java汉字转拼音总结

    转载请表明出处:http://blog.csdn.net/lmj623565791/article/details/23187701 开发过程中有时候会遇到使用拼音模糊搜索等功能(典型的就是Andro ...

  2. CoreGraphics QuartzCore CGContextTranslateCTM 说明

    CoreGraphics.h 一些经常使用旋转常量 #define M_E 2.71828182845904523536028747135266250 e 
#define M_LOG2E 1.442 ...

  3. redmine忘记username和password

    环境: Ubuntu 13.10 bitnami-redmine-2.5.1-1-linux-x64-installer.run 用bitnami安装完redmine以后,有是否忘记了username ...

  4. ZOJ 3635 Cinema in Akiba[ 大规模阵列 ]

    门户:problemCode=3635">ZOJ 3635 Cinema in Akiba Time Limit: 3 Seconds      Memory Limit: 65536 ...

  5. 【Linux探索之旅】第二部分第二课:命令行,世界尽在掌握

    内容简介 1.第二部分第二课:命令行,世界尽在掌握 2.第二部分第三课预告:文件和目录,组织不会亏待你 命令行,世界尽在掌握 今天的标题是不是有点霸气侧漏呢? 读者:“小编,你为什么每次都要起这么非主 ...

  6. Android UI设计规则

    Android UI技巧 1.1 不该做什么 l  不要照搬你在其他平台的UI设计,应该让用户使用感觉是在真正使用一个Android软件,在你的LOGO显示和平台总体观感之间做好平衡 l  不要过度使 ...

  7. 360的IM可能会是什么样?

    尽管周鸿祎不止一次的说过,它不会进入IM领域,可是在360和QQ大战之后,很多用户 在卸载了QQ,寻找替代的IM工具的时候,发现他们非常难找到合适的替代IM工具,由于 好友非常难迁移.在用户的强烈 呼 ...

  8. 完全背包(南阳oj311)(完全背包)

    全然背包 时间限制:3000 ms  |  内存限制:65535 KB 难度:4 描写叙述 直接说题意,全然背包定义有N种物品和一个容量为V的背包.每种物品都有无限件可用. 第i种物品的体积是c.价值 ...

  9. UVA 11769 All Souls Night 的三维凸包要求的表面面积

    主题链接:option=com_onlinejudge&Itemid=8&page=show_problem&problem=2869">点击打开链接 求给定的 ...

  10. HDU 4391 Paint The Wall 段树(水

    意甲冠军: 特定n多头排列.m操作 以下是各点的颜色 以下m一种操纵: 1 l r col 染色 2 l r col 问间隔col色点 == 通的操作+区间内最大最小颜色数的优化,感觉非常不科学... ...