Mercurial > hg > svgui
view layer/WaveformLayer.h @ 131:eaae73b6bd28
* Suspend/resume fft data server write activity while reading from a server
to repaint the spectrogram display. Makes a significant improvement to
the otherwise dreadful responsiveness of spectrogram display.
author | Chris Cannam |
---|---|
date | Thu, 03 Aug 2006 12:42:15 +0000 |
parents | 33929e0c3c6b |
children | 9e6b3e239b9d |
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 Chris Cannam. 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 _WAVEFORM_LAYER_H_ #define _WAVEFORM_LAYER_H_ #include <QRect> #include <QColor> #include "Layer.h" #include "data/model/RangeSummarisableTimeValueModel.h" class View; class QPainter; class QPixmap; class WaveformLayer : public Layer { Q_OBJECT public: WaveformLayer(); ~WaveformLayer(); virtual const ZoomConstraint *getZoomConstraint() const { return m_model; } virtual const Model *getModel() const { return m_model; } virtual void paint(View *v, QPainter &paint, QRect rect) const; virtual QString getFeatureDescription(View *v, QPoint &) const; virtual int getVerticalScaleWidth(View *v, QPainter &) const; virtual void paintVerticalScale(View *v, QPainter &paint, QRect rect) const; void setModel(const RangeSummarisableTimeValueModel *model); 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) const; virtual QString getPropertyValueLabel(const PropertyName &, int value) const; virtual void setProperty(const PropertyName &, int value); /** * Set the gain multiplier for sample values in this view. * * The default is 1.0. */ void setGain(float gain); float getGain() const { return m_gain; } /** * Toggle automatic normalization of the currently visible waveform. */ void setAutoNormalize(bool); bool getAutoNormalize() const { return m_autoNormalize; } /** * Set the basic display colour for waveforms. * * The default is black. *!!! NB should default to white if the associated View !hasLightBackground() */ void setBaseColour(QColor); QColor getBaseColour() const { return m_colour; } /** * Set whether to display mean values as a lighter-coloured area * beneath the peaks. Rendering will be slightly faster without * but arguably prettier with. * * The default is to display means. */ void setShowMeans(bool); bool getShowMeans() const { return m_showMeans; } /** * Set whether to use shades of grey (or of the base colour) to * provide additional perceived vertical resolution (i.e. using * half-filled pixels to represent levels that only just meet the * pixel unit boundary). This provides a small improvement in * waveform quality at a small cost in rendering speed. * * The default is to use greyscale. */ void setUseGreyscale(bool); bool getUseGreyscale() const { return m_greyscale; } enum ChannelMode { SeparateChannels, MixChannels, MergeChannels }; /** * Specify whether multi-channel audio data should be displayed * with a separate axis per channel (SeparateChannels), with a * single synthetic axis showing channel 0 above the axis and * channel 1 below (MergeChannels), or with a single axis showing * the average of the channels (MixChannels). * * MergeChannels does not work for files with more than 2 * channels. * * The default is SeparateChannels. */ void setChannelMode(ChannelMode); ChannelMode getChannelMode() const { return m_channelMode; } /** * Specify the channel to use from the source model. A value of * -1 means to show all available channels (laid out to the * channel mode). The default is -1. */ void setChannel(int); int getChannel() const { return m_channel; } enum Scale { LinearScale, MeterScale, dBScale }; /** * Specify the vertical scale for sample levels. With LinearScale, * the scale is directly proportional to the raw [-1, +1) * floating-point audio sample values. With dBScale the * vertical scale is proportional to dB level (truncated at * -50dB). MeterScale provides a hybrid variable scale based on * IEC meter scale, intended to provide a clear overview at * relatively small heights. * * Note that the effective gain (see setGain()) is applied before * vertical scaling. * * The default is LinearScale. */ void setScale(Scale); Scale getScale() const { return m_scale; } /** * Enable or disable aggressive pixmap cacheing. If enabled, * waveforms will be rendered to an off-screen pixmap and * refreshed from there instead of being redrawn from the peak * data each time. This may be faster if the data and zoom level * do not change often, but it may be slower for frequently zoomed * data and it will only work if the waveform is the "bottom" * layer on the displayed widget, as each refresh will erase * anything beneath the waveform. * * This is intended specifically for a panner widget display in * which the waveform never moves, zooms, or changes, but some * graphic such as a panner outline is frequently redrawn over the * waveform. This situation would necessitate a lot of waveform * refresh if the default cacheing strategy was used. * * The default is not to use aggressive cacheing. */ void setAggressiveCacheing(bool); bool getAggressiveCacheing() const { return m_aggressive; } virtual bool isLayerScrollable(const View *) const; virtual int getCompletion(View *) const; virtual bool getValueExtents(float &min, float &max, bool &log, QString &unit) const; virtual QString toXmlString(QString indent = "", QString extraAttributes = "") const; void setProperties(const QXmlAttributes &attributes); protected: int dBscale(float sample, int m) const; const RangeSummarisableTimeValueModel *m_model; // I do not own this /// Return value is number of channels displayed size_t getChannelArrangement(size_t &min, size_t &max, bool &merging, bool &mixing) const; int getYForValue(View *v, Scale scale, float value, size_t channel, size_t minChannel, size_t maxChannel) const; float m_gain; bool m_autoNormalize; QColor m_colour; bool m_showMeans; bool m_greyscale; ChannelMode m_channelMode; int m_channel; Scale m_scale; bool m_aggressive; mutable std::vector<float> m_effectiveGains; mutable QPixmap *m_cache; mutable bool m_cacheValid; mutable int m_cacheZoomLevel; }; #endif