* (at your option) any later version. *
***************************************************************************/
+/**
+ Displays a spectral power distribution of audio samples.
+ The frequency distribution is calculated by means of a Fast Fourier Transformation.
+ For more information see Wikipedia:FFT and the code comments.
+*/
+
#ifndef AUDIOSPECTRUM_H
#define AUDIOSPECTRUM_H
#include "abstractaudioscopewidget.h"
#include "ui_audiospectrum_ui.h"
#include "tools/kiss_fftr.h"
+#include "ffttools.h"
class AudioSpectrum_UI;
class AudioSpectrum : public AbstractAudioScopeWidget {
private:
Ui::AudioSpectrum_UI *ui;
- kiss_fftr_cfg m_cfg;
- QHash<QString, QVector<float> > m_windowFunctions;
QAction *m_aResetHz;
- // Contains the plot only; m_scopeRect contains text and widgets as well
+ FFTTools m_fftTools;
+
+ /** Contains the plot only; m_scopeRect contains text and widgets as well */
QRect m_innerScopeRect;
/** Lower bound for the dB value to display */
/** Upper bound (max: 0) */
int m_dBmax;
- /** Maximum frequency (depends on the sampling rate)
- Stored for the HUD painter */
+ /** Maximum frequency (limited by the sampling rate if determined automatically).
+ Stored for the painters. */
uint m_freqMax;
/** The user has chosen a custom frequency. */
bool m_customFreq;
+ /** Returns a signature for a kiss_fft configuration
+ used as a hash in the cache */
+ static const QString cfgSignature(const int size);
+
+
///// Movement detection /////
const int m_rescaleMinDist;
const float m_rescaleVerticalThreshold;
private slots:
- void slotUpdateCfg();
void slotResetMaxFreq();
};