audio-drain/audio/drain/EndPointWrite.h

85 lines
2.8 KiB
C
Raw Normal View History

2015-04-10 23:00:13 +02:00
/** @file
* @author Edouard DUPIN
* @copyright 2011, Edouard DUPIN, all right reserved
* @license APACHE v2.0 (see license file)
*/
#pragma once
2015-04-10 23:00:13 +02:00
#include <audio/drain/EndPoint.h>
2015-09-14 21:11:04 +02:00
#include <functional>
#include <mutex>
2015-04-10 23:00:13 +02:00
#include <audio/drain/CircularBuffer.h>
namespace audio {
namespace drain{
typedef std::function<void (const audio::Time& _time,
2015-04-10 23:00:13 +02:00
size_t _nbChunk,
enum audio::format _format,
uint32_t _frequency,
const std::vector<audio::channel>& _map)> playbackFunctionWrite;
class EndPointWrite : public EndPoint {
private:
audio::drain::CircularBuffer m_buffer;
playbackFunctionWrite m_function;
std::mutex m_mutex;
2015-04-10 23:00:13 +02:00
protected:
/**
* @brief Constructor
*/
EndPointWrite();
void init();
public:
static std::shared_ptr<audio::drain::EndPointWrite> create();
2015-04-10 23:00:13 +02:00
/**
* @brief Destructor
*/
virtual ~EndPointWrite() {};
virtual void configurationChange();
2015-04-13 21:49:48 +02:00
virtual bool process(audio::Time& _time,
2015-04-10 23:00:13 +02:00
void* _input,
size_t _inputNbChunk,
void*& _output,
size_t& _outputNbChunk);
virtual void write(const void* _value, size_t _nbChunk);
virtual void setCallback(playbackFunctionWrite _function) {
m_function = _function;
}
protected:
std::chrono::microseconds m_bufferSizeMicroseconds; // 0 if m_bufferSizeChunk != 0
2015-04-10 23:00:13 +02:00
size_t m_bufferSizeChunk; // 0 if m_bufferSizeMicroseconds != 0
public:
/**
* @brief Set buffer size in chunk number
* @param[in] _nbChunk Number of chunk in the buffer
*/
virtual void setBufferSize(size_t _nbChunk);
/**
* @brief Set buffer size size of the buffer with the stored time in <EFBFBD>s
* @param[in] _time Time in microsecond of the buffer
*/
virtual void setBufferSize(const std::chrono::microseconds& _time);
2015-04-10 23:00:13 +02:00
/**
* @brief get buffer size in chunk number
* @return Number of chunk that can be written in the buffer
*/
virtual size_t getBufferSize();
/**
* @brief Set buffer size size of the buffer with the stored time in <EFBFBD>s
* @return Time in microsecond that can be written in the buffer
*/
virtual std::chrono::microseconds getBufferSizeMicrosecond();
2015-04-10 23:00:13 +02:00
/**
* @brief Get buffer size filled in chunk number
* @return Number of chunk in the buffer (that might be read/write)
*/
virtual size_t getBufferFillSize();
/**
* @brief Set buffer size size of the buffer with the stored time in <EFBFBD>s
* @return Time in microsecond of the buffer (that might be read/write)
*/
virtual std::chrono::microseconds getBufferFillSizeMicrosecond();
2015-04-10 23:00:13 +02:00
};
}
}