Mercurial > hg > easaier-soundaccess
diff layer/SpectrumLayer.h @ 0:fc9323a41f5a
start base : Sonic Visualiser sv1-1.0rc1
author | lbajardsilogic |
---|---|
date | Fri, 11 May 2007 09:08:14 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/layer/SpectrumLayer.h Fri May 11 09:08:14 2007 +0000 @@ -0,0 +1,100 @@ + +/* -*- 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