Mercurial > hg > svgui
view layer/SpectrumLayer.h @ 252:8d89f8869cfb
* don't store fft values scaled by fftsize/2; that's a special requirement
for the spectrogram, and other applications will not expect it -- make the
spectrogram do that scaling itself
* add a higher-resolution memory cache (still polar, though) as an alternative
to the 16-bit compact cache
* don't use the memory cache if we want rectangular coords (unless the disc
cache is totally infeasible) as conversion slows it down anyway
* avoid redundant rectangular -> polar -> rectangular conversion when storing
values in a rectangular-mode disc cache
author | Chris Cannam |
---|---|
date | Fri, 01 Jun 2007 13:56:35 +0000 |
parents | 28c8e8e3c537 |
children | a2ae3d93c645 |
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ /* Sonic Visualiser An audio file viewer and annotation editor. Centre for Digital Music, Queen Mary, University of London. This file copyright 2006 QMUL. 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. See the file COPYING included with this distribution for more information. */ #ifndef _SPECTRUM_LAYER_H_ #define _SPECTRUM_LAYER_H_ #include "SliceLayer.h" #include "base/Window.h" #include "data/model/DenseTimeValueModel.h" #include <QColor> class FFTModel; class SpectrumLayer : public SliceLayer { Q_OBJECT public: SpectrumLayer(); ~SpectrumLayer(); void setModel(DenseTimeValueModel *model); virtual const Model *getModel() const { return m_originModel; } virtual QString getFeatureDescription(View *v, QPoint &) const; virtual PropertyList getProperties() const; virtual QString getPropertyLabel(const PropertyName &) const; virtual PropertyType getPropertyType(const PropertyName &) const; virtual QString getPropertyGroupName(const PropertyName &) const; virtual int getPropertyRangeAndValue(const PropertyName &, int *min, int *max, int *deflt) const; virtual QString getPropertyValueLabel(const PropertyName &, int value) const; virtual RangeMapper *getNewPropertyRangeMapper(const PropertyName &) const; virtual void setProperty(const PropertyName &, int value); virtual void setProperties(const QXmlAttributes &); virtual bool getValueExtents(float &min, float &max, bool &logarithmic, QString &unit) const; virtual bool isLayerScrollable(const View *) const { return false; } void setChannel(int); int getChannel() const { return m_channel; } void setWindowSize(size_t); size_t getWindowSize() const { return m_windowSize; } void setWindowHopLevel(size_t level); size_t getWindowHopLevel() const { return m_windowHopLevel; } void setWindowType(WindowType type); WindowType getWindowType() const { return m_windowType; } virtual QString toXmlString(QString indent = "", QString extraAttributes = "") const; protected slots: void preferenceChanged(PropertyContainer::PropertyName name); protected: // make this SliceLayer method unavailable to the general public // virtual void setModel(DenseThreeDimensionalModel *model) { // SliceLayer::setModel(model); // } DenseTimeValueModel *m_originModel; int m_channel; bool m_channelSet; size_t m_windowSize; WindowType m_windowType; size_t m_windowHopLevel; void setupFFT(); size_t getWindowIncrement() const { if (m_windowHopLevel == 0) return m_windowSize; else if (m_windowHopLevel == 1) return (m_windowSize * 3) / 4; else return m_windowSize / (1 << (m_windowHopLevel - 1)); } }; #endif