目前市面上的游戏外设,要么支持传统的DirectInput接口,要么支持最新的XInput技术。今天在这里聊一聊,如何通过XInput技术实现对这类游戏外设相关信息的捕获。关于DirectInput与XInput间的区别,可以参考 XInput和DirectInput文章。
 
相较于DirectInput来说,XInput在针对游戏外设编程时就简单明了很多,不需要太多繁琐的代码就可以轻松获得游戏外设的状态。
 
首先,在应用程序头文件中添加以下信息,代码如下:
#include <XInput.h>
#include "afxwin.h"
#pragma comment(lib, "XInput.lib")

在应用程序类当中,定义一个手柄状态量,代码如下:

public:
XINPUT_STATE m_ControllerState;

通过XInputGetState函数来获取支持XInput接口的游戏外设信息,同时通过该函数的返回值信息来判断当前是否有支持XInput接口的游戏设备接入当前操作系统。

ZeroMemory(&m_ControllerState, sizeof(XINPUT_STATE));
if(XInputGetState(, &m_ControllerState) != ERROR_SUCCESS)
{
MessageBox(_T("No Controller Connected!"));
}

在一个定时器或者线程里面,可以通过判定XINPUT_STATE相关成员的值来识别相关按键是否被按下,代码如下:

XINPUT_GAMEPAD gamepad;
CString temp;
while(XInputGetState(, &(m_ControllerState)) == ERROR_SUCCESS)
{
gamepad = m_ControllerState.Gamepad;
// gamepad.sThumbLX
// gamepad.sThumbLY
// gamepad.bLeftTrigger
// gamepad.bRightTrigger
// gamepad.wButtons & XINPUT_GAMEPAD_DPAD_UP
// gamepad.wButtons & XINPUT_GAMEPAD_DPAD_DOWN
// gamepad.wButtons & XINPUT_GAMEPAD_DPAD_LEFT
// gamepad.wButtons & XINPUT_GAMEPAD_DPAD_RIGHT
// gamepad.wButtons & XINPUT_GAMEPAD_START
// gamepad.wButtons & XINPUT_GAMEPAD_BACK
// gamepad.wButtons & XINPUT_GAMEPAD_LEFT_SHOULDER
// gamepad.wButtons & XINPUT_GAMEPAD_RIGHT_SHOULDER
// gamepad.wButtons & XINPUT_GAMEPAD_A
// gamepad.wButtons & XINPUT_GAMEPAD_B
// gamepad.wButtons & XINPUT_GAMEPAD_X
// gamepad.wButtons & XINPUT_GAMEPAD_Y
}
至此,所有XInput针对游戏外设的编程关键点已经水落石出。

如何通过XInput技术针对游戏方向盘或者手柄编程的更多相关文章

  1. 如何通过DirectInput技术针对莱仕达雷驰V3II游戏方向盘编程

    三自由度的动感座椅可以让玩游戏人员在玩的过程中随座椅一起晃动,通过应用程序对方向盘动作的抓取来实现体感,动作类型主要分为加速(后仰,对应踩油门).减速(前倾,对应踩刹车 ).左转(向左打方向盘).右转 ...

  2. 原创教程“ActionScript3.0游戏中的图像编程”開始连载啦!

            经过近两年的不懈努力,笔者的原创教程"ActionScript3游戏中的图像编程"最终在今日划上了完美的句号!这其中记录着笔者多年来在游戏制作,尤其是其中图像处理方 ...

  3. 动态弹球的实现 加入了多线程技术--javaSE游戏准备工作

    任务描述:实现了动态弹球的功能,对于有弹球功能的SE游戏奠定了基础. package 运用线程技术的小球; import java.awt.*; import java.awt.event.*; im ...

  4. 锐动SDK针对游戏直播提出的解决方案

    方案架构 PC端视频直播与录播功能为游戏厂商宣传,玩家个人秀,大型电竞赛事提供完美的技术解决方案. 直播形式灵活多变不,同音源的选择,画面切换,游戏中嵌入摄像头丰,富解说画面.突出主播个人魅力与粉丝形 ...

  5. UnrealEngine4针对游戏模式的思考

    游戏能够概括为三类:单进程联机(超级玛丽).小规模联机(魔兽争霸.CS),大规模联机(魔兽世界). watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvZmx1c ...

  6. 大数据技术之_16_Scala学习_04_函数式编程-基础+面向对象编程-基础

    第五章 函数式编程-基础5.1 函数式编程内容说明5.1.1 函数式编程内容5.1.2 函数式编程授课顺序5.2 函数式编程介绍5.2.1 几个概念的说明5.2.2 方法.函数.函数式编程和面向对象编 ...

  7. 3D游戏引擎一 win32编程

    Windows程序一般都等待用户进行一些操作,然后响应并採取行动. 一般来说.对win32的程序的操作都会转换为系统事件队列中的消息,如按键消息WM_KEYDOWN,WM_MOUSECLICK等传递键 ...

  8. Mad Libs游戏:熟悉python编程环境,基本输入输出

    Mad Libs游戏: 代码: name1=input("请输入一个名字:") name2=input("请输入一个名字:") print("{}才刚 ...

  9. bananapi+OLED做的一个打地鼠游戏,c语言编程

    说明一下:BPI是对拍死的BPI的计数,对应最终的成绩RANK是难度 数值越低难度越高 每当打死10个BPI以后就会减一即难度高一级 默认初始化RANK等于15 DIE是存在的BPI数量,一旦数量大于 ...

随机推荐

  1. js继承的方式

    深入理解继承的实现方式不仅仅有利于自己去造轮子,封装插件,更有利于我们去阅读一些框架的源码, 以下记录几种常见的继承方式 1. 原型链实现继承 function Father(){ this.name ...

  2. 个人总结的常用java,anroid网站

    http://blog.csdn.net/wanghao200906/article/details/49334987

  3. Ubuntu安装Foxit PDF阅读器

    最近使用Ubuntu自带的PDF阅读器,发现使用体验较差,打算安装FoxitReader(可能是我习惯了Foxit和Adobe) Foxit官网 对系统平台要求如下:(支持Linux) 继续摸索了一下 ...

  4. TestNG套件测试(一)

    测试套件是用于测试软件程序的行为或一组行为的测试用例集合. 在TestNG中,我们无法在测试源代码中定义一个套件,但它可以由一个XML文件表示,可以灵活配置要运行的测试. 套件用<suite&g ...

  5. Python利用带权重随机数解决抽奖和游戏爆装备问题

    关于带权随机数 为了帮助理解,先来看三类随机问题的对比: 1.已有n条记录,从中选取m条记录,选取出来的记录前后顺序不管. 实现思路:按行遍历所有记录,约隔n/m条取一个数据即可 2.在1类情况下,还 ...

  6. [ural1057][Amount of Degrees] (数位dp+进制模型)

    Discription Create a code to determine the amount of integers, lying in the set [X; Y] and being a s ...

  7. [模拟赛FJOI Easy Round #2][T1 sign] (模拟+求字符串重复字串)

    [题目描述] 小Z在无意中发现了一个神奇的OJ,这个OJ有一个神奇的功能:每日签到,并且会通过某种玄学的算法计算出今日的运势.在多次试验之后,小Z发现自己的运势按照一定的周期循环,现在他找到了你,请通 ...

  8. 【05】AngularJS 指令

    AngularJS 指令 AngularJS 通过被称为 指令 的新属性来扩展 HTML. AngularJS 指令 AngularJS 指令是扩展的 HTML 属性,带有前缀 ng-. ng-app ...

  9. 【Codeforces 489D】Unbearable Controversy of Being

    [链接] 我是链接,点我呀:) [题意] 让你找到(a,b,c,d)的个数 这4个点之间有4条边有向边 (a,b)(b,c) (a,d)(d,c) 即有两条从a到b的路径,且这两条路径分别经过b和d到 ...

  10. [luoguP3146] [USACO16OPEN]248(区间DP)

    传送门 f[i][j]表示区间 i-j 合并的最大值 转移: 若f[i][k] && f[k+1][j] && f[i][k] == f[k+1][j] --> ...