mirror of
https://github.com/bsnes-emu/bsnes.git
synced 2025-02-23 22:52:34 +01:00
byuu says: Changelog: - nall: added -static-libgcc -static-libstdc++ to Windows/GCC link flags - bsnes, higan: added program icons to main window when game isn't loaded - bsnes: improved recent games menu sorting - bsnes: fixed multi-game recent game loading on Windows - bsnes: completed path override support - bsnes, higan: added screensaver suppression on Windows - icarus: add 32K volatile RAM to SuperFX boards that report no RAM (fixes Starfox) - bsnes, higan: added automatic dependency generation [Talarubi] - hiro/GTK: appending actions to menus restores enabled() state - higan: use board node inside manifest.bml if it exists - bsnes: added blur emulation and color emulation options to view menu - ruby: upgraded input.sdl to SDL 2.0 (though it makes no functional difference sadly) - ruby: removed video.sdl (due to deprecating SDL 1.2) - nall, ruby: improvements to HID class (generic vendor and product IDs) Errata: - bsnes, higan: on Windows, Application::Windows::onScreenSaver needs `[&]` lambda capture, not `[]` - find it in presentation/presentation.cpp
79 lines
2.4 KiB
C++
79 lines
2.4 KiB
C++
#pragma once
|
|
|
|
struct InputJoypadSDL {
|
|
Input& input;
|
|
InputJoypadSDL(Input& input) : input(input) {}
|
|
|
|
struct Joypad {
|
|
shared_pointer<HID::Joypad> hid{new HID::Joypad};
|
|
|
|
uint id = 0;
|
|
SDL_Joystick* handle = nullptr;
|
|
};
|
|
vector<Joypad> joypads;
|
|
|
|
auto assign(shared_pointer<HID::Joypad> hid, uint groupID, uint inputID, int16_t value) -> void {
|
|
auto& group = hid->group(groupID);
|
|
if(group.input(inputID).value() == value) return;
|
|
input.doChange(hid, groupID, inputID, group.input(inputID).value(), value);
|
|
group.input(inputID).setValue(value);
|
|
}
|
|
|
|
auto poll(vector<shared_pointer<HID::Device>>& devices) -> void {
|
|
SDL_JoystickUpdate();
|
|
|
|
for(auto& jp : joypads) {
|
|
for(auto n : range(jp.hid->axes())) {
|
|
assign(jp.hid, HID::Joypad::GroupID::Axis, n, (int16_t)SDL_JoystickGetAxis(jp.handle, n));
|
|
}
|
|
|
|
for(int n = 0; n < (int)jp.hid->hats().size() - 1; n += 2) {
|
|
uint8_t state = SDL_JoystickGetHat(jp.handle, n >> 1);
|
|
assign(jp.hid, HID::Joypad::GroupID::Hat, n + 0, state & SDL_HAT_LEFT ? -32767 : state & SDL_HAT_RIGHT ? +32767 : 0);
|
|
assign(jp.hid, HID::Joypad::GroupID::Hat, n + 1, state & SDL_HAT_UP ? -32767 : state & SDL_HAT_DOWN ? +32767 : 0);
|
|
}
|
|
|
|
for(auto n : range(jp.hid->buttons())) {
|
|
assign(jp.hid, HID::Joypad::GroupID::Button, n, (bool)SDL_JoystickGetButton(jp.handle, n));
|
|
}
|
|
|
|
devices.append(jp.hid);
|
|
}
|
|
}
|
|
|
|
auto initialize() -> bool {
|
|
SDL_InitSubSystem(SDL_INIT_JOYSTICK);
|
|
SDL_JoystickEventState(SDL_IGNORE);
|
|
|
|
for(auto id : range(SDL_NumJoysticks())) {
|
|
Joypad jp;
|
|
jp.id = id;
|
|
jp.handle = SDL_JoystickOpen(jp.id);
|
|
|
|
uint axes = SDL_JoystickNumAxes(jp.handle);
|
|
uint hats = SDL_JoystickNumHats(jp.handle) * 2;
|
|
uint buttons = SDL_JoystickNumButtons(jp.handle);
|
|
|
|
jp.hid->setVendorID(HID::Joypad::GenericVendorID);
|
|
jp.hid->setProductID(HID::Joypad::GenericProductID);
|
|
jp.hid->setPathID(jp.id);
|
|
for(auto n : range(axes)) jp.hid->axes().append(n);
|
|
for(auto n : range(hats)) jp.hid->hats().append(n);
|
|
for(auto n : range(buttons)) jp.hid->buttons().append(n);
|
|
jp.hid->setRumble(false);
|
|
|
|
joypads.append(jp);
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
auto terminate() -> void {
|
|
for(auto& jp : joypads) {
|
|
SDL_JoystickClose(jp.handle);
|
|
}
|
|
joypads.reset();
|
|
SDL_QuitSubSystem(SDL_INIT_JOYSTICK);
|
|
}
|
|
};
|