事件响应模型(游戏引擎、JAVA中等应用)
事件,我们在生活中时时在产生事件并且做出响应,如早晨出门时,看见外面下雨了,这时候我们需要带把伞等情况!
在现实生活之中事件分为人为事件和自然事件,那么在计算机操作系统中也不例外,存在两种事件
1.人为事件:自定义事件等(如游戏引擎中节点推动节点产生的一系列事件)
2.系统事件:计算器内部触发的事件(如键盘、鼠标等事件)
一、简单事件处理方案
网络上也可以看到很多文章说到被观察者和观察者,
小白:啊!大神,我是小白,不懂,说的是什么外星语
小白别急,一步一步咱们开始深入学习,先来看一张简单的图:

触发者一但发生事件则触发,就通知接收者进行响应,要想达到这个条件,那么必须要接收者给触发者一个联系方式,编程中叫回调函数,只要我们给触发者一个回调函数的地址,那么触发者有事件时就可以调用这个回调函数了,相当于给了个接口(联系方式),例如[接收者]给[触发者]一个电话号码一样,[触发者]有事情找[接收者]了,那么直接拨打这个电话号码就可以联系到[接收者]一样的道理!
那么我们就可以推出另外一张图了,如下:

如上图中显示,那么在实际应用当中,触发者和接收者太多太多,那么每个触发者都保存接收者的联系方式,这样的负担太重,例如上图中,【B接收者】假如产生了一个事件,【A接收者】对【B接收者】这个事件感兴趣,那么这个简单模型中,【B接收者】又需要保存【A接收者】的联系方式,越来越复杂了!
二、添加中间者【派发者】

为了更好地管理派送中心,仅仅联系方式还是显得有些简陋,我们在加上一个事件类型,这样更容易区别事件!
编辑中。。。。
#include <string>
#include <iostream>
#include <vector>
#include <map>
using namespace std;
#include <windows.h>
enum class EventType
{
NON = 1,
KEY_BOARD, // 键盘
MOUSE // 鼠标
};
// 监听者、观察者基类
class EventListener
{
public:
EventListener():m_Type(EventType::NON){ }
virtual EventType getType() { return m_Type; }
virtual void update() = 0;
protected:
EventType m_Type;
};
// [举例一]键盘事件
class KeyListener : public EventListener
{
public:
KeyListener()
{
this->m_Type = EventType::KEY_BOARD;
}
virtual void update() override
{
cout << "KeyListener upDate()" << endl;
}
};
// [举例二]键盘事件
class MouseListener : public EventListener
{
public:
MouseListener()
{
this->m_Type = EventType::MOUSE;
}
virtual void update() override
{
cout << "MouseListener upDate()" << endl;
}
};
// 派送中心
class EventDispatch
{
public:
EventDispatch() {
// 创建EventListener*数组并添加到map中
vector<EventListener*> *vec1 = new vector<EventListener *>();
vec1->reserve(20);
vector<EventListener*> *vec2 = new vector<EventListener *>();
vec2->reserve(20);
map_type_listener.insert(pair<EventType,
vector<EventListener*>*>(EventType::KEY_BOARD, vec1));
map_type_listener.insert(pair<EventType,
vector<EventListener*>*>(EventType::MOUSE, vec2));
}
void addListener(EventListener* e)
{
map<EventType, vector<EventListener*>*>::iterator iter;
if (e->getType() == EventType::KEY_BOARD)
{
iter = map_type_listener.find(EventType::KEY_BOARD);
//if (iter == map_type_listener.end()){
// vector<EventListener*> *vec1 = new vector<EventListener *>();
// map_type_listener.insert(pair<EventType,
// vector<EventListener*>*>(EventType::KEY_BOARD, vec1));
//}
}else if (e->getType() == EventType::MOUSE)
{
iter = map_type_listener.find(EventType::MOUSE);
//if (iter == map_type_listener.end()) {
// vector<EventListener*> *vec2 = new vector<EventListener *>();
// map_type_listener.insert(pair<EventType,
// vector<EventListener*>*>(EventType::MOUSE, vec2));
//}
}
vector<EventListener*>* eListener = iter->second;
eListener->push_back(e);
}
void dispatch()
{
map<EventType, vector<EventListener*>*>::iterator iter;
for (iter = map_type_listener.begin(); iter != map_type_listener.end(); iter++)
{
vector<EventListener*>* eListener = iter->second;
vector<EventListener*>::iterator it = eListener->begin();
for (it; it != eListener->end(); it++)
{
// 更新状态
(*it)->update();
}
}
}
private:
// map[key:事件类型 value:EventListener*数组的指针]
map<EventType, vector<EventListener*>*> map_type_listener;
};
// 游戏节点
class GameNode
{
public:
GameNode(EventDispatch* pEventDispatch):m_pEventDispatch(pEventDispatch){}
public:
EventDispatch* m_pEventDispatch;
};
EventDispatch dis;
int main()
{
KeyListener kListener;
MouseListener mListener;
GameNode node(&dis);
// 添加键盘监听事件
node.m_pEventDispatch->addListener(&kListener);
// 添加鼠标监听事件
node.m_pEventDispatch->addListener(&mListener);
while (true)
{
//dis.dispatch();
node.m_pEventDispatch->dispatch();
Sleep(5000);
}
system("pause");
return 0;
}
Java事件通知模型:
1.有事件添加到事件队列中;
2.取事件队列中的事件进行处理

事件响应模型(游戏引擎、JAVA中等应用)的更多相关文章
- 第1部分: 游戏引擎介绍, 渲染和构造3D世界
原文作者:Jake Simpson译者: 向海Email:GameWorldChina@myway.com ---------------------------------------------- ...
- AI:从游戏引擎--到AI
原文链接:http://blog.csdn.net/left_la/article/details/6358911#t9 这是我在Gameres上看到的一篇文章,文章很长,全文分为11个部分,看后感觉 ...
- Android游戏引擎总汇 原文出处:http://software.intel.com/en-us/blogs/2012/03/13/game-engines-for-android?page=1
随着Android系统的使用越来越广泛,了解一下Android平台下的游戏引擎就非常有必要.而同时因为基于Intel x86的移动设备越来越多,我也非常关注支持x86的移动游戏引擎.然而就目前为止游戏 ...
- cocos2d-x游戏引擎核心(3.x)----事件分发机制之事件从(android,ios,desktop)系统传到cocos2dx的过程浅析
(一) Android平台下: cocos2dx 版本3.2,先导入一个android工程,然后看下AndroidManifest.xml <application android:label= ...
- cocos2d-x游戏引擎核心之五——触摸事件和触摸分发器机制
一.触摸事件 为了处理屏幕触摸事件,Cocos2d-x 提供了非常方便.灵活的支持.在深入研究 Cocos2d-x 的触摸事件分发机制之前,我们利用 CCLayer 已经封装好的触摸接口来实现对简单的 ...
- 基于Java的开源3D游戏引擎jMonkeyEngine
jMonkeyEngine简介 jMonkeyEngine是一款纯Java语言编写的游戏引擎,继承了Java应用跨平台的特性,而且是开放源代码的,遵循BSD开源协议,BSD开源协议用一句简单的话概括就 ...
- java事件响应方法汇总(容器类监听、监听器类、AbstractAction、反射)
Java图形用户界面中,处理事件时所必须的步骤是: 1.创建接受响应的组件(控件)2.实现相关事件监听接口3.注册事件源的动作监听器4.事件触发时的事件处理 相应的可以通过以下的集中方式来作出事件响应 ...
- Java 3D游戏引擎——JME(java Monkey Engine)
转自:http://bbs.gameres.com/forum.php?mod=viewthread&tid=180732 JME(java Monkey Engine),一个非常棒的Java ...
- Python游戏引擎开发(五):Sprite精灵类和鼠标事件
本次来实现Sprite类和鼠标事件. 说起这个Sprite啊,涉及过2D游戏研究领域的看官应该都听说过它. 它中文原意是"精灵",只是在不同人的眼中,它所表示的意义不同. 比方说在 ...
随机推荐
- day0321 生成器
一.生成器 1.迭代器: 1.1.调用方法直接返回 1.2.可迭代对象通过执行iter方法得到 迭代器的优势:节省内存. 2.生成器:有些情况我们也需要也需要节省空间,只能是自己写来实现迭代器的功能就 ...
- iOS自定义结构体
一.提要 通过以官方的CGSize为例,自定义Objective-C中的结构体,并使用. 二.CGSize 1.系统定义的CGSize结构体 struct CGSize { CGFloat width ...
- day4_高效处理文件
read()将文件内容从磁盘中全部读出,放到内存,再给cpu处理,性能低,如果文件量大,很容易内存溢出或卡死. 高效方式: 方式一:一般不用的,代码行多 f = open('users.txt','r ...
- Linux 下安装JDK和jmeter 及环境配置记录过程
一.安装首先要查看linux系统的位数,用命令getconf LONG_BIT,我的是centOS 32位 二.官网下载32位的JDK8 http://www.oracle.com/technetwo ...
- Monkey简介及环境搭建(1)
简介:Monkey是Android SDK自带的测试工具,是一个命令行工具,可以运行在模拟器中或者实际设备中,它向系统发送伪随机的用户事件流(如按键输入,触摸屏输入,手势输入等),实现对正在开发的应用 ...
- Django + Redis实现页面缓存
目的:把从数据库读出的数据存入的redis 中既提高了效率,又减少了对数据库的读写,提高用户体验. 例如: 1,同一页面局部缓存,局部动态 from django.views import View ...
- git 用远程覆盖本地
git fetch --all git reset --hard origin/master
- python解析VOC的xml文件并转成自己需要的txt格式
在进行神经网络训练的时候,自己标注的数据集往往会有数据量不够大以及代表性不强等问题,因此我们会采用开源数据集作为训练,开源数据集往往具有特定的格式,如果我们想将开源数据集为我们所用的话,就需要对其格式 ...
- discuz优化10个小技巧
Discuz论坛是国内使用最多的论坛系统,现在最新版为X 3.4,X3.4 从 2018 年 1 月 1 日起只在官方 Git 发布,地址:https://gitee.com/ComsenzDiscu ...
- AsyncStorage和Promise配合使用
代码: AsyncStorage封装 import {AsyncStorage} from "react-native"; class DeviceStorage { //保存数据 ...