audio-river/river/Manager.h

111 lines
4.3 KiB
C
Raw Normal View History

2015-01-25 22:17:06 +01:00
/** @file
* @author Edouard DUPIN
* @copyright 2015, Edouard DUPIN, all right reserved
* @license APACHE v2.0 (see license file)
*/
#ifndef __RIVER_MANAGER_H__
#define __RIVER_MANAGER_H__
2015-01-25 22:17:06 +01:00
#include <string>
#include <stdint.h>
2015-02-25 22:05:00 +01:00
#include <etk/memory.h>
2015-02-05 19:10:53 +01:00
#include <river/Interface.h>
#include <audio/format.h>
#include <audio/channel.h>
2015-02-12 22:08:23 +01:00
#include <ejson/ejson.h>
2015-01-25 22:17:06 +01:00
2015-02-05 19:10:53 +01:00
namespace river {
2015-01-25 22:17:06 +01:00
/**
* @brief Audio interface manager : Single interface for every application that want to access on the Audio input/output
*/
class Manager {
private:
2015-02-12 22:08:23 +01:00
ejson::Document m_config; // virtual configuration
2015-01-25 22:17:06 +01:00
const std::string& m_applicationUniqueId; //!< name of the application that open the Audio Interface.
2015-02-24 22:20:11 +01:00
std::vector<std11::weak_ptr<river::Interface> > m_listOpenInterface; //!< List of all open Stream.
2015-01-25 22:17:06 +01:00
protected:
/**
* @brief Constructor
*/
2015-01-26 22:04:29 +01:00
Manager(const std::string& _applicationUniqueId);
2015-01-25 22:17:06 +01:00
public:
2015-02-24 22:20:11 +01:00
static std11::shared_ptr<river::Manager> create(const std::string& _applicationUniqueId);
2015-01-25 22:17:06 +01:00
/**
* @brief Destructor
*/
2015-01-26 22:04:29 +01:00
virtual ~Manager();
2015-01-25 22:17:06 +01:00
public:
/**
* @brief Get all input audio stream description.
* @return a list of all availlables input stream (name + description)
*/
2015-01-26 22:04:29 +01:00
virtual std::vector<std::pair<std::string,std::string> > getListStreamInput();
2015-01-25 22:17:06 +01:00
/**
* @brief Get all output audio stream description.
* @return a list of all availlables output stream (name + description)
*/
2015-01-26 22:04:29 +01:00
virtual std::vector<std::pair<std::string,std::string> > getListStreamOutput();
2015-01-25 22:17:06 +01:00
/**
2015-02-04 21:08:06 +01:00
* @brief Set a volume for a specific group
* @param[in] _volumeName Name of the volume (MASTER, MATER_BT ...)
* @param[in] _value Volume in dB to set.
2015-01-30 21:44:36 +01:00
* @return true set done
* @return false An error occured
2015-02-04 21:08:06 +01:00
* @example : setVolume("MASTER", -3.0f);
2015-01-25 22:17:06 +01:00
*/
2015-02-04 21:08:06 +01:00
virtual bool setVolume(const std::string& _volumeName, float _valuedB);
2015-01-25 22:17:06 +01:00
/**
2015-02-04 21:08:06 +01:00
* @brief Get a volume value
* @param[in] _volumeName Name of the volume (MASTER, MATER_BT ...)
* @return The Volume value in dB.
* @example ret = getVolume("MASTER"); can return something like ret = -3.0f
2015-01-25 22:17:06 +01:00
*/
2015-02-04 21:08:06 +01:00
virtual float getVolume(const std::string& _volumeName) const;
2015-01-25 22:17:06 +01:00
/**
2015-01-30 21:44:36 +01:00
* @brief Get a parameter value
2015-02-04 21:08:06 +01:00
* @param[in] _volumeName Name of the volume (MASTER, MATER_BT ...)
* @return The requested value Range.
* @example ret = getVolumeRange("MASTER"); can return something like ret=(-120.0f,0.0f)
2015-01-25 22:17:06 +01:00
*/
2015-02-04 21:08:06 +01:00
virtual std::pair<float,float> getVolumeRange(const std::string& _volumeName) const;
2015-01-25 22:17:06 +01:00
/**
* @brief Create output Interface
* @param[in] _freq Frequency to open Interface [8,16,22,32,48] kHz
* @param[in] _map ChannelMap of the Output
* @param[in] _format Sample Format to open the stream [int8_t]
* @param[in] _streamName Stream name to open: "" or "default" open current selected output
* @param[in] _name Name of this interface
* @return a pointer on the interface
*/
2015-02-24 22:20:11 +01:00
virtual std11::shared_ptr<Interface> createOutput(float _freq,
const std::vector<audio::channel>& _map,
audio::format _format,
2015-01-25 22:17:06 +01:00
const std::string& _streamName = "",
const std::string& _name = "");
/**
* @brief Create input Interface
* @param[in] _freq Frequency to open Interface [8,16,22,32,48] kHz
* @param[in] _map ChannelMap of the Output
* @param[in] _format Sample Format to open the stream [int8_t]
* @param[in] _streamName Stream name to open: "" or "default" open current selected input
* @param[in] _name Name of this interface
* @return a pointer on the interface
*/
2015-02-24 22:20:11 +01:00
virtual std11::shared_ptr<Interface> createInput(float _freq,
const std::vector<audio::channel>& _map,
audio::format _format,
2015-01-25 22:17:06 +01:00
const std::string& _streamName = "",
const std::string& _name = "");
2015-02-18 15:22:48 +01:00
/**
* @brief Generate the dot file corresponding at all the actif nodes.
* @param[in] _filename Name of the file to write data.
*/
virtual void generateDotAll(const std::string& _filename);
2015-01-25 22:17:06 +01:00
};
};
#endif