Skip to content
This repository has been archived by the owner on Feb 11, 2021. It is now read-only.

Latest commit

 

History

History
249 lines (211 loc) · 7.74 KB

SDL_joystick.h

File metadata and controls

249 lines (211 loc) · 7.74 KB
 
1
2
/*
Simple DirectMedia Layer
Feb 15, 2013
Feb 15, 2013
3
Copyright (C) 1997-2013 Sam Lantinga <slouken@libsdl.org>
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
This software is provided 'as-is', without any express or implied
warranty. In no event will the authors be held liable for any damages
arising from the use of this software.
Permission is granted to anyone to use this software for any purpose,
including commercial applications, and to alter it and redistribute it
freely, subject to the following restrictions:
1. The origin of this software must not be misrepresented; you must not
claim that you wrote the original software. If you use this software
in a product, an acknowledgment in the product documentation would be
appreciated but is not required.
2. Altered source versions must be plainly marked as such, and must not be
misrepresented as being the original software.
3. This notice may not be removed or altered from any source distribution.
*/
/**
* \file SDL_joystick.h
May 18, 2013
May 18, 2013
24
*
25
* Include file for SDL joystick event handling
Nov 27, 2012
Nov 27, 2012
26
27
28
29
30
31
32
*
* The term "device_index" identifies currently plugged in joystick devices between 0 and SDL_NumJoysticks, with the exact joystick
* behind a device_index changing as joysticks are plugged and unplugged.
*
* The term "instance_id" is the current instantiation of a joystick device in the system, if the joystick is removed and then re-inserted
* then it will get a new instance_id, instance_id's are monotonically increasing identifiers of a joystick plugged in.
*
May 18, 2013
May 18, 2013
33
* The term JoystickGUID is a stable 128-bit identifier for a joystick device that does not change over time, it identifies class of
Nov 27, 2012
Nov 27, 2012
34
35
36
* the device (a X360 wired controller for example). This identifier is platform dependent.
*
*
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
*/
#ifndef _SDL_joystick_h
#define _SDL_joystick_h
#include "SDL_stdinc.h"
#include "SDL_error.h"
#include "begin_code.h"
/* Set up for C function definitions, even when using C++ */
#ifdef __cplusplus
extern "C" {
#endif
/**
* \file SDL_joystick.h
*
* In order to use these functions, SDL_Init() must have been called
* with the ::SDL_INIT_JOYSTICK flag. This causes SDL to scan the system
* for joysticks, and load appropriate drivers.
*/
/* The joystick structure used to identify an SDL joystick */
struct _SDL_Joystick;
typedef struct _SDL_Joystick SDL_Joystick;
Nov 27, 2012
Nov 27, 2012
63
64
/* A structure that encodes the stable unique id for a joystick device */
typedef struct {
May 18, 2013
May 18, 2013
65
Uint8 data[16];
Dec 11, 2012
Dec 11, 2012
66
} SDL_JoystickGUID;
Nov 27, 2012
Nov 27, 2012
67
Mar 6, 2013
Mar 6, 2013
68
typedef Sint32 SDL_JoystickID;
Nov 27, 2012
Nov 27, 2012
69
70
71
72
/* Function prototypes */
/**
Nov 27, 2012
Nov 27, 2012
73
* Count the number of joysticks attached to the system right now
74
75
76
77
78
79
80
81
*/
extern DECLSPEC int SDLCALL SDL_NumJoysticks(void);
/**
* Get the implementation dependent name of a joystick.
* This can be called before any joysticks are opened.
* If no name can be found, this function returns NULL.
*/
Nov 27, 2012
Nov 27, 2012
82
extern DECLSPEC const char *SDLCALL SDL_JoystickNameForIndex(int device_index);
May 18, 2013
May 18, 2013
85
86
* Open a joystick for use.
* The index passed as an argument refers tothe N'th joystick on the system.
87
88
* This index is the value which will identify this joystick in future joystick
* events.
May 18, 2013
May 18, 2013
89
*
90
91
92
93
94
* \return A joystick identifier, or NULL if an error occurred.
*/
extern DECLSPEC SDL_Joystick *SDLCALL SDL_JoystickOpen(int device_index);
/**
Nov 27, 2012
Nov 27, 2012
95
96
97
98
* Return the name for this currently opened joystick.
* If no name can be found, this function returns NULL.
*/
extern DECLSPEC const char *SDLCALL SDL_JoystickName(SDL_Joystick * joystick);
May 18, 2013
May 18, 2013
99
Nov 27, 2012
Nov 27, 2012
100
101
102
/**
* Return the GUID for the joystick at this index
*/
Dec 11, 2012
Dec 11, 2012
103
extern DECLSPEC SDL_JoystickGUID SDLCALL SDL_JoystickGetDeviceGUID(int device_index);
Nov 27, 2012
Nov 27, 2012
104
105
106
107
/**
* Return the GUID for this opened joystick
*/
Dec 11, 2012
Dec 11, 2012
108
extern DECLSPEC SDL_JoystickGUID SDLCALL SDL_JoystickGetGUID(SDL_Joystick * joystick);
Nov 27, 2012
Nov 27, 2012
109
110
/**
Dec 11, 2012
Dec 11, 2012
111
112
* Return a string representation for this guid. pszGUID must point to at least 33 bytes
* (32 for the string plus a NULL terminator).
Nov 27, 2012
Nov 27, 2012
113
*/
Dec 11, 2012
Dec 11, 2012
114
extern DECLSPEC void SDL_JoystickGetGUIDString(SDL_JoystickGUID guid, char *pszGUID, int cbGUID);
Nov 27, 2012
Nov 27, 2012
115
116
117
118
/**
* convert a string into a joystick formatted guid
*/
Dec 11, 2012
Dec 11, 2012
119
extern DECLSPEC SDL_JoystickGUID SDLCALL SDL_JoystickGetGUIDFromString(const char *pchGUID);
Nov 27, 2012
Nov 27, 2012
120
121
/**
Nov 27, 2012
Nov 27, 2012
122
* Returns SDL_TRUE if the joystick has been opened and currently connected, or SDL_FALSE if it has not.
Nov 27, 2012
Nov 27, 2012
124
extern DECLSPEC SDL_bool SDLCALL SDL_JoystickGetAttached(SDL_Joystick * joystick);
Mar 6, 2013
Mar 6, 2013
127
* Get the instance ID of an opened joystick or -1 if the joystick is invalid.
Nov 27, 2012
Nov 27, 2012
129
extern DECLSPEC SDL_JoystickID SDLCALL SDL_JoystickInstanceID(SDL_Joystick * joystick);
130
131
132
133
134
135
136
137
/**
* Get the number of general axis controls on a joystick.
*/
extern DECLSPEC int SDLCALL SDL_JoystickNumAxes(SDL_Joystick * joystick);
/**
* Get the number of trackballs on a joystick.
May 18, 2013
May 18, 2013
138
*
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
* Joystick trackballs have only relative motion events associated
* with them and their state cannot be polled.
*/
extern DECLSPEC int SDLCALL SDL_JoystickNumBalls(SDL_Joystick * joystick);
/**
* Get the number of POV hats on a joystick.
*/
extern DECLSPEC int SDLCALL SDL_JoystickNumHats(SDL_Joystick * joystick);
/**
* Get the number of buttons on a joystick.
*/
extern DECLSPEC int SDLCALL SDL_JoystickNumButtons(SDL_Joystick * joystick);
/**
* Update the current state of the open joysticks.
May 18, 2013
May 18, 2013
156
*
157
158
159
160
161
162
163
* This is called automatically by the event loop if any joystick
* events are enabled.
*/
extern DECLSPEC void SDLCALL SDL_JoystickUpdate(void);
/**
* Enable/disable joystick event polling.
May 18, 2013
May 18, 2013
164
*
165
166
167
* If joystick events are disabled, you must call SDL_JoystickUpdate()
* yourself and check the state of the joystick when you want joystick
* information.
May 18, 2013
May 18, 2013
168
*
169
170
171
172
173
174
* The state can be one of ::SDL_QUERY, ::SDL_ENABLE or ::SDL_IGNORE.
*/
extern DECLSPEC int SDLCALL SDL_JoystickEventState(int state);
/**
* Get the current state of an axis control on a joystick.
May 18, 2013
May 18, 2013
175
*
176
* The state is a value ranging from -32768 to 32767.
May 18, 2013
May 18, 2013
177
*
178
179
180
181
182
183
184
185
186
* The axis indices start at index 0.
*/
extern DECLSPEC Sint16 SDLCALL SDL_JoystickGetAxis(SDL_Joystick * joystick,
int axis);
/**
* \name Hat positions
*/
/*@{*/
May 18, 2013
May 18, 2013
187
188
189
190
191
192
193
194
195
#define SDL_HAT_CENTERED 0x00
#define SDL_HAT_UP 0x01
#define SDL_HAT_RIGHT 0x02
#define SDL_HAT_DOWN 0x04
#define SDL_HAT_LEFT 0x08
#define SDL_HAT_RIGHTUP (SDL_HAT_RIGHT|SDL_HAT_UP)
#define SDL_HAT_RIGHTDOWN (SDL_HAT_RIGHT|SDL_HAT_DOWN)
#define SDL_HAT_LEFTUP (SDL_HAT_LEFT|SDL_HAT_UP)
#define SDL_HAT_LEFTDOWN (SDL_HAT_LEFT|SDL_HAT_DOWN)
196
197
198
199
200
201
/*@}*/
/**
* Get the current state of a POV hat on a joystick.
*
* The hat indices start at index 0.
May 18, 2013
May 18, 2013
202
*
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
* \return The return value is one of the following positions:
* - ::SDL_HAT_CENTERED
* - ::SDL_HAT_UP
* - ::SDL_HAT_RIGHT
* - ::SDL_HAT_DOWN
* - ::SDL_HAT_LEFT
* - ::SDL_HAT_RIGHTUP
* - ::SDL_HAT_RIGHTDOWN
* - ::SDL_HAT_LEFTUP
* - ::SDL_HAT_LEFTDOWN
*/
extern DECLSPEC Uint8 SDLCALL SDL_JoystickGetHat(SDL_Joystick * joystick,
int hat);
/**
* Get the ball axis change since the last poll.
May 18, 2013
May 18, 2013
219
*
220
* \return 0, or -1 if you passed it invalid parameters.
May 18, 2013
May 18, 2013
221
*
222
223
224
225
226
227
228
* The ball indices start at index 0.
*/
extern DECLSPEC int SDLCALL SDL_JoystickGetBall(SDL_Joystick * joystick,
int ball, int *dx, int *dy);
/**
* Get the current state of a button on a joystick.
May 18, 2013
May 18, 2013
229
*
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
* The button indices start at index 0.
*/
extern DECLSPEC Uint8 SDLCALL SDL_JoystickGetButton(SDL_Joystick * joystick,
int button);
/**
* Close a joystick previously opened with SDL_JoystickOpen().
*/
extern DECLSPEC void SDLCALL SDL_JoystickClose(SDL_Joystick * joystick);
/* Ends C function definitions when using C++ */
#ifdef __cplusplus
}
#endif
#include "close_code.h"
#endif /* _SDL_joystick_h */
/* vi: set ts=4 sw=4 expandtab: */