This repository has been archived by the owner on Feb 11, 2021. It is now read-only.
/
SDL_sysjoystick.c
192 lines (153 loc) · 4.97 KB
1
2
/*
SDL - Simple DirectMedia Layer
3
Copyright (C) 1997-2010 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
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
*/
#include "SDL_config.h"
#ifdef SDL_JOYSTICK_NDS
/* This is the system specific header for the SDL joystick API */
#include <nds.h>
#include <stdio.h> /* For the definition of NULL */
#include "SDL_error.h"
#include "SDL_events.h"
#include "SDL_joystick.h"
#include "SDL_sysjoystick.h"
#include "SDL_joystick_c.h"
#include "../../video/nds/SDL_ndsevents_c.h"
/* 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.
*/
int
SDL_SYS_JoystickInit(void)
{
47
48
SDL_numjoysticks = 1;
return (1);
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
}
/* Function to get the device-dependent name of a joystick */
const char *
SDL_SYS_JoystickName(int index)
{
if (!index)
return "NDS builtin joypad";
SDL_SetError("No joystick available with that index");
return (NULL);
}
/* 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.
*/
int
SDL_SYS_JoystickOpen(SDL_Joystick * joystick)
{
joystick->nbuttons = 8;
joystick->nhats = 0;
joystick->nballs = 0;
joystick->naxes = 2;
return 0;
}
/* 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.
*/
82
void
83
84
85
86
87
SDL_SYS_JoystickUpdate(SDL_Joystick * joystick)
{
u32 keysd, keysu;
int magnitude = 16384;
88
89
/*scanKeys(); - this is done in PumpEvents, because touch uses it too */
keysd = keysDown();
90
91
92
93
94
95
96
97
98
99
100
101
102
103
keysu = keysUp();
if ((keysd & KEY_UP)) {
SDL_PrivateJoystickAxis(joystick, 1, -magnitude);
}
if ((keysd & KEY_DOWN)) {
SDL_PrivateJoystickAxis(joystick, 1, magnitude);
}
if ((keysd & KEY_LEFT)) {
SDL_PrivateJoystickAxis(joystick, 0, -magnitude);
}
if ((keysd & KEY_RIGHT)) {
SDL_PrivateJoystickAxis(joystick, 0, magnitude);
}
104
if ((keysu & (KEY_UP | KEY_DOWN))) {
105
106
SDL_PrivateJoystickAxis(joystick, 1, 0);
}
107
if ((keysu & (KEY_LEFT | KEY_RIGHT))) {
108
109
SDL_PrivateJoystickAxis(joystick, 0, 0);
}
110
if ((keysd & KEY_A)) {
111
112
SDL_PrivateJoystickButton(joystick, 0, SDL_PRESSED);
}
113
if ((keysd & KEY_B)) {
114
115
SDL_PrivateJoystickButton(joystick, 1, SDL_PRESSED);
}
116
if ((keysd & KEY_X)) {
117
118
SDL_PrivateJoystickButton(joystick, 2, SDL_PRESSED);
}
119
if ((keysd & KEY_Y)) {
120
121
SDL_PrivateJoystickButton(joystick, 3, SDL_PRESSED);
}
122
if ((keysd & KEY_L)) {
123
124
SDL_PrivateJoystickButton(joystick, 4, SDL_PRESSED);
}
125
if ((keysd & KEY_R)) {
126
127
SDL_PrivateJoystickButton(joystick, 5, SDL_PRESSED);
}
128
if ((keysd & KEY_SELECT)) {
129
130
SDL_PrivateJoystickButton(joystick, 6, SDL_PRESSED);
}
131
if ((keysd & KEY_START)) {
132
133
SDL_PrivateJoystickButton(joystick, 7, SDL_PRESSED);
}
134
if ((keysu & KEY_A)) {
135
136
SDL_PrivateJoystickButton(joystick, 0, SDL_RELEASED);
}
137
if ((keysu & KEY_B)) {
138
139
SDL_PrivateJoystickButton(joystick, 1, SDL_RELEASED);
}
140
if ((keysu & KEY_X)) {
141
142
SDL_PrivateJoystickButton(joystick, 2, SDL_RELEASED);
}
143
if ((keysu & KEY_Y)) {
144
145
SDL_PrivateJoystickButton(joystick, 3, SDL_RELEASED);
}
146
if ((keysu & KEY_L)) {
147
148
SDL_PrivateJoystickButton(joystick, 4, SDL_RELEASED);
}
149
if ((keysu & KEY_R)) {
150
151
SDL_PrivateJoystickButton(joystick, 5, SDL_RELEASED);
}
152
if ((keysu & KEY_SELECT)) {
153
154
SDL_PrivateJoystickButton(joystick, 6, SDL_RELEASED);
}
155
if ((keysu & KEY_START)) {
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
SDL_PrivateJoystickButton(joystick, 7, SDL_RELEASED);
}
}
/* Function to close a joystick after use */
void
SDL_SYS_JoystickClose(SDL_Joystick * joystick)
{
}
/* Function to perform any system-specific joystick related cleanup */
void
SDL_SYS_JoystickQuit(void)
{
}
#endif /* SDL_JOYSTICK_NDS */