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
|
/***************************************************************************
LowPassPlugin.h - 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. *
* *
***************************************************************************/
#ifndef LOW_PASS_PLUGIN_H
#define LOW_PASS_PLUGIN_H
#include "config.h"
#include <QObject>
#include <QString>
#include <QStringList>
#include "libkwave/Plugin.h"
#include "libkwave/PluginSetupDialog.h"
#include "libgui/FilterPlugin.h"
namespace Kwave
{
class LowPassPlugin: public Kwave::FilterPlugin
{
Q_OBJECT
public:
/**
* Constructor
* @param parent reference to our plugin manager
* @param args argument list [unused]
*/
LowPassPlugin(QObject *parent, const QVariantList &args);
/** Destructor */
~LowPassPlugin() override;
/** Creates the setup dialog and connects it's signals */
virtual Kwave::PluginSetupDialog *createDialog(QWidget *parent)
override;
/**
* Creates a multi-track filter with the given number of tracks
* @param tracks number of tracks that the filter should have
* @return pointer to the filter or null if failed
*/
virtual Kwave::SampleSource *createFilter(unsigned int tracks)
override;
/**
* Returns true if the parameters have changed during pre-listen.
*/
bool paramsChanged() override;
/**
* Update the filter with new parameters if it has changed
* changed during the pre-listen.
* @param filter the Kwave::SampleSource to be updated, should be the
* same one as created with createFilter()
* @param force if true, even update if no settings have changed
*/
virtual void updateFilter(Kwave::SampleSource *filter,
bool force = false) override;
/**
* Returns a verbose name of the performed action. Used for giving
* the undo action a readable name.
*/
QString actionName() override;
protected:
/** Reads values from the parameter list */
int interpreteParameters(QStringList ¶ms) override;
protected slots:
/**
* Called when the parameter changed during pre-listen
* @param frequency the frequency parameter in Hz
*/
void setValue(double frequency);
private:
/** cutoff frequency [Hz] */
double m_frequency;
/** last value of m_frequency */
double m_last_freq;
};
}
#endif /* LOW_PASS_PLUGIN_H */
//***************************************************************************
//***************************************************************************
|