90 lines
2.4 KiB
C++
90 lines
2.4 KiB
C++
/** @file
|
|
* @author Edouard DUPIN
|
|
* @copyright 2011, Edouard DUPIN, all right reserved
|
|
* @license APACHE v2.0 (see license file)
|
|
*/
|
|
#pragma once
|
|
|
|
#include <string>
|
|
#include <vector>
|
|
#include <stdint.h>
|
|
#include <audio/format.h>
|
|
#include <audio/channel.h>
|
|
#include <chrono>
|
|
#include <functional>
|
|
#include <ememory/memory.h>
|
|
#include "AutoLogInOut.h"
|
|
#include "debug.h"
|
|
|
|
namespace audio {
|
|
namespace drain{
|
|
class IOFormatInterface {
|
|
public:
|
|
IOFormatInterface();
|
|
IOFormatInterface(std::vector<audio::channel> _map, audio::format _format=audio::format_int16, float _frequency=48000.0f);
|
|
void set(std::vector<audio::channel> _map, audio::format _format=audio::format_int16, float _frequency=48000.0f);
|
|
protected:
|
|
bool m_configured;
|
|
public:
|
|
void setConfigured(bool _value);
|
|
bool getConfigured() const;
|
|
protected:
|
|
audio::format m_format; //!< input Algo Format
|
|
public:
|
|
/**
|
|
* @brief Get the algo format.
|
|
* @return the current Format.
|
|
*/
|
|
audio::format getFormat() const;
|
|
/**
|
|
* @brief Set the algo format.
|
|
* @param[in] _value New Format.
|
|
*/
|
|
void setFormat(audio::format _value);
|
|
protected:
|
|
std::vector<audio::channel> m_map; //!< input channel Map
|
|
public:
|
|
/**
|
|
* @brief Get the algo channel Map.
|
|
* @return the current channel Map.
|
|
*/
|
|
const std::vector<audio::channel>& getMap() const;
|
|
/**
|
|
* @brief Set the algo channel Map.
|
|
* @param[in] _value New channel Map.
|
|
*/
|
|
void setMap(const std::vector<audio::channel>& _value);
|
|
protected:
|
|
float m_frequency; //!< input Algo Format
|
|
public:
|
|
/**
|
|
* @brief Get the algo frequency.
|
|
* @return the current frequency.
|
|
*/
|
|
float getFrequency() const;
|
|
/**
|
|
* @brief Set the algo frequency.
|
|
* @param[in] _value New frequency.
|
|
*/
|
|
void setFrequency(float _value);
|
|
public:
|
|
/**
|
|
* @brief Get the Chunk size in byte.
|
|
* @return the number of byte used by chunk.
|
|
*/
|
|
int32_t getChunkSize() const;
|
|
protected:
|
|
std::function<void()> m_ioChangeFunctor; //!< function pointer on the upper class
|
|
void configurationChange();
|
|
public:
|
|
/**
|
|
* @brief Set the callback function to be notify when the arameter change.
|
|
* @param[in] _functor Function to call.
|
|
*/
|
|
void setCallback(const std::function<void()>& _functor);
|
|
};
|
|
std::ostream& operator <<(std::ostream& _os, const audio::drain::IOFormatInterface& _obj);
|
|
}
|
|
}
|
|
|