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
|
/*************************************************************************
ZeroPlugin.h - wipes out the selected range of samples to zero
-------------------
begin : Fri Jun 01 2001
copyright : (C) 2001 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 ZERO_PLUGIN_H
#define ZERO_PLUGIN_H
#include "config.h"
#include <QString>
#include <QStringList>
#include "libkwave/Plugin.h"
#include "libkwave/Sample.h"
#include "libkwave/SampleArray.h"
namespace Kwave
{
/**
* @class ZeroPlugin
* This is a very simple plugin that blanks the currently selected range of
* samples with zeroes.
*/
class ZeroPlugin: public Kwave::Plugin
{
Q_OBJECT
public:
/**
* Constructor
* @param parent reference to our plugin manager
* @param args argument list [unused]
*/
ZeroPlugin(QObject *parent, const QVariantList &args);
/** Destructor */
~ZeroPlugin() override;
/**
* Fills the selected area with zeroes
* @param params list of strings with parameters
*/
void run(QStringList params) override;
private:
/** use an array with zeroes for faster filling */
Kwave::SampleArray m_zeroes;
};
}
#endif /* ZERO_PLUGIN_H */
//***************************************************************************
//***************************************************************************
|