mirror of https://github.com/cemu-project/Cemu.git
More changes to finding wiimotes (#961)
This commit is contained in:
parent
98b5a8758a
commit
323bdfa183
|
@ -56,7 +56,6 @@ WiimoteControllerSettings::WiimoteControllerSettings(wxWindow* parent, const wxP
|
||||||
// Motion
|
// Motion
|
||||||
m_use_motion = new wxCheckBox(box, wxID_ANY, _("Use motion"));
|
m_use_motion = new wxCheckBox(box, wxID_ANY, _("Use motion"));
|
||||||
m_use_motion->SetValue(m_settings.motion);
|
m_use_motion->SetValue(m_settings.motion);
|
||||||
m_use_motion->SetValue(m_settings.motion);
|
|
||||||
m_use_motion->Enable(m_controller->has_motion());
|
m_use_motion->Enable(m_controller->has_motion());
|
||||||
row_sizer->Add(m_use_motion, 0, wxALL, 5);
|
row_sizer->Add(m_use_motion, 0, wxALL, 5);
|
||||||
|
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <numbers>
|
#include <numbers>
|
||||||
|
#include <queue>
|
||||||
|
|
||||||
WiimoteControllerProvider::WiimoteControllerProvider()
|
WiimoteControllerProvider::WiimoteControllerProvider()
|
||||||
: m_running(true)
|
: m_running(true)
|
||||||
|
@ -30,20 +31,39 @@ WiimoteControllerProvider::~WiimoteControllerProvider()
|
||||||
std::vector<std::shared_ptr<ControllerBase>> WiimoteControllerProvider::get_controllers()
|
std::vector<std::shared_ptr<ControllerBase>> WiimoteControllerProvider::get_controllers()
|
||||||
{
|
{
|
||||||
std::scoped_lock lock(m_device_mutex);
|
std::scoped_lock lock(m_device_mutex);
|
||||||
for (const auto& device : WiimoteDevice_t::get_devices())
|
|
||||||
{
|
std::queue<uint32> disconnected_wiimote_indices;
|
||||||
// test connection of all devices as they might have been changed
|
for (auto i{0u}; i < m_wiimotes.size(); ++i){
|
||||||
const bool is_connected = device->write_data({kStatusRequest, 0x00});
|
if (!(m_wiimotes[i].connected = m_wiimotes[i].device->write_data({kStatusRequest, 0x00}))){
|
||||||
if (is_connected)
|
disconnected_wiimote_indices.push(i);
|
||||||
{
|
|
||||||
// only add unknown, connected devices to our list
|
|
||||||
const bool is_new_device = std::none_of(m_wiimotes.cbegin(), m_wiimotes.cend(),
|
|
||||||
[device](const auto& it) { return *it.device == *device; });
|
|
||||||
if (is_new_device)
|
|
||||||
{
|
|
||||||
m_wiimotes.push_back(std::make_unique<Wiimote>(device));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const auto valid_new_device = [&](std::shared_ptr<WiimoteDevice> & device) {
|
||||||
|
const auto writeable = device->write_data({kStatusRequest, 0x00});
|
||||||
|
const auto not_already_connected =
|
||||||
|
std::none_of(m_wiimotes.cbegin(), m_wiimotes.cend(),
|
||||||
|
[device](const auto& it) {
|
||||||
|
return (*it.device == *device) && it.connected;
|
||||||
|
});
|
||||||
|
return writeable && not_already_connected;
|
||||||
|
};
|
||||||
|
|
||||||
|
for (auto& device : WiimoteDevice_t::get_devices())
|
||||||
|
{
|
||||||
|
if (!valid_new_device(device))
|
||||||
|
continue;
|
||||||
|
// Replace disconnected wiimotes
|
||||||
|
if (!disconnected_wiimote_indices.empty()){
|
||||||
|
const auto idx = disconnected_wiimote_indices.front();
|
||||||
|
disconnected_wiimote_indices.pop();
|
||||||
|
|
||||||
|
m_wiimotes.replace(idx, std::make_unique<Wiimote>(device));
|
||||||
|
}
|
||||||
|
// Otherwise add them
|
||||||
|
else {
|
||||||
|
m_wiimotes.push_back(std::make_unique<Wiimote>(device));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<std::shared_ptr<ControllerBase>> result;
|
std::vector<std::shared_ptr<ControllerBase>> result;
|
||||||
|
|
|
@ -5,8 +5,8 @@ static constexpr uint16 WIIMOTE_PRODUCT_ID = 0x0306;
|
||||||
static constexpr uint16 WIIMOTE_MP_PRODUCT_ID = 0x0330;
|
static constexpr uint16 WIIMOTE_MP_PRODUCT_ID = 0x0330;
|
||||||
static constexpr uint16 WIIMOTE_MAX_INPUT_REPORT_LENGTH = 22;
|
static constexpr uint16 WIIMOTE_MAX_INPUT_REPORT_LENGTH = 22;
|
||||||
|
|
||||||
HidapiWiimote::HidapiWiimote(hid_device* dev, uint64_t identifier, std::string_view path)
|
HidapiWiimote::HidapiWiimote(hid_device* dev, std::string_view path)
|
||||||
: m_handle(dev), m_identifier(identifier), m_path(path) {
|
: m_handle(dev), m_path(path) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -36,11 +36,7 @@ std::vector<WiimoteDevicePtr> HidapiWiimote::get_devices() {
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
hid_set_nonblocking(dev, true);
|
hid_set_nonblocking(dev, true);
|
||||||
// Enough to have a unique id for each device within a session
|
wiimote_devices.push_back(std::make_shared<HidapiWiimote>(dev, it->path));
|
||||||
uint64_t id = (static_cast<uint64>(it->interface_number) << 32) |
|
|
||||||
(static_cast<uint64>(it->usage_page) << 16) |
|
|
||||||
(it->usage);
|
|
||||||
wiimote_devices.push_back(std::make_shared<HidapiWiimote>(dev, id, it->path));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
hid_free_enumeration(device_enumeration);
|
hid_free_enumeration(device_enumeration);
|
||||||
|
@ -48,8 +44,7 @@ std::vector<WiimoteDevicePtr> HidapiWiimote::get_devices() {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool HidapiWiimote::operator==(WiimoteDevice& o) const {
|
bool HidapiWiimote::operator==(WiimoteDevice& o) const {
|
||||||
auto const& other_mote = static_cast<HidapiWiimote const&>(o);
|
return static_cast<HidapiWiimote const&>(o).m_path == m_path;
|
||||||
return m_identifier == other_mote.m_identifier && other_mote.m_path == m_path;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
HidapiWiimote::~HidapiWiimote() {
|
HidapiWiimote::~HidapiWiimote() {
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
|
|
||||||
class HidapiWiimote : public WiimoteDevice {
|
class HidapiWiimote : public WiimoteDevice {
|
||||||
public:
|
public:
|
||||||
HidapiWiimote(hid_device* dev, uint64_t identifier, std::string_view path);
|
HidapiWiimote(hid_device* dev, std::string_view path);
|
||||||
~HidapiWiimote() override;
|
~HidapiWiimote() override;
|
||||||
|
|
||||||
bool write_data(const std::vector<uint8> &data) override;
|
bool write_data(const std::vector<uint8> &data) override;
|
||||||
|
@ -16,7 +16,6 @@ public:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
hid_device* m_handle;
|
hid_device* m_handle;
|
||||||
const uint64_t m_identifier;
|
|
||||||
const std::string m_path;
|
const std::string m_path;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue