///////////////////////////////////////////////////////////////////////////////////
// Copyright (C) 2023 Jon Beniston, M7RCE //
// //
// This program is free software; you can redistribute it and/or modify //
// it under the terms of the GNU General Public License as published by //
// the Free Software Foundation as version 3 of the License, or //
// (at your option) any later version. //
// //
// This program 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 General Public License V3 for more details. //
// //
// You should have received a copy of the GNU General Public License //
// along with this program. If not, see . //
///////////////////////////////////////////////////////////////////////////////////
#ifdef QT_GAMEPAD_FOUND
#include
#include "gamepadinputcontroller.h"
#endif
#include "inputcontroller.h"
InputControllerManager* InputControllerManager::m_instance = nullptr;
QStringList InputControllerManager::getAllControllers()
{
#ifdef QT_GAMEPAD_FOUND
return GamepadInputController::getAllControllers();
#else
return {};
#endif
}
InputController* InputControllerManager::open(const QString& name)
{
#ifdef QT_GAMEPAD_FOUND
return GamepadInputController::open(name);
#else
return nullptr;
#endif
}
InputControllerManager* InputControllerManager::instance()
{
if (!m_instance) {
m_instance = new InputControllerManager();
}
return m_instance;
}
InputControllerManager::InputControllerManager()
{
#ifdef QT_GAMEPAD_FOUND
connect(QGamepadManager::instance(), &QGamepadManager::connectedGamepadsChanged, this, &InputControllerManager::connectedGamepadsChanged);
#endif
}
void InputControllerManager::connectedGamepadsChanged()
{
emit controllersChanged();
}