diff --git a/src/avmodel.cpp b/src/avmodel.cpp index c597240e5c6a39b4204ff4b68b9f81ce13a9a400..4a28fe589fbb878cf246a83873e8c0062dbb1e62 100644 --- a/src/avmodel.cpp +++ b/src/avmodel.cpp @@ -292,11 +292,11 @@ AVModel::getAudioManager() const std::vector<std::string> AVModel::getAudioOutputDevices() const { - QStringList managers = ConfigurationManager::instance() + QStringList devices = ConfigurationManager::instance() .getAudioOutputDeviceList(); std::vector<std::string> result; - for (const auto& manager : managers) { - result.emplace_back(manager.toStdString()); + for (const auto& device : devices) { + result.emplace_back(device.toStdString()); } return result; } @@ -304,11 +304,11 @@ AVModel::getAudioOutputDevices() const std::vector<std::string> AVModel::getAudioInputDevices() const { - QStringList managers = ConfigurationManager::instance() + QStringList devices = ConfigurationManager::instance() .getAudioInputDeviceList(); std::vector<std::string> result; - for (const auto& manager : managers) { - result.emplace_back(manager.toStdString()); + for (const auto& device : devices) { + result.emplace_back(device.toStdString()); } return result; } @@ -740,7 +740,18 @@ AVModelPimpl::getDevice(int type) const } auto deviceIdx = currentDevicesIdx[type].toUInt(); for (const auto& dev : devices) { - int idx = ConfigurationManager::instance().getAudioInputDeviceIndex(dev.c_str()); + int idx; + switch (type) { + case 1: // INPUT + idx = ConfigurationManager::instance().getAudioInputDeviceIndex(dev.c_str()); + break; + case 0: // OUTPUT + case 2: // RINGTONE + idx = ConfigurationManager::instance().getAudioOutputDeviceIndex(dev.c_str()); + break; + default: + break; + } if (idx == deviceIdx) { return dev; }