/** @file * @author Edouard DUPIN * @copyright 2015, Edouard DUPIN, all right reserved * @license APACHE v2.0 (see license file) */ #include "Manager.h" #include "Interface.h" #include #include #include "io/Manager.h" #include "io/Node.h" std::shared_ptr airtio::Manager::create(const std::string& _applicationUniqueId) { return std::shared_ptr(new airtio::Manager(_applicationUniqueId)); } airtio::Manager::Manager(const std::string& _applicationUniqueId) : m_applicationUniqueId(_applicationUniqueId), m_listOpenInterface(), m_masterVolume(0.0f), m_masterVolumeRange(std::make_pair(-120.0f, 0.0f)) { } airtio::Manager::~Manager() { // TODO : Stop all interfaces... } std::vector > airtio::Manager::getListStreamInput() { std::vector > output; output.push_back(std::make_pair("default", "48000 Hz, 16 bits, 2 channels: Default input ")); return output; } std::vector > airtio::Manager::getListStreamOutput() { std::vector > output; output.push_back(std::make_pair("default", "48000 Hz, 16 bits, 2 channels: Default output ")); return output; } // TODO : Deprecated ... void airtio::Manager::setMasterOutputVolume(float _gainDB) { if (_gainDB < m_masterVolumeRange.first) { //throw std::range_error(std::string(_gainDB) + " is out of bonds : [" + m_masterVolumeRange.first + ".." + m_masterVolumeRange.second + "]"); return; } if (_gainDB > m_masterVolumeRange.second) { //throw std::range_error(std::string(_gainDB) + " is out of bonds : [" + m_masterVolumeRange.first + ".." + m_masterVolumeRange.second + "]"); return; } m_masterVolume = _gainDB; for (auto &it : m_listOpenInterface) { std::shared_ptr tmpElem = it.lock(); if (tmpElem == nullptr) { continue; } // TODO : Deprecated ... //tmpElem->setMasterVolume(m_masterVolume); } } float airtio::Manager::getMasterOutputVolume() { return m_masterVolume; } std::pair airtio::Manager::getMasterOutputVolumeRange() { return m_masterVolumeRange; } void airtio::Manager::setSectionVolume(const std::string& _section, float _gainDB) { } float airtio::Manager::getSectionVolume(const std::string& _section) { return 0.0f; } std::pair airtio::Manager::getSectionVolumeRange(const std::string& _section) { return std::make_pair(0.0f, 0.0f); } std::shared_ptr airtio::Manager::createOutput(float _freq, const std::vector& _map, airtalgo::format _format, const std::string& _streamName, const std::string& _name) { // get global hardware interface: std::shared_ptr manager = airtio::io::Manager::getInstance(); // get the output or input channel : std::shared_ptr node = manager->getNode(_streamName, false); // create user iterface: std::shared_ptr interface; interface = airtio::Interface::create(_name, _freq, _map, _format, node); // store it in a list (needed to apply some parameters). m_listOpenInterface.push_back(interface); // TODO : DEPRECATED ... //interface->setMasterVolume(m_masterVolume); return interface; } std::shared_ptr airtio::Manager::createInput(float _freq, const std::vector& _map, airtalgo::format _format, const std::string& _streamName, const std::string& _name) { // get global hardware interface: std::shared_ptr manager = airtio::io::Manager::getInstance(); // get the output or input channel : std::shared_ptr node = manager->getNode(_streamName, true); // create user iterface: std::shared_ptr interface; interface = airtio::Interface::create(_name, _freq, _map, _format, node); // store it in a list (needed to apply some parameters). m_listOpenInterface.push_back(interface); // TODO : DEPRECATED ... //interface->setMasterVolume(m_masterVolume); return interface; }