annotate layer/WaveformLayer.h @ 286:7554ae119882

* Fix failure to save vertical scale setting from time-value layer
author Chris Cannam
date Wed, 11 Jul 2007 20:46:37 +0000
parents 9dd432665059
children cd2492c5fe45
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@30 16 #ifndef _WAVEFORM_LAYER_H_
Chris@30 17 #define _WAVEFORM_LAYER_H_
Chris@0 18
Chris@0 19 #include <QRect>
Chris@0 20 #include <QColor>
Chris@0 21
Chris@128 22 #include "Layer.h"
Chris@0 23
Chris@128 24 #include "data/model/RangeSummarisableTimeValueModel.h"
Chris@0 25
Chris@0 26 class View;
Chris@0 27 class QPainter;
Chris@0 28 class QPixmap;
Chris@0 29
Chris@0 30 class WaveformLayer : public Layer
Chris@0 31 {
Chris@0 32 Q_OBJECT
Chris@0 33
Chris@0 34 public:
Chris@44 35 WaveformLayer();
Chris@0 36 ~WaveformLayer();
Chris@0 37
Chris@156 38 virtual const ZoomConstraint *getZoomConstraint() const {
Chris@156 39 return m_model ? m_model->getZoomConstraint() : 0;
Chris@156 40 }
Chris@0 41 virtual const Model *getModel() const { return m_model; }
Chris@44 42 virtual void paint(View *v, QPainter &paint, QRect rect) const;
Chris@0 43
Chris@44 44 virtual QString getFeatureDescription(View *v, QPoint &) const;
Chris@25 45
Chris@44 46 virtual int getVerticalScaleWidth(View *v, QPainter &) const;
Chris@44 47 virtual void paintVerticalScale(View *v, QPainter &paint, QRect rect) const;
Chris@0 48
Chris@285 49 virtual bool hasLightBackground() const;
Chris@285 50
Chris@0 51 void setModel(const RangeSummarisableTimeValueModel *model);
Chris@0 52
Chris@0 53 virtual PropertyList getProperties() const;
Chris@87 54 virtual QString getPropertyLabel(const PropertyName &) const;
Chris@0 55 virtual PropertyType getPropertyType(const PropertyName &) const;
Chris@0 56 virtual QString getPropertyGroupName(const PropertyName &) const;
Chris@0 57 virtual int getPropertyRangeAndValue(const PropertyName &,
Chris@216 58 int *min, int *max, int *deflt) const;
Chris@0 59 virtual QString getPropertyValueLabel(const PropertyName &,
Chris@0 60 int value) const;
Chris@167 61 virtual RangeMapper *getNewPropertyRangeMapper(const PropertyName &) const;
Chris@0 62 virtual void setProperty(const PropertyName &, int value);
Chris@0 63
Chris@0 64 /**
Chris@0 65 * Set the gain multiplier for sample values in this view.
Chris@0 66 *
Chris@0 67 * The default is 1.0.
Chris@0 68 */
Chris@0 69 void setGain(float gain);
Chris@0 70 float getGain() const { return m_gain; }
Chris@0 71
Chris@0 72 /**
Chris@67 73 * Toggle automatic normalization of the currently visible waveform.
Chris@67 74 */
Chris@67 75 void setAutoNormalize(bool);
Chris@67 76 bool getAutoNormalize() const { return m_autoNormalize; }
Chris@67 77
Chris@67 78 /**
Chris@285 79 * Set the basic display colour for waveforms. The parameter is
Chris@285 80 * a ColourDatabase index.
Chris@0 81 *
Chris@285 82 * The default is the first colour in the database.
Chris@0 83 *!!! NB should default to white if the associated View !hasLightBackground()
Chris@0 84 */
Chris@285 85 void setBaseColour(int);
Chris@285 86 int getBaseColour() const;
Chris@0 87
Chris@0 88 /**
Chris@0 89 * Set whether to display mean values as a lighter-coloured area
Chris@0 90 * beneath the peaks. Rendering will be slightly faster without
Chris@0 91 * but arguably prettier with.
Chris@0 92 *
Chris@0 93 * The default is to display means.
Chris@0 94 */
Chris@0 95 void setShowMeans(bool);
Chris@0 96 bool getShowMeans() const { return m_showMeans; }
Chris@0 97
Chris@0 98 /**
Chris@0 99 * Set whether to use shades of grey (or of the base colour) to
Chris@0 100 * provide additional perceived vertical resolution (i.e. using
Chris@0 101 * half-filled pixels to represent levels that only just meet the
Chris@0 102 * pixel unit boundary). This provides a small improvement in
Chris@0 103 * waveform quality at a small cost in rendering speed.
Chris@0 104 *
Chris@0 105 * The default is to use greyscale.
Chris@0 106 */
Chris@0 107 void setUseGreyscale(bool);
Chris@0 108 bool getUseGreyscale() const { return m_greyscale; }
Chris@0 109
Chris@0 110
Chris@67 111 enum ChannelMode { SeparateChannels, MixChannels, MergeChannels };
Chris@0 112
Chris@0 113 /**
Chris@0 114 * Specify whether multi-channel audio data should be displayed
Chris@67 115 * with a separate axis per channel (SeparateChannels), with a
Chris@0 116 * single synthetic axis showing channel 0 above the axis and
Chris@67 117 * channel 1 below (MergeChannels), or with a single axis showing
Chris@67 118 * the average of the channels (MixChannels).
Chris@0 119 *
Chris@0 120 * MergeChannels does not work for files with more than 2
Chris@0 121 * channels.
Chris@0 122 *
Chris@0 123 * The default is SeparateChannels.
Chris@0 124 */
Chris@0 125 void setChannelMode(ChannelMode);
Chris@0 126 ChannelMode getChannelMode() const { return m_channelMode; }
Chris@0 127
Chris@0 128
Chris@0 129 /**
Chris@0 130 * Specify the channel to use from the source model. A value of
Chris@0 131 * -1 means to show all available channels (laid out to the
Chris@0 132 * channel mode). The default is -1.
Chris@0 133 */
Chris@0 134 void setChannel(int);
Chris@0 135 int getChannel() const { return m_channel; }
Chris@0 136
Chris@0 137
Chris@0 138 enum Scale { LinearScale, MeterScale, dBScale };
Chris@0 139
Chris@0 140 /**
Chris@0 141 * Specify the vertical scale for sample levels. With LinearScale,
Chris@0 142 * the scale is directly proportional to the raw [-1, +1)
Chris@0 143 * floating-point audio sample values. With dBScale the
Chris@0 144 * vertical scale is proportional to dB level (truncated at
Chris@0 145 * -50dB). MeterScale provides a hybrid variable scale based on
Chris@0 146 * IEC meter scale, intended to provide a clear overview at
Chris@0 147 * relatively small heights.
Chris@0 148 *
Chris@0 149 * Note that the effective gain (see setGain()) is applied before
Chris@0 150 * vertical scaling.
Chris@0 151 *
Chris@0 152 * The default is LinearScale.
Chris@0 153 */
Chris@0 154 void setScale(Scale);
Chris@0 155 Scale getScale() const { return m_scale; }
Chris@0 156
Chris@0 157 /**
Chris@0 158 * Enable or disable aggressive pixmap cacheing. If enabled,
Chris@0 159 * waveforms will be rendered to an off-screen pixmap and
Chris@0 160 * refreshed from there instead of being redrawn from the peak
Chris@0 161 * data each time. This may be faster if the data and zoom level
Chris@0 162 * do not change often, but it may be slower for frequently zoomed
Chris@0 163 * data and it will only work if the waveform is the "bottom"
Chris@0 164 * layer on the displayed widget, as each refresh will erase
Chris@0 165 * anything beneath the waveform.
Chris@0 166 *
Chris@0 167 * This is intended specifically for a panner widget display in
Chris@0 168 * which the waveform never moves, zooms, or changes, but some
Chris@0 169 * graphic such as a panner outline is frequently redrawn over the
Chris@0 170 * waveform. This situation would necessitate a lot of waveform
Chris@0 171 * refresh if the default cacheing strategy was used.
Chris@0 172 *
Chris@0 173 * The default is not to use aggressive cacheing.
Chris@0 174 */
Chris@0 175 void setAggressiveCacheing(bool);
Chris@0 176 bool getAggressiveCacheing() const { return m_aggressive; }
Chris@0 177
Chris@67 178 virtual bool isLayerScrollable(const View *) const;
Chris@67 179
Chris@115 180 virtual int getCompletion(View *) const;
Chris@0 181
Chris@101 182 virtual bool getValueExtents(float &min, float &max,
Chris@101 183 bool &log, QString &unit) const;
Chris@79 184
Chris@267 185 virtual bool getYScaleValue(const View *v, int y,
Chris@261 186 float &value, QString &unit) const;
Chris@274 187
Chris@274 188 virtual bool getYScaleDifference(const View *v, int y0, int y1,
Chris@274 189 float &diff, QString &unit) const;
Chris@261 190
Chris@6 191 virtual QString toXmlString(QString indent = "",
Chris@6 192 QString extraAttributes = "") const;
Chris@6 193
Chris@11 194 void setProperties(const QXmlAttributes &attributes);
Chris@11 195
Chris@133 196 virtual int getVerticalZoomSteps(int &defaultStep) const;
Chris@133 197 virtual int getCurrentVerticalZoomStep() const;
Chris@133 198 virtual void setVerticalZoomStep(int);
Chris@133 199
Chris@0 200 protected:
Chris@0 201 int dBscale(float sample, int m) const;
Chris@0 202
Chris@0 203 const RangeSummarisableTimeValueModel *m_model; // I do not own this
Chris@0 204
Chris@0 205 /// Return value is number of channels displayed
Chris@67 206 size_t getChannelArrangement(size_t &min, size_t &max,
Chris@67 207 bool &merging, bool &mixing) const;
Chris@0 208
Chris@274 209 int getYForValue(const View *v, float value, size_t channel) const;
Chris@68 210
Chris@274 211 float getValueForY(const View *v, int y, size_t &channel) const;
Chris@261 212
Chris@6 213 float m_gain;
Chris@67 214 bool m_autoNormalize;
Chris@285 215 int m_colour;
Chris@6 216 bool m_showMeans;
Chris@6 217 bool m_greyscale;
Chris@6 218 ChannelMode m_channelMode;
Chris@6 219 int m_channel;
Chris@6 220 Scale m_scale;
Chris@6 221 bool m_aggressive;
Chris@0 222
Chris@67 223 mutable std::vector<float> m_effectiveGains;
Chris@67 224
Chris@0 225 mutable QPixmap *m_cache;
Chris@0 226 mutable bool m_cacheValid;
Chris@0 227 mutable int m_cacheZoomLevel;
Chris@0 228 };
Chris@0 229
Chris@0 230 #endif