mirror of https://github.com/mgba-emu/mgba.git
SDL: Add ability to control tilt sensor with right analog stick (currently hardcoded)
This commit is contained in:
parent
049e3639d1
commit
7fa043cb50
|
@ -286,7 +286,7 @@ void GBAHardwareInitGyro(struct GBACartridgeHardware* hw) {
|
||||||
|
|
||||||
void _gyroReadPins(struct GBACartridgeHardware* hw) {
|
void _gyroReadPins(struct GBACartridgeHardware* hw) {
|
||||||
struct GBARotationSource* gyro = hw->p->rotationSource;
|
struct GBARotationSource* gyro = hw->p->rotationSource;
|
||||||
if (!gyro) {
|
if (!gyro || !gyro->readGyroZ) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -100,6 +100,7 @@ GameController::GameController(QObject* parent)
|
||||||
context->gba->rtcSource = &controller->m_rtc;
|
context->gba->rtcSource = &controller->m_rtc;
|
||||||
#ifdef BUILD_SDL
|
#ifdef BUILD_SDL
|
||||||
context->gba->rumble = controller->m_inputController->rumble();
|
context->gba->rumble = controller->m_inputController->rumble();
|
||||||
|
context->gba->rotationSource = controller->m_inputController->rotationSource();
|
||||||
#endif
|
#endif
|
||||||
controller->gameStarted(context);
|
controller->gameStarted(context);
|
||||||
};
|
};
|
||||||
|
|
|
@ -157,6 +157,10 @@ void InputController::setPreferredGamepad(uint32_t type, const QString& device)
|
||||||
GBARumble* InputController::rumble() {
|
GBARumble* InputController::rumble() {
|
||||||
return &m_sdlPlayer.rumble.d;
|
return &m_sdlPlayer.rumble.d;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GBARotationSource* InputController::rotationSource() {
|
||||||
|
return &m_sdlPlayer.rotation.d;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GBAKey InputController::mapKeyboard(int key) const {
|
GBAKey InputController::mapKeyboard(int key) const {
|
||||||
|
|
|
@ -66,6 +66,7 @@ public:
|
||||||
void setGamepad(uint32_t type, int index) { GBASDLPlayerChangeJoystick(&s_sdlEvents, &m_sdlPlayer, index); }
|
void setGamepad(uint32_t type, int index) { GBASDLPlayerChangeJoystick(&s_sdlEvents, &m_sdlPlayer, index); }
|
||||||
void setPreferredGamepad(uint32_t type, const QString& device);
|
void setPreferredGamepad(uint32_t type, const QString& device);
|
||||||
GBARumble* rumble();
|
GBARumble* rumble();
|
||||||
|
GBARotationSource* rotationSource();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
|
|
|
@ -21,6 +21,9 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void _GBASDLSetRumble(struct GBARumble* rumble, int enable);
|
static void _GBASDLSetRumble(struct GBARumble* rumble, int enable);
|
||||||
|
static int32_t _GBASDLReadTiltX(struct GBARotationSource* rumble);
|
||||||
|
static int32_t _GBASDLReadTiltY(struct GBARotationSource* rumble);
|
||||||
|
static void _GBASDLRotationSample(struct GBARotationSource* source);
|
||||||
|
|
||||||
bool GBASDLInitEvents(struct GBASDLEvents* context) {
|
bool GBASDLInitEvents(struct GBASDLEvents* context) {
|
||||||
int subsystem = SDL_INIT_JOYSTICK;
|
int subsystem = SDL_INIT_JOYSTICK;
|
||||||
|
@ -146,6 +149,14 @@ bool GBASDLAttachPlayer(struct GBASDLEvents* events, struct GBASDLPlayer* player
|
||||||
player->rumble.p = player;
|
player->rumble.p = player;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
player->rotation.d.readTiltX = _GBASDLReadTiltX;
|
||||||
|
player->rotation.d.readTiltY = _GBASDLReadTiltY;
|
||||||
|
player->rotation.d.readGyroZ = 0;
|
||||||
|
player->rotation.d.sample = _GBASDLRotationSample;
|
||||||
|
player->rotation.axisX = 2;
|
||||||
|
player->rotation.axisY = 3;
|
||||||
|
player->rotation.p = player;
|
||||||
|
|
||||||
if (events->playersAttached >= MAX_PLAYERS) {
|
if (events->playersAttached >= MAX_PLAYERS) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -447,3 +458,21 @@ static void _GBASDLSetRumble(struct GBARumble* rumble, int enable) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static int32_t _readTilt(struct GBASDLPlayer* player, int axis) {
|
||||||
|
return SDL_JoystickGetAxis(player->joystick, axis) * 0x3800;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int32_t _GBASDLReadTiltX(struct GBARotationSource* source) {
|
||||||
|
struct GBASDLRotation* rotation = (struct GBASDLRotation*) source;
|
||||||
|
return _readTilt(rotation->p, rotation->axisX);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int32_t _GBASDLReadTiltY(struct GBARotationSource* source) {
|
||||||
|
struct GBASDLRotation* rotation = (struct GBASDLRotation*) source;
|
||||||
|
return _readTilt(rotation->p, rotation->axisY);
|
||||||
|
}
|
||||||
|
static void _GBASDLRotationSample(struct GBARotationSource* source) {
|
||||||
|
UNUSED(source);
|
||||||
|
SDL_JoystickUpdate();
|
||||||
|
}
|
||||||
|
|
|
@ -47,6 +47,13 @@ struct GBASDLPlayer {
|
||||||
struct GBASDLPlayer* p;
|
struct GBASDLPlayer* p;
|
||||||
} rumble;
|
} rumble;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
struct GBASDLRotation {
|
||||||
|
struct GBARotationSource d;
|
||||||
|
struct GBASDLPlayer* p;
|
||||||
|
int axisX;
|
||||||
|
int axisY;
|
||||||
|
} rotation;
|
||||||
};
|
};
|
||||||
|
|
||||||
bool GBASDLInitEvents(struct GBASDLEvents*);
|
bool GBASDLInitEvents(struct GBASDLEvents*);
|
||||||
|
|
Loading…
Reference in New Issue