annotate layer/SpectrumLayer.h @ 335:2f83b6e3b8ca

* Add Erase tool and mode * Add icons for Normalize buttons in property boxes, and for Show Peaks * Add support for velocity in notes -- not yet reflected in display or editable in the note edit dialog, but they are imported from MIDI, played, and exported * Begin work on making pastes align pasted times (subtler than I thought)
author Chris Cannam
date Fri, 23 Nov 2007 16:48:23 +0000
parents c0b9eec70639
children 369a197737c7
rev   line source
Chris@133 1
Chris@133 2 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@133 3
Chris@133 4 /*
Chris@133 5 Sonic Visualiser
Chris@133 6 An audio file viewer and annotation editor.
Chris@133 7 Centre for Digital Music, Queen Mary, University of London.
Chris@182 8 This file copyright 2006 QMUL.
Chris@133 9
Chris@133 10 This program is free software; you can redistribute it and/or
Chris@133 11 modify it under the terms of the GNU General Public License as
Chris@133 12 published by the Free Software Foundation; either version 2 of the
Chris@133 13 License, or (at your option) any later version. See the file
Chris@133 14 COPYING included with this distribution for more information.
Chris@133 15 */
Chris@133 16
Chris@133 17 #ifndef _SPECTRUM_LAYER_H_
Chris@133 18 #define _SPECTRUM_LAYER_H_
Chris@133 19
Chris@193 20 #include "SliceLayer.h"
Chris@133 21
Chris@153 22 #include "base/Window.h"
Chris@153 23
Chris@133 24 #include "data/model/DenseTimeValueModel.h"
Chris@133 25
Chris@133 26 #include <QColor>
Chris@133 27
Chris@133 28 class FFTModel;
Chris@133 29
Chris@193 30 class SpectrumLayer : public SliceLayer
Chris@133 31 {
Chris@133 32 Q_OBJECT
Chris@133 33
Chris@133 34 public:
Chris@133 35 SpectrumLayer();
Chris@133 36 ~SpectrumLayer();
Chris@133 37
Chris@133 38 void setModel(DenseTimeValueModel *model);
Chris@193 39 virtual const Model *getModel() const { return m_originModel; }
Chris@133 40
Chris@254 41 virtual bool getCrosshairExtents(View *, QPainter &, QPoint cursorPos,
Chris@254 42 std::vector<QRect> &extents) const;
Chris@254 43 virtual void paintCrosshairs(View *, QPainter &, QPoint) const;
Chris@254 44
Chris@199 45 virtual QString getFeatureDescription(View *v, QPoint &) const;
Chris@199 46
Chris@275 47 virtual void paint(View *v, QPainter &paint, QRect rect) const;
Chris@275 48
Chris@277 49 virtual VerticalPosition getPreferredFrameCountPosition() const {
Chris@277 50 return PositionTop;
Chris@277 51 }
Chris@277 52
Chris@153 53 virtual PropertyList getProperties() const;
Chris@153 54 virtual QString getPropertyLabel(const PropertyName &) const;
Chris@335 55 virtual QString getPropertyIconName(const PropertyName &) const;
Chris@153 56 virtual PropertyType getPropertyType(const PropertyName &) const;
Chris@153 57 virtual QString getPropertyGroupName(const PropertyName &) const;
Chris@153 58 virtual int getPropertyRangeAndValue(const PropertyName &,
Chris@216 59 int *min, int *max, int *deflt) const;
Chris@153 60 virtual QString getPropertyValueLabel(const PropertyName &,
Chris@153 61 int value) const;
Chris@167 62 virtual RangeMapper *getNewPropertyRangeMapper(const PropertyName &) const;
Chris@153 63 virtual void setProperty(const PropertyName &, int value);
Chris@133 64 virtual void setProperties(const QXmlAttributes &);
Chris@133 65
Chris@133 66 virtual bool getValueExtents(float &min, float &max,
Chris@133 67 bool &logarithmic, QString &unit) const;
Chris@133 68
Chris@267 69 virtual bool getXScaleValue(const View *v, int x,
Chris@260 70 float &value, QString &unit) const;
Chris@260 71
Chris@274 72 virtual bool getYScaleValue(const View *, int y,
Chris@274 73 float &value, QString &unit) const;
Chris@274 74
Chris@274 75 virtual bool getYScaleDifference(const View *, int y0, int y1,
Chris@274 76 float &diff, QString &unit) const;
Chris@274 77
Chris@248 78 virtual bool isLayerScrollable(const View *) const { return false; }
Chris@133 79
Chris@153 80 void setChannel(int);
Chris@153 81 int getChannel() const { return m_channel; }
Chris@153 82
Chris@153 83 void setWindowSize(size_t);
Chris@153 84 size_t getWindowSize() const { return m_windowSize; }
Chris@153 85
Chris@153 86 void setWindowHopLevel(size_t level);
Chris@153 87 size_t getWindowHopLevel() const { return m_windowHopLevel; }
Chris@153 88
Chris@153 89 void setWindowType(WindowType type);
Chris@153 90 WindowType getWindowType() const { return m_windowType; }
Chris@153 91
Chris@284 92 void setShowPeaks(bool);
Chris@284 93 bool getShowPeaks() const { return m_showPeaks; }
Chris@284 94
Chris@316 95 virtual void toXml(QTextStream &stream, QString indent = "",
Chris@316 96 QString extraAttributes = "") const;
Chris@153 97
Chris@153 98 protected slots:
Chris@153 99 void preferenceChanged(PropertyContainer::PropertyName name);
Chris@133 100
Chris@133 101 protected:
Chris@193 102 // make this SliceLayer method unavailable to the general public
Chris@193 103 // virtual void setModel(DenseThreeDimensionalModel *model) {
Chris@193 104 // SliceLayer::setModel(model);
Chris@193 105 // }
Chris@193 106
Chris@193 107 DenseTimeValueModel *m_originModel;
Chris@153 108 int m_channel;
Chris@153 109 bool m_channelSet;
Chris@153 110 size_t m_windowSize;
Chris@153 111 WindowType m_windowType;
Chris@153 112 size_t m_windowHopLevel;
Chris@284 113 bool m_showPeaks;
Chris@275 114 mutable bool m_newFFTNeeded;
Chris@153 115
Chris@193 116 void setupFFT();
Chris@153 117
Chris@254 118 virtual void getBiasCurve(BiasCurve &) const;
Chris@254 119 BiasCurve m_biasCurve;
Chris@254 120
Chris@265 121 virtual float getXForBin(int bin, int totalBins, float w) const;
Chris@265 122 virtual int getBinForX(float x, int totalBins, float w) const;
Chris@265 123
Chris@254 124 float getFrequencyForX(float x, float w) const;
Chris@254 125 float getXForFrequency(float freq, float w) const;
Chris@254 126
Chris@153 127 size_t getWindowIncrement() const {
Chris@153 128 if (m_windowHopLevel == 0) return m_windowSize;
Chris@153 129 else if (m_windowHopLevel == 1) return (m_windowSize * 3) / 4;
Chris@153 130 else return m_windowSize / (1 << (m_windowHopLevel - 1));
Chris@153 131 }
Chris@133 132 };
Chris@133 133
Chris@133 134 #endif