annotate layer/Colour3DPlotLayer.h @ 738:d26545a2a02d tonioni

Rather than undrawing the bottom bit of the dial, don't draw it in the first place (necessary on shaded background)
author Chris Cannam
date Thu, 06 Mar 2014 13:52:33 +0000
parents 67e6d518ac27
children c27a3604fe6f
rev   line source
Chris@58 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@0 2
Chris@0 3 /*
Chris@59 4 Sonic Visualiser
Chris@59 5 An audio file viewer and annotation editor.
Chris@59 6 Centre for Digital Music, Queen Mary, University of London.
Chris@182 7 This file copyright 2006 Chris Cannam and QMUL.
Chris@0 8
Chris@59 9 This program is free software; you can redistribute it and/or
Chris@59 10 modify it under the terms of the GNU General Public License as
Chris@59 11 published by the Free Software Foundation; either version 2 of the
Chris@59 12 License, or (at your option) any later version. See the file
Chris@59 13 COPYING included with this distribution for more information.
Chris@0 14 */
Chris@0 15
Chris@0 16 #ifndef _COLOUR_3D_PLOT_H_
Chris@0 17 #define _COLOUR_3D_PLOT_H_
Chris@0 18
Chris@193 19 #include "SliceableLayer.h"
Chris@0 20
Chris@128 21 #include "data/model/DenseThreeDimensionalModel.h"
Chris@0 22
Chris@0 23 class View;
Chris@0 24 class QPainter;
Chris@0 25 class QImage;
Chris@0 26
Chris@0 27 /**
Chris@0 28 * This is a view that displays dense 3-D data (time, some sort of
Chris@0 29 * binned y-axis range, value) as a colour plot with value mapped to
Chris@0 30 * colour range. Its source is a DenseThreeDimensionalModel.
Chris@0 31 *
Chris@0 32 * This was the original implementation for the spectrogram view, but
Chris@0 33 * it was replaced with a more efficient implementation that derived
Chris@0 34 * the spectrogram itself from a DenseTimeValueModel instead of using
Chris@0 35 * a three-dimensional model. This class is retained in case it
Chris@0 36 * becomes useful, but it will probably need some cleaning up if it's
Chris@0 37 * ever actually used.
Chris@0 38 */
Chris@0 39
Chris@193 40 class Colour3DPlotLayer : public SliceableLayer
Chris@0 41 {
Chris@0 42 Q_OBJECT
Chris@0 43
Chris@0 44 public:
Chris@44 45 Colour3DPlotLayer();
Chris@0 46 ~Colour3DPlotLayer();
Chris@0 47
Chris@156 48 virtual const ZoomConstraint *getZoomConstraint() const {
Chris@156 49 return m_model ? m_model->getZoomConstraint() : 0;
Chris@156 50 }
Chris@0 51 virtual const Model *getModel() const { return m_model; }
Chris@44 52 virtual void paint(View *v, QPainter &paint, QRect rect) const;
Chris@0 53
Chris@607 54 virtual int getVerticalScaleWidth(View *v, bool, QPainter &) const;
Chris@607 55 virtual void paintVerticalScale(View *v, bool, QPainter &paint, QRect rect) const;
Chris@25 56
Chris@44 57 virtual QString getFeatureDescription(View *v, QPoint &) const;
Chris@25 58
Chris@44 59 virtual bool snapToFeatureFrame(View *v, int &frame,
Chris@28 60 size_t &resolution,
Chris@28 61 SnapType snap) const;
Chris@24 62
Chris@475 63 virtual void setLayerDormant(const View *v, bool dormant);
Chris@475 64
Chris@44 65 virtual bool isLayerScrollable(const View *v) const;
Chris@25 66
Chris@287 67 virtual ColourSignificance getLayerColourSignificance() const {
Chris@287 68 return ColourHasMeaningfulValue;
Chris@287 69 }
Chris@183 70
Chris@0 71 void setModel(const DenseThreeDimensionalModel *model);
Chris@0 72
Chris@115 73 virtual int getCompletion(View *) const { return m_model->getCompletion(); }
Chris@24 74
Chris@0 75 virtual PropertyList getProperties() const;
Chris@0 76 virtual PropertyType getPropertyType(const PropertyName &) const;
Chris@159 77 virtual QString getPropertyLabel(const PropertyName &) const;
Chris@346 78 virtual QString getPropertyIconName(const PropertyName &) const;
Chris@159 79 virtual QString getPropertyGroupName(const PropertyName &) const;
Chris@0 80 virtual int getPropertyRangeAndValue(const PropertyName &,
Chris@216 81 int *min, int *max, int *deflt) const;
Chris@0 82 virtual QString getPropertyValueLabel(const PropertyName &,
Chris@0 83 int value) const;
Chris@534 84 virtual RangeMapper *getNewPropertyRangeMapper(const PropertyName &) const;
Chris@0 85 virtual void setProperty(const PropertyName &, int value);
Chris@197 86 virtual void setProperties(const QXmlAttributes &);
Chris@11 87
Chris@509 88 enum ColourScale {
Chris@509 89 LinearScale,
Chris@509 90 LogScale,
Chris@509 91 PlusMinusOneScale,
Chris@509 92 AbsoluteScale
Chris@509 93 };
Chris@159 94
Chris@159 95 void setColourScale(ColourScale);
Chris@159 96 ColourScale getColourScale() const { return m_colourScale; }
Chris@159 97
Chris@197 98 void setColourMap(int map);
Chris@197 99 int getColourMap() const;
Chris@197 100
Chris@534 101 /**
Chris@534 102 * Set the gain multiplier for sample values in this view.
Chris@534 103 * The default is 1.0.
Chris@534 104 */
Chris@534 105 void setGain(float gain);
Chris@534 106 float getGain() const;
Chris@534 107
Chris@531 108 enum BinScale {
Chris@531 109 LinearBinScale,
Chris@531 110 LogBinScale
Chris@531 111 };
Chris@531 112
Chris@531 113 /**
Chris@531 114 * Specify the scale for the y axis.
Chris@531 115 */
Chris@531 116 void setBinScale(BinScale);
Chris@531 117 BinScale getBinScale() const;
Chris@531 118
Chris@719 119 /**
Chris@719 120 * Normalize each column to its maximum value, independent of its
Chris@719 121 * neighbours.
Chris@719 122 */
Chris@197 123 void setNormalizeColumns(bool n);
Chris@197 124 bool getNormalizeColumns() const;
Chris@197 125
Chris@719 126 /**
Chris@719 127 * Normalize each value against the maximum in the visible region.
Chris@719 128 */
Chris@197 129 void setNormalizeVisibleArea(bool n);
Chris@197 130 bool getNormalizeVisibleArea() const;
Chris@197 131
Chris@719 132 /**
Chris@719 133 * Normalize each column to its maximum value, and then scale by
Chris@719 134 * the log of the (absolute) maximum value.
Chris@719 135 */
Chris@719 136 void setNormalizeHybrid(bool n);
Chris@719 137 bool getNormalizeHybrid() const;
Chris@719 138
Chris@357 139 void setInvertVertical(bool i);
Chris@357 140 bool getInvertVertical() const;
Chris@357 141
Chris@465 142 void setOpaque(bool i);
Chris@465 143 bool getOpaque() const;
Chris@465 144
Chris@535 145 void setSmooth(bool i);
Chris@535 146 bool getSmooth() const;
Chris@535 147
Chris@444 148 virtual bool getValueExtents(float &min, float &max,
Chris@444 149 bool &logarithmic, QString &unit) const;
Chris@444 150
Chris@444 151 virtual bool getDisplayExtents(float &min, float &max) const;
Chris@444 152 virtual bool setDisplayExtents(float min, float max);
Chris@444 153
Chris@444 154 virtual int getVerticalZoomSteps(int &defaultStep) const;
Chris@444 155 virtual int getCurrentVerticalZoomStep() const;
Chris@444 156 virtual void setVerticalZoomStep(int);
Chris@444 157 virtual RangeMapper *getNewVerticalZoomRangeMapper() const;
Chris@444 158
Chris@193 159 virtual const Model *getSliceableModel() const { return m_model; }
Chris@193 160
Chris@316 161 virtual void toXml(QTextStream &stream, QString indent = "",
Chris@316 162 QString extraAttributes = "") const;
Chris@197 163
Chris@0 164 protected slots:
Chris@0 165 void cacheInvalid();
Chris@0 166 void cacheInvalid(size_t startFrame, size_t endFrame);
Chris@461 167 void modelChanged();
Chris@461 168 void modelChanged(size_t, size_t);
Chris@0 169
Chris@0 170 protected:
Chris@0 171 const DenseThreeDimensionalModel *m_model; // I do not own this
Chris@0 172
Chris@0 173 mutable QImage *m_cache;
Chris@469 174 mutable QImage *m_peaksCache;
Chris@461 175 mutable size_t m_cacheValidStart;
Chris@461 176 mutable size_t m_cacheValidEnd;
Chris@98 177
Chris@159 178 ColourScale m_colourScale;
Chris@461 179 bool m_colourScaleSet;
Chris@197 180 int m_colourMap;
Chris@534 181 float m_gain;
Chris@531 182 BinScale m_binScale;
Chris@197 183 bool m_normalizeColumns;
Chris@197 184 bool m_normalizeVisibleArea;
Chris@719 185 bool m_normalizeHybrid;
Chris@357 186 bool m_invertVertical;
Chris@465 187 bool m_opaque;
Chris@535 188 bool m_smooth;
Chris@469 189 size_t m_peakResolution;
Chris@197 190
Chris@444 191 int m_miny;
Chris@444 192 int m_maxy;
Chris@444 193
Chris@467 194 DenseThreeDimensionalModel::Column getColumn(size_t col) const;
Chris@159 195
Chris@469 196 int getColourScaleWidth(QPainter &) const;
Chris@469 197 void fillCache(size_t firstBin, size_t lastBin) const;
Chris@469 198 void paintDense(View *v, QPainter &paint, QRect rect) const;
Chris@532 199
Chris@532 200 float getYForBin(View *, float bin) const;
Chris@532 201 float getBinForY(View *, float y) const;
Chris@0 202 };
Chris@0 203
Chris@0 204 #endif