This repository has been archived by the owner on Feb 11, 2021. It is now read-only.
/
SDL_bejoystick.cc
240 lines (204 loc) · 7.51 KB
1
2
/*
SDL - Simple DirectMedia Layer
3
Copyright (C) 1997-2006 Sam Lantinga
4
5
This library is free software; you can redistribute it and/or
6
modify it under the terms of the GNU Lesser General Public
7
License as published by the Free Software Foundation; either
8
version 2.1 of the License, or (at your option) any later version.
9
10
11
12
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13
Lesser General Public License for more details.
14
15
16
17
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
18
19
Sam Lantinga
20
slouken@libsdl.org
21
*/
22
#include "SDL_config.h"
23
24
25
#ifdef SDL_JOYSTICK_BEOS
26
27
28
29
30
/* This is the system specific header for the SDL joystick API */
#include <be/support/String.h>
#include <be/device/Joystick.h>
31
32
extern "C"
{
33
34
#include "SDL_joystick.h"
35
36
#include "../SDL_sysjoystick.h"
#include "../SDL_joystick_c.h"
37
38
39
/* The maximum number of joysticks we'll detect */
40
#define MAX_JOYSTICKS 16
41
42
/* A list of available joysticks */
43
44
static char *SDL_joyport[MAX_JOYSTICKS];
static char *SDL_joyname[MAX_JOYSTICKS];
45
46
/* The private structure used to keep track of a joystick */
47
48
49
50
51
52
struct joystick_hwdata
{
BJoystick *stick;
uint8 *new_hats;
int16 *new_axes;
};
53
54
55
56
57
58
/* Function to scan the system for joysticks.
* This function should set SDL_numjoysticks to the number of available
* joysticks. Joystick 0 should be the system default joystick.
* It should return 0, or -1 on an unrecoverable fatal error.
*/
59
int SDL_SYS_JoystickInit(void)
60
61
62
63
64
65
66
67
{
BJoystick joystick;
int numjoysticks;
int i;
int32 nports;
char name[B_OS_NAME_LENGTH];
/* Search for attached joysticks */
68
nports = joystick.CountDevices();
69
numjoysticks = 0;
70
71
SDL_memset(SDL_joyport, 0, (sizeof SDL_joyport));
SDL_memset(SDL_joyname, 0, (sizeof SDL_joyname));
72
73
for (i = 0; (SDL_numjoysticks < MAX_JOYSTICKS) && (i < nports); ++i)
{
74
75
if (joystick.GetDeviceName(i, name) == B_OK) {
if (joystick.Open(name) != B_ERROR) {
76
BString stick_name;
77
78
79
joystick.GetControllerName(&stick_name);
SDL_joyport[numjoysticks] = strdup(name);
SDL_joyname[numjoysticks] = strdup(stick_name.String());
80
numjoysticks++;
81
joystick.Close();
82
83
84
85
86
}
}
}
return (numjoysticks);
}
87
88
/* Function to get the device-dependent name of a joystick */
89
const char *SDL_SYS_JoystickName(int index)
90
91
92
{
return SDL_joyname[index];
}
93
94
95
96
97
98
/* Function to open a joystick for use.
The joystick to open is specified by the index field of the joystick.
This should fill the nbuttons and naxes fields of the joystick structure.
It returns 0, or -1 if there is an error.
*/
99
int SDL_SYS_JoystickOpen(SDL_Joystick * joystick)
100
101
102
103
104
{
BJoystick *stick;
/* Create the joystick data structure */
joystick->hwdata = (struct joystick_hwdata *)
105
SDL_malloc(sizeof(*joystick->hwdata));
106
if (joystick->hwdata == NULL) {
107
SDL_OutOfMemory();
108
109
return (-1);
}
110
SDL_memset(joystick->hwdata, 0, sizeof(*joystick->hwdata));
111
112
113
114
stick = new BJoystick;
joystick->hwdata->stick = stick;
/* Open the requested joystick for use */
115
116
117
if (stick->Open(SDL_joyport[joystick->index]) == B_ERROR) {
SDL_SetError("Unable to open joystick");
SDL_SYS_JoystickClose(joystick);
118
119
120
121
return (-1);
}
/* Set the joystick to calibrated mode */
122
stick->EnableCalibration();
123
124
/* Get the number of buttons, hats, and axes on the joystick */
125
126
127
joystick->nbuttons = stick->CountButtons();
joystick->naxes = stick->CountAxes();
joystick->nhats = stick->CountHats();
128
129
joystick->hwdata->new_axes = (int16 *)
130
SDL_malloc(joystick->naxes * sizeof(int16));
131
joystick->hwdata->new_hats = (uint8 *)
132
SDL_malloc(joystick->nhats * sizeof(uint8));
133
if (!joystick->hwdata->new_hats || !joystick->hwdata->new_axes) {
134
135
SDL_OutOfMemory();
SDL_SYS_JoystickClose(joystick);
136
137
138
139
140
141
return (-1);
}
/* We're done! */
return (0);
}
142
143
144
145
146
147
/* Function to update the state of a joystick - called as a device poll.
* This function shouldn't update the joystick structure directly,
* but instead should call SDL_PrivateJoystick*() to deliver events
* and update joystick device state.
*/
148
void SDL_SYS_JoystickUpdate(SDL_Joystick * joystick)
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
{
static const Uint8 hat_map[9] = {
SDL_HAT_CENTERED,
SDL_HAT_UP,
SDL_HAT_RIGHTUP,
SDL_HAT_RIGHT,
SDL_HAT_RIGHTDOWN,
SDL_HAT_DOWN,
SDL_HAT_LEFTDOWN,
SDL_HAT_LEFT,
SDL_HAT_LEFTUP
};
const int JITTER = (32768 / 10); /* 10% jitter threshold (ok?) */
BJoystick *stick;
int i, change;
int16 *axes;
uint8 *hats;
uint32 buttons;
/* Set up data pointers */
stick = joystick->hwdata->stick;
axes = joystick->hwdata->new_axes;
hats = joystick->hwdata->new_hats;
/* Get the new joystick state */
175
176
177
178
stick->Update();
stick->GetAxisValues(axes);
stick->GetHatValues(hats);
buttons = stick->ButtonValues();
179
180
181
182
183
/* Generate axis motion events */
for (i = 0; i < joystick->naxes; ++i) {
change = ((int32) axes[i] - joystick->axes[i]);
if ((change > JITTER) || (change < -JITTER)) {
184
SDL_PrivateJoystickAxis(joystick, i, axes[i]);
185
186
187
188
189
190
}
}
/* Generate hat change events */
for (i = 0; i < joystick->nhats; ++i) {
if (hats[i] != joystick->hats[i]) {
191
SDL_PrivateJoystickHat(joystick, i, hat_map[hats[i]]);
192
193
194
195
196
197
}
}
/* Generate button events */
for (i = 0; i < joystick->nbuttons; ++i) {
if ((buttons & 0x01) != joystick->buttons[i]) {
198
SDL_PrivateJoystickButton(joystick, i, (buttons & 0x01));
199
200
201
202
}
buttons >>= 1;
}
}
203
204
/* Function to close a joystick after use */
205
void SDL_SYS_JoystickClose(SDL_Joystick * joystick)
206
207
{
if (joystick->hwdata) {
208
joystick->hwdata->stick->Close();
209
210
delete joystick->hwdata->stick;
if (joystick->hwdata->new_hats) {
211
SDL_free(joystick->hwdata->new_hats);
212
213
}
if (joystick->hwdata->new_axes) {
214
SDL_free(joystick->hwdata->new_axes);
215
}
216
SDL_free(joystick->hwdata);
217
218
219
joystick->hwdata = NULL;
}
}
220
221
/* Function to perform any system-specific joystick related cleanup */
222
void SDL_SYS_JoystickQuit(void)
223
224
{
int i;
225
226
for (i = 0; SDL_joyport[i]; ++i) {
227
SDL_free(SDL_joyport[i]);
228
229
}
SDL_joyport[0] = NULL;
230
231
for (i = 0; SDL_joyname[i]; ++i) {
232
SDL_free(SDL_joyname[i]);
233
234
235
}
SDL_joyname[0] = NULL;
}
236
237
}; // extern "C"
238
239
#endif /* SDL_JOYSTICK_BEOS */
240
/* vi: set ts=4 sw=4 expandtab: */