mirror of
https://github.com/LMMS/lmms.git
synced 2026-03-10 01:58:44 -04:00
Until now, Mixer not only was responsible for rendering audio buffers but also managed writing them to audio backend (through a FIFO) and handled various quality related parameters. All this functionality has been moved into the new AudioOutputContext class. It glues together AudioBackend (formerly called AudioDevice), global quality settings and the Mixer. The AudioOutputContext class creates a FifoWriter which calls Mixer::renderNextBuffer() and writes the output into the BufferFifo of the AudioOutputContext it belongs to. The BufferFifo is read by the according AudioBackend which belongs to the AudioOutputContext as well. The AudioOutputContext also handles resampling in case the AudioBackend wants the buffers in a different samplerate. During this rewrite the Mixer class and the according source files have been renamed from "mixer" to "Mixer". This results in small changes all over LMMS' code base.
60 lines
1.7 KiB
C++
60 lines
1.7 KiB
C++
/*
|
|
* AudioSampleRecorder.h - device-class that implements recording
|
|
* audio-buffers into RAM
|
|
*
|
|
* Copyright (c) 2004-2009 Tobias Doerffel <tobydox/at/users.sourceforge.net>
|
|
*
|
|
* This file is part of Linux MultiMedia Studio - http://lmms.sourceforge.net
|
|
*
|
|
* 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 (see COPYING); if not, write to the
|
|
* Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
* Boston, MA 02110-1301 USA.
|
|
*
|
|
*/
|
|
|
|
#ifndef _AUDIO_SAMPLE_RECORDER_H
|
|
#define _AUDIO_SAMPLE_RECORDER_H
|
|
|
|
#include <QtCore/QList>
|
|
#include <QtCore/QPair>
|
|
|
|
#include "AudioBackend.h"
|
|
|
|
class sampleBuffer;
|
|
|
|
|
|
class AudioSampleRecorder : public AudioBackend
|
|
{
|
|
public:
|
|
AudioSampleRecorder( const ch_cnt_t _channels, bool & _success_ful,
|
|
AudioOutputContext * context );
|
|
virtual ~AudioSampleRecorder();
|
|
|
|
f_cnt_t framesRecorded() const;
|
|
void createSampleBuffer( sampleBuffer * * _sample_buf );
|
|
|
|
|
|
private:
|
|
virtual void writeBuffer( const sampleFrameA * _ab,
|
|
const fpp_t _frames,
|
|
const float _master_gain );
|
|
|
|
typedef QList<QPair<sampleFrameA *, fpp_t> > BufferList;
|
|
BufferList m_buffers;
|
|
|
|
} ;
|
|
|
|
|
|
#endif
|