2019-04-10 20:00:54 +02:00
|
|
|
/******************************************************************************\
|
|
|
|
*
|
|
|
|
* Author(s):
|
|
|
|
* pljones
|
|
|
|
*
|
|
|
|
******************************************************************************
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it under
|
|
|
|
* the terms of the GNU General Public License as published by the Free Software
|
|
|
|
* Foundation; either version 2 of the License, or (at your option) any later
|
|
|
|
* version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
|
|
* details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along with
|
|
|
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*
|
|
|
|
\******************************************************************************/
|
|
|
|
|
2019-07-09 08:52:38 +02:00
|
|
|
#pragma once
|
2019-04-03 19:12:45 +02:00
|
|
|
|
|
|
|
#include <QDataStream>
|
|
|
|
|
|
|
|
namespace recorder {
|
|
|
|
|
|
|
|
class HdrRiff
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
HdrRiff() {}
|
|
|
|
|
|
|
|
static const uint32_t chunkId = 0x46464952; // RIFF
|
|
|
|
static const uint32_t chunkSize = 0xffffffff; // (will be overwritten) Size of file in bytes - 8 = size of data + 36
|
|
|
|
static const uint32_t format = 0x45564157; // WAVE
|
|
|
|
};
|
|
|
|
|
|
|
|
class FmtSubChunk
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
FmtSubChunk(const uint16_t _numChannels) :
|
|
|
|
numChannels (_numChannels)
|
|
|
|
, byteRate (sampleRate * numChannels * bitsPerSample/8)
|
|
|
|
, blockAlign (numChannels * bitsPerSample/8)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
static const uint32_t chunkId = 0x20746d66; // "fmt "
|
|
|
|
static const uint32_t chunkSize = 16; // bytes in fmtSubChunk after chunkSize
|
|
|
|
static const uint16_t audioFormat = 1; // PCM
|
|
|
|
const uint16_t numChannels; // 1 for mono, 2 for joy... uh, stereo
|
|
|
|
static const uint32_t sampleRate = 48000; // because it's Jamulus
|
|
|
|
const uint32_t byteRate; // sampleRate * numChannels * bitsPerSample/8
|
|
|
|
const uint16_t blockAlign; // numChannels * bitsPerSample/8
|
|
|
|
static const uint16_t bitsPerSample = 16;
|
|
|
|
};
|
|
|
|
|
|
|
|
class DataSubChunkHdr
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DataSubChunkHdr() {}
|
|
|
|
|
|
|
|
static const uint32_t chunkId = 0x61746164; // "data"
|
|
|
|
static const uint32_t chunkSize = 0xffffffff; // (will be overwritten) Size of data
|
|
|
|
};
|
|
|
|
|
|
|
|
class CWaveStream : public QDataStream
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
CWaveStream(const uint16_t numChannels);
|
|
|
|
explicit CWaveStream(QIODevice *iod, const uint16_t numChannels);
|
|
|
|
CWaveStream(QByteArray *iod, QIODevice::OpenMode flags, const uint16_t numChannels);
|
|
|
|
CWaveStream(const QByteArray &ba, const uint16_t numChannels);
|
2019-04-21 23:13:07 +02:00
|
|
|
|
|
|
|
void finalise();
|
2019-04-03 19:12:45 +02:00
|
|
|
|
|
|
|
private:
|
|
|
|
void waveStreamHeaders();
|
|
|
|
|
|
|
|
const uint16_t numChannels;
|
|
|
|
const int64_t initialPos;
|
|
|
|
const ByteOrder initialByteOrder;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
recorder::CWaveStream& operator<<(recorder::CWaveStream& out, recorder::HdrRiff& hdrRiff);
|
|
|
|
recorder::CWaveStream& operator<<(recorder::CWaveStream& out, recorder::FmtSubChunk& fmtSubChunk);
|
|
|
|
recorder::CWaveStream& operator<<(recorder::CWaveStream& out, recorder::DataSubChunkHdr& dataSubChunkHdr);
|