1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
|
/***************************************************************************
LowPassPlugin.cpp - Plugin for simple lowpass filtering
-------------------
begin : Fri Mar 07 2003
copyright : (C) 2003 by Thomas Eschenbacher
email : Thomas.Eschenbacher@gmx.de
***************************************************************************/
/***************************************************************************
* *
* 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. *
* *
***************************************************************************/
#include "config.h"
#include <errno.h>
#include <math.h>
#include <new>
#include <QStringList>
#include <KLocalizedString>
#include "LowPassDialog.h"
#include "LowPassFilter.h"
#include "LowPassPlugin.h"
#include "libkwave/MultiTrackSource.h"
KWAVE_PLUGIN(lowpass, LowPassPlugin)
//***************************************************************************
Kwave::LowPassPlugin::LowPassPlugin(QObject *parent,
const QVariantList &args)
:Kwave::FilterPlugin(parent, args),
m_frequency(3500.0), m_last_freq(100)
{
}
//***************************************************************************
Kwave::LowPassPlugin::~LowPassPlugin()
{
}
//***************************************************************************
int Kwave::LowPassPlugin::interpreteParameters(QStringList ¶ms)
{
bool ok;
QString param;
// evaluate the parameter list
if (params.count() != 1) return -EINVAL;
param = params[0];
m_frequency = param.toDouble(&ok);
Q_ASSERT(ok);
if (!ok) return -EINVAL;
return 0;
}
//***************************************************************************
Kwave::PluginSetupDialog *Kwave::LowPassPlugin::createDialog(QWidget *parent)
{
Kwave::LowPassDialog *dialog =
new(std::nothrow) Kwave::LowPassDialog(parent, signalRate());
Q_ASSERT(dialog);
if (!dialog) return nullptr;
// connect the signals for detecting value changes in pre-listen mode
connect(dialog, SIGNAL(changed(double)),
this, SLOT(setValue(double)));
return dialog;
}
//***************************************************************************
Kwave::SampleSource *Kwave::LowPassPlugin::createFilter(unsigned int tracks)
{
return new(std::nothrow)
Kwave::MultiTrackSource<Kwave::LowPassFilter, true>(tracks);
}
//***************************************************************************
bool Kwave::LowPassPlugin::paramsChanged()
{
return (!qFuzzyCompare(m_frequency, m_last_freq));
}
//***************************************************************************
void Kwave::LowPassPlugin::updateFilter(Kwave::SampleSource *filter,
bool force)
{
double sr = signalRate();
if (!filter) return;
if (!qFuzzyCompare(m_frequency, m_last_freq) || force)
filter->setAttribute(SLOT(setFrequency(QVariant)),
QVariant((m_frequency * 2.0 * M_PI) / sr));
m_last_freq = m_frequency;
}
//***************************************************************************
QString Kwave::LowPassPlugin::actionName()
{
return i18n("Low Pass");
}
//***************************************************************************
void Kwave::LowPassPlugin::setValue(double frequency)
{
m_frequency = frequency;
}
//***************************************************************************
#include "LowPassPlugin.moc"
//***************************************************************************
//***************************************************************************
#include "moc_LowPassPlugin.cpp"
|