mirror of
https://github.com/wheremyfoodat/Panda3DS.git
synced 2025-04-06 14:15:41 +12:00
commit
b79c12901b
5 changed files with 10 additions and 33 deletions
|
@ -1,7 +1,5 @@
|
|||
#pragma once
|
||||
|
||||
#include <SDL.h>
|
||||
|
||||
#include <QApplication>
|
||||
#include <QComboBox>
|
||||
#include <QMenuBar>
|
||||
|
@ -39,9 +37,6 @@ class MainWindow : public QMainWindow {
|
|||
QComboBox* themeSelect = nullptr;
|
||||
QMenuBar* menuBar = nullptr;
|
||||
|
||||
SDL_GameController* gameController = nullptr;
|
||||
int gameControllerID;
|
||||
|
||||
Theme currentTheme;
|
||||
void setTheme(Theme theme);
|
||||
void swapEmuBuffer();
|
||||
|
|
|
@ -4,16 +4,18 @@
|
|||
|
||||
#include "emulator.hpp"
|
||||
|
||||
struct FrontendSDL {
|
||||
class FrontendSDL {
|
||||
Emulator emu;
|
||||
#ifdef PANDA3DS_ENABLE_OPENGL
|
||||
SDL_GLContext glContext;
|
||||
#endif
|
||||
|
||||
public:
|
||||
FrontendSDL();
|
||||
bool loadROM(const std::filesystem::path& path);
|
||||
void run();
|
||||
|
||||
Emulator emu;
|
||||
SDL_Window* window = nullptr;
|
||||
#ifdef PANDA3DS_ENABLE_OPENGL
|
||||
SDL_GLContext glContext;
|
||||
#endif
|
||||
SDL_GameController* gameController = nullptr;
|
||||
int gameControllerID;
|
||||
};
|
|
@ -51,24 +51,6 @@ MainWindow::MainWindow(QApplication* app, QWidget* parent) : QMainWindow(parent)
|
|||
usingGL = (rendererType == RendererType::OpenGL || rendererType == RendererType::Software || rendererType == RendererType::Null);
|
||||
usingVk = (rendererType == RendererType::Vulkan);
|
||||
|
||||
if (SDL_Init(SDL_INIT_EVENTS) < 0) {
|
||||
Helpers::panic("Failed to initialize SDL2");
|
||||
}
|
||||
|
||||
// Make SDL use consistent positional button mapping
|
||||
SDL_SetHint(SDL_HINT_GAMECONTROLLER_USE_BUTTON_LABELS, "0");
|
||||
if (SDL_Init(SDL_INIT_GAMECONTROLLER) < 0) {
|
||||
Helpers::warn("Failed to initialize SDL2 GameController: %s", SDL_GetError());
|
||||
}
|
||||
|
||||
if (SDL_WasInit(SDL_INIT_GAMECONTROLLER)) {
|
||||
gameController = SDL_GameControllerOpen(0);
|
||||
|
||||
if (gameController != nullptr) {
|
||||
SDL_Joystick* stick = SDL_GameControllerGetJoystick(gameController);
|
||||
gameControllerID = SDL_JoystickInstanceID(stick);
|
||||
}
|
||||
}
|
||||
if (usingGL) {
|
||||
// Make GL context current for this thread, enable VSync
|
||||
GL::Context* glContext = screen.getGLContext();
|
||||
|
|
|
@ -75,7 +75,6 @@ FrontendSDL::FrontendSDL() {
|
|||
}
|
||||
|
||||
bool FrontendSDL::loadROM(const std::filesystem::path& path) { return emu.loadROM(path); }
|
||||
|
||||
void FrontendSDL::run() { emu.run(this); }
|
||||
|
||||
void Emulator::run(void* frontend) {
|
||||
|
@ -352,7 +351,6 @@ void Emulator::run(void* frontend) {
|
|||
// TODO: Should this be uncommented?
|
||||
// kernel.evalReschedule();
|
||||
|
||||
// Update inputs in the HID module
|
||||
SDL_GL_SwapWindow(frontendSDL->window);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,11 +1,11 @@
|
|||
#include "panda_sdl/frontend_sdl.hpp"
|
||||
|
||||
int main(int argc, char *argv[]) {
|
||||
FrontendSDL frontend;
|
||||
FrontendSDL app;
|
||||
|
||||
if (argc > 1) {
|
||||
auto romPath = std::filesystem::current_path() / argv[1];
|
||||
if (!frontend.loadROM(romPath)) {
|
||||
if (!app.loadROM(romPath)) {
|
||||
// For some reason just .c_str() doesn't show the proper path
|
||||
Helpers::panic("Failed to load ROM file: %s", romPath.string().c_str());
|
||||
}
|
||||
|
@ -13,5 +13,5 @@ int main(int argc, char *argv[]) {
|
|||
printf("No ROM inserted! Load a ROM by dragging and dropping it into the emulator window!\n");
|
||||
}
|
||||
|
||||
frontend.run();
|
||||
app.run();
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue