mirror of
https://github.com/LMMS/lmms.git
synced 2026-02-24 10:17:59 -05:00
* Give our threads names It helps with debugging. * Use Q_OBJECT macro to automatically name threads. By default, QThread sets its name based on the Qt meta class. To get an accurate metaclass, the class which inherits QThread must declare Q_OBJECT in its header. Futhermore, Qt's MOC requires that a Qt type be the primary base class when declaring Q_OBJECT, hence the order of base classes has been rearranged for some classes.
119 lines
2.3 KiB
C++
119 lines
2.3 KiB
C++
/*
|
|
* AudioDummy.h - dummy audio-device
|
|
*
|
|
* Copyright (c) 2004-2014 Tobias Doerffel <tobydox/at/users.sourceforge.net>
|
|
*
|
|
* This file is part of LMMS - https://lmms.io
|
|
*
|
|
* 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_DUMMY_H
|
|
#define AUDIO_DUMMY_H
|
|
|
|
#include "AudioDevice.h"
|
|
#include "AudioDeviceSetupWidget.h"
|
|
#include "MicroTimer.h"
|
|
#include "Mixer.h"
|
|
|
|
|
|
class AudioDummy : public QThread, public AudioDevice
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
AudioDummy( bool & _success_ful, Mixer* mixer ) :
|
|
AudioDevice( DEFAULT_CHANNELS, mixer )
|
|
{
|
|
_success_ful = true;
|
|
}
|
|
|
|
virtual ~AudioDummy()
|
|
{
|
|
stopProcessing();
|
|
}
|
|
|
|
inline static QString name()
|
|
{
|
|
return QT_TRANSLATE_NOOP( "setupWidget", "Dummy (no sound output)" );
|
|
}
|
|
|
|
|
|
class setupWidget : public AudioDeviceSetupWidget
|
|
{
|
|
public:
|
|
setupWidget( QWidget * _parent ) :
|
|
AudioDeviceSetupWidget( AudioDummy::name(), _parent )
|
|
{
|
|
}
|
|
|
|
virtual ~setupWidget()
|
|
{
|
|
}
|
|
|
|
virtual void saveSettings()
|
|
{
|
|
}
|
|
|
|
virtual void show()
|
|
{
|
|
parentWidget()->hide();
|
|
QWidget::show();
|
|
}
|
|
|
|
} ;
|
|
|
|
|
|
private:
|
|
virtual void startProcessing()
|
|
{
|
|
start();
|
|
}
|
|
|
|
virtual void stopProcessing()
|
|
{
|
|
stopProcessingThread( this );
|
|
}
|
|
|
|
virtual void run()
|
|
{
|
|
MicroTimer timer;
|
|
while( true )
|
|
{
|
|
timer.reset();
|
|
const surroundSampleFrame* b = mixer()->nextBuffer();
|
|
if( !b )
|
|
{
|
|
break;
|
|
}
|
|
if( mixer()->hasFifoWriter() )
|
|
{
|
|
delete[] b;
|
|
}
|
|
|
|
const int microseconds = static_cast<int>( mixer()->framesPerPeriod() * 1000000.0f / mixer()->processingSampleRate() - timer.elapsed() );
|
|
if( microseconds > 0 )
|
|
{
|
|
usleep( microseconds );
|
|
}
|
|
}
|
|
}
|
|
|
|
} ;
|
|
|
|
|
|
#endif
|