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

Latest commit

 

History

History
253 lines (215 loc) · 7.94 KB

SDL_joystick.h

File metadata and controls

253 lines (215 loc) · 7.94 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
*/
#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.
Jul 3, 2013
Jul 3, 2013
57
58
59
60
*
* If you would like to receive joystick updates while the application
* is in the background, you should set the following hint before calling
* SDL_Init(): SDL_HINT_JOYSTICK_ALLOW_BACKGROUND_EVENTS
61
62
63
64
65
66
*/
/* The joystick structure used to identify an SDL joystick */
struct _SDL_Joystick;
typedef struct _SDL_Joystick SDL_Joystick;
Nov 27, 2012
Nov 27, 2012
67
68
/* A structure that encodes the stable unique id for a joystick device */
typedef struct {
May 18, 2013
May 18, 2013
69
Uint8 data[16];
Dec 11, 2012
Dec 11, 2012
70
} SDL_JoystickGUID;
Nov 27, 2012
Nov 27, 2012
71
Mar 6, 2013
Mar 6, 2013
72
typedef Sint32 SDL_JoystickID;
Nov 27, 2012
Nov 27, 2012
73
74
75
76
/* Function prototypes */
/**
Nov 27, 2012
Nov 27, 2012
77
* Count the number of joysticks attached to the system right now
78
79
80
81
82
83
84
85
*/
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
86
extern DECLSPEC const char *SDLCALL SDL_JoystickNameForIndex(int device_index);
May 18, 2013
May 18, 2013
89
90
* Open a joystick for use.
* The index passed as an argument refers tothe N'th joystick on the system.
91
92
* This index is the value which will identify this joystick in future joystick
* events.
May 18, 2013
May 18, 2013
93
*
94
95
96
97
98
* \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
99
100
101
102
* 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
103
Nov 27, 2012
Nov 27, 2012
104
105
106
/**
* Return the GUID for the joystick at this index
*/
Dec 11, 2012
Dec 11, 2012
107
extern DECLSPEC SDL_JoystickGUID SDLCALL SDL_JoystickGetDeviceGUID(int device_index);
Nov 27, 2012
Nov 27, 2012
108
109
110
111
/**
* Return the GUID for this opened joystick
*/
Dec 11, 2012
Dec 11, 2012
112
extern DECLSPEC SDL_JoystickGUID SDLCALL SDL_JoystickGetGUID(SDL_Joystick * joystick);
Nov 27, 2012
Nov 27, 2012
113
114
/**
Dec 11, 2012
Dec 11, 2012
115
116
* 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
117
*/
Dec 11, 2012
Dec 11, 2012
118
extern DECLSPEC void SDL_JoystickGetGUIDString(SDL_JoystickGUID guid, char *pszGUID, int cbGUID);
Nov 27, 2012
Nov 27, 2012
119
120
121
122
/**
* convert a string into a joystick formatted guid
*/
Dec 11, 2012
Dec 11, 2012
123
extern DECLSPEC SDL_JoystickGUID SDLCALL SDL_JoystickGetGUIDFromString(const char *pchGUID);
Nov 27, 2012
Nov 27, 2012
124
125
/**
Nov 27, 2012
Nov 27, 2012
126
* 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
128
extern DECLSPEC SDL_bool SDLCALL SDL_JoystickGetAttached(SDL_Joystick * joystick);
Mar 6, 2013
Mar 6, 2013
131
* Get the instance ID of an opened joystick or -1 if the joystick is invalid.
Nov 27, 2012
Nov 27, 2012
133
extern DECLSPEC SDL_JoystickID SDLCALL SDL_JoystickInstanceID(SDL_Joystick * joystick);
134
135
136
137
138
139
140
141
/**
* 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
142
*
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
* 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
160
*
161
162
163
164
165
166
167
* 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
168
*
169
170
171
* 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
172
*
173
174
175
176
177
178
* 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
179
*
180
* The state is a value ranging from -32768 to 32767.
May 18, 2013
May 18, 2013
181
*
182
183
184
185
186
187
188
189
190
* 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
191
192
193
194
195
196
197
198
199
#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)
200
201
202
203
204
205
/*@}*/
/**
* Get the current state of a POV hat on a joystick.
*
* The hat indices start at index 0.
May 18, 2013
May 18, 2013
206
*
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
* \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
223
*
224
* \return 0, or -1 if you passed it invalid parameters.
May 18, 2013
May 18, 2013
225
*
226
227
228
229
230
231
232
* 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
233
*
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
* 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: */