SpectrogramLayer represents waveform data (obtained from a DenseTimeValueModel) in spectrogram form. More...

#include <SpectrogramLayer.h>

Inheritance diagram for SpectrogramLayer:
Inheritance graph
Collaboration diagram for SpectrogramLayer:
Collaboration graph

Public Types

enum  Configuration { FullRangeDb, MelodicRange, MelodicPeaks }
 
enum  VerticalPosition { PositionTop, PositionMiddle, PositionBottom }
 
enum  SnapType { SnapLeft, SnapRight, SnapNeighbouring }
 
enum  ColourSignificance {
  ColourAbsent, ColourIrrelevant, ColourDistinguishes, ColourAndBackgroundSignificant,
  ColourHasMeaningfulValue
}
 

Public Slots

void showLayer (LayerGeometryProvider *, bool show)
 Change the visibility status (dormancy) of the layer in the given view. More...
 

Signals

void modelChanged (ModelId)
 
void modelCompletionChanged (ModelId)
 
void modelAlignmentCompletionChanged (ModelId)
 
void modelChangedWithin (ModelId, sv_frame_t startFrame, sv_frame_t endFrame)
 
void modelReplaced ()
 
void layerParametersChanged ()
 
void layerParameterRangesChanged ()
 
void layerMeasurementRectsChanged ()
 
void layerNameChanged ()
 
void verticalZoomChanged ()
 

Public Member Functions

 SpectrogramLayer (Configuration=FullRangeDb)
 Construct a SpectrogramLayer with default parameters appropriate for the given configuration. More...
 
 ~SpectrogramLayer ()
 
const ZoomConstraint * getZoomConstraint () const override
 Return a zoom constraint object defining the supported zoom levels for this layer. More...
 
ModelId getModel () const override
 Return the ID of the model represented in this layer. More...
 
ModelId getExportModel (LayerGeometryProvider *) const override
 Return the ID of a model representing the contents of this layer in a form suitable for export to a tabular file format such as CSV. More...
 
void paint (LayerGeometryProvider *v, QPainter &paint, QRect rect) const override
 Paint the given rectangle of this layer onto the given view using the given painter, superimposing it on top of any existing material in that view. More...
 
void setSynchronousPainting (bool synchronous) override
 Enable or disable synchronous painting. More...
 
int getVerticalScaleWidth (LayerGeometryProvider *v, bool detailed, QPainter &) const override
 
void paintVerticalScale (LayerGeometryProvider *v, bool detailed, QPainter &paint, QRect rect) const override
 
bool getCrosshairExtents (LayerGeometryProvider *, QPainter &, QPoint cursorPos, std::vector< QRect > &extents) const override
 
void paintCrosshairs (LayerGeometryProvider *, QPainter &, QPoint) const override
 
QString getFeatureDescription (LayerGeometryProvider *v, QPoint &) const override
 
bool snapToFeatureFrame (LayerGeometryProvider *v, sv_frame_t &frame, int &resolution, SnapType snap, int ycoord) const override
 Adjust the given frame to snap to the nearest feature, if possible. More...
 
void measureDoubleClick (LayerGeometryProvider *, QMouseEvent *) override
 
bool hasLightBackground () const override
 
void setModel (ModelId model)
 
PropertyList getProperties () const override
 
QString getPropertyLabel (const PropertyName &) const override
 
QString getPropertyIconName (const PropertyName &) const override
 
PropertyType getPropertyType (const PropertyName &) const override
 
QString getPropertyGroupName (const PropertyName &) const override
 
int getPropertyRangeAndValue (const PropertyName &, int *min, int *max, int *deflt) const override
 
QString getPropertyValueLabel (const PropertyName &, int value) const override
 
QString getPropertyValueIconName (const PropertyName &, int value) const override
 
RangeMapper * getNewPropertyRangeMapper (const PropertyName &) const override
 
void setProperty (const PropertyName &, int value) override
 
void setChannel (int)
 Specify the channel to use from the source model. More...
 
int getChannel () const
 
void setWindowSize (int)
 
int getWindowSize () const
 
void setWindowHopLevel (int level)
 
int getWindowHopLevel () const
 
void setOversampling (int oversampling)
 
int getOversampling () const
 
void setWindowType (WindowType type)
 
WindowType getWindowType () const
 
void setGain (float gain)
 Set the gain multiplier for sample values in this view. More...
 
float getGain () const
 
void setThreshold (float threshold)
 Set the threshold for sample values to qualify for being shown in the FFT, in voltage units. More...
 
float getThreshold () const
 
void setVerticallyFixed ()
 Mark the spectrogram layer as having a fixed range in the vertical axis. More...
 
void setMinFrequency (int)
 
int getMinFrequency () const
 
void setMaxFrequency (int)
 
int getMaxFrequency () const
 
void setColourScale (ColourScaleType)
 Specify the scale for sample levels. More...
 
ColourScaleType getColourScale () const
 
void setColourScaleMultiple (double)
 Specify multiple factor for colour scale. More...
 
double getColourScaleMultiple () const
 
void setBinScale (BinScale)
 Specify the scale for the y axis. More...
 
BinScale getBinScale () const
 
void setBinDisplay (BinDisplay)
 Specify the processing of frequency bins for the y axis. More...
 
BinDisplay getBinDisplay () const
 
void setNormalization (ColumnNormalization)
 Specify the normalization mode for individual columns. More...
 
ColumnNormalization getNormalization () const
 
void setNormalizeVisibleArea (bool)
 Specify whether to normalize the visible area. More...
 
bool getNormalizeVisibleArea () const
 
void setColourMap (int map)
 Specify the colour map. More...
 
int getColourMap () const
 
void setColourRotation (int)
 Specify the colourmap rotation for the colour scale. More...
 
int getColourRotation () const
 
VerticalPosition getPreferredFrameCountPosition () const override
 
bool isLayerOpaque () const override
 This should return true if the layer completely obscures any underlying layers. More...
 
ColourSignificance getLayerColourSignificance () const override
 This should return the degree of meaning associated with colour in this layer. More...
 
double getYForFrequency (const LayerGeometryProvider *v, double frequency) const
 
double getFrequencyForY (const LayerGeometryProvider *v, int y) const
 
double getYForBin (const LayerGeometryProvider *, double bin) const override
 !! VerticalBinLayer methods. Note overlap with get*BinRange() More...
 
double getBinForY (const LayerGeometryProvider *, double y) const override
 Return the bin number, possibly fractional, at the given y coordinate. More...
 
int getCompletion (LayerGeometryProvider *v) const override
 Return the proportion of background work complete in drawing this view, as a percentage – in most cases this will be the value returned by pointer from a call to the underlying model's isReady(int *) call. More...
 
QString getError (LayerGeometryProvider *v) const override
 Return an error string if any errors have occurred while loading or processing data for the given view. More...
 
bool getValueExtents (double &min, double &max, bool &logarithmic, QString &unit) const override
 Return the minimum and maximum values for the y axis of the model in this layer, as well as whether the layer is configured to use a logarithmic y axis display. More...
 
bool getDisplayExtents (double &min, double &max) const override
 Return the minimum and maximum values within the visible area for the y axis of this layer. More...
 
bool setDisplayExtents (double min, double max) override
 Set the displayed minimum and maximum values for the y axis to the given range, if supported. More...
 
bool getYScaleValue (const LayerGeometryProvider *, int, double &, QString &) const override
 Return the value and unit at the given y coordinate in the given view. More...
 
void toXml (QTextStream &stream, QString indent="", QString extraAttributes="") const override
 
void setProperties (const QXmlAttributes &attributes) override
 Set the particular properties of a layer (those specific to the subclass) from a set of XML attributes. More...
 
void setLayerDormant (const LayerGeometryProvider *v, bool dormant) override
 Indicate that a layer is not currently visible in the given view and is not expected to become visible in the near future (for example because the user has explicitly removed or hidden it). More...
 
bool isLayerScrollable (const LayerGeometryProvider *) const override
 This should return true if the layer can safely be scrolled automatically by a given view (simply copying the existing data and then refreshing the exposed area) without altering its meaning. More...
 
int getVerticalZoomSteps (int &defaultStep) const override
 Get the number of vertical zoom steps available for this layer. More...
 
int getCurrentVerticalZoomStep () const override
 Get the current vertical zoom step. More...
 
void setVerticalZoomStep (int) override
 Set the vertical zoom step. More...
 
RangeMapper * getNewVerticalZoomRangeMapper () const override
 Create and return a range mapper for vertical zoom step values. More...
 
ModelId getSliceableModel () const override
 
virtual int getIYForBin (const LayerGeometryProvider *v, int bin) const
 As getYForBin, but rounding to integer values. More...
 
virtual int getIBinForY (const LayerGeometryProvider *v, int y) const
 As getBinForY, but rounding to integer values. More...
 
ModelId getSourceModel () const
 Return the ID of the source model for the model represented in this layer. More...
 
virtual bool supportsOtherZoomLevels () const
 Return true if this layer can handle zoom levels other than those supported by its zoom constraint (presumably less efficiently or accurately than the officially supported zoom levels). More...
 
virtual VerticalPosition getPreferredTimeRulerPosition () const
 
QString getPropertyContainerIconName () const override
 
QString getPropertyContainerName () const override
 
virtual void setPresentationName (QString name)
 
virtual bool isPresentationNameSet () const
 
virtual QString getLayerPresentationName () const
 
virtual QPixmap getLayerPresentationPixmap (QSize) const
 
virtual int getHorizontalScaleHeight (LayerGeometryProvider *, QPainter &) const
 
virtual void paintMeasurementRects (LayerGeometryProvider *, QPainter &, bool showFocus, QPoint focusPoint) const
 
virtual bool nearestMeasurementRectChanged (LayerGeometryProvider *, QPoint prev, QPoint now) const
 
virtual QString getLabelPreceding (sv_frame_t) const
 
virtual bool snapToSimilarFeature (LayerGeometryProvider *, sv_frame_t &, int &resolution, SnapType) const
 Adjust the given frame to snap to the next feature that has "effectively" the same value as the feature prior to the given frame, if possible. More...
 
virtual void drawStart (LayerGeometryProvider *, QMouseEvent *)
 
virtual void drawDrag (LayerGeometryProvider *, QMouseEvent *)
 
virtual void drawEnd (LayerGeometryProvider *, QMouseEvent *)
 
virtual void eraseStart (LayerGeometryProvider *, QMouseEvent *)
 
virtual void eraseDrag (LayerGeometryProvider *, QMouseEvent *)
 
virtual void eraseEnd (LayerGeometryProvider *, QMouseEvent *)
 
virtual void editStart (LayerGeometryProvider *, QMouseEvent *)
 
virtual void editDrag (LayerGeometryProvider *, QMouseEvent *)
 
virtual void editEnd (LayerGeometryProvider *, QMouseEvent *)
 
virtual void splitStart (LayerGeometryProvider *, QMouseEvent *)
 
virtual void splitEnd (LayerGeometryProvider *, QMouseEvent *)
 
virtual void addNote (LayerGeometryProvider *, QMouseEvent *)
 
virtual void measureStart (LayerGeometryProvider *, QMouseEvent *)
 
virtual void measureDrag (LayerGeometryProvider *, QMouseEvent *)
 
virtual void measureEnd (LayerGeometryProvider *, QMouseEvent *)
 
virtual bool haveCurrentMeasureRect () const
 
virtual void deleteCurrentMeasureRect ()
 
virtual bool editOpen (LayerGeometryProvider *, QMouseEvent *)
 Open an editor on the item under the mouse (e.g. More...
 
virtual void moveSelection (Selection, sv_frame_t)
 
virtual void resizeSelection (Selection, Selection)
 
virtual void deleteSelection (Selection)
 
virtual void copy (LayerGeometryProvider *, Selection, Clipboard &)
 
virtual bool paste (LayerGeometryProvider *, const Clipboard &, sv_frame_t, bool)
 Paste from the given clipboard onto the layer at the given frame offset. More...
 
virtual bool isLayerEditable () const
 This should return true if the layer can be edited by the user. More...
 
virtual void setObjectName (const QString &name)
 
virtual void toBriefXml (QTextStream &stream, QString indent="", QString extraAttributes="") const
 Produce XML containing the layer's ID and type. More...
 
virtual void addMeasurementRect (const QXmlAttributes &)
 Add a measurement rectangle from the given XML attributes (presumably taken from a measurement element). More...
 
virtual bool isLayerDormant (const LayerGeometryProvider *v) const
 Return whether the layer is dormant (i.e. More...
 
std::shared_ptr< PlayParameters > getPlayParameters () override
 Return the play parameters for this layer, if any. More...
 
virtual bool needsTextLabelHeight () const
 True if this layer will need to place text labels when it is painted. More...
 
virtual bool hasTimeXAxis () const
 Return true if the X axis on the layer is time proportional to audio frames, false otherwise. More...
 
virtual void zoomToRegion (const LayerGeometryProvider *, QRect)
 Update the X and Y axis scales, where appropriate, to focus on the given rectangular region. More...
 
virtual bool adoptExtents (double, double, QString)
 Consider using the given value extents and units for this layer. More...
 
virtual bool getXScaleValue (const LayerGeometryProvider *v, int x, double &value, QString &unit) const
 Return the value and unit at the given x coordinate in the given view. More...
 
virtual bool getYScaleDifference (const LayerGeometryProvider *v, int y0, int y1, double &diff, QString &unit) const
 Return the difference between the values at the given y coordinates in the given view, and the unit of the difference. More...
 
virtual bool canExistWithoutModel () const
 Return true if this layer type can function without a model being set. More...
 

Protected Types

typedef std::map< int, MagnitudeRange > ViewMagMap
 
typedef std::map< int, Colour3DPlotRenderer * > ViewRendererMap
 
typedef std::set< MeasureRectMeasureRectSet
 

Protected Slots

void cacheInvalid (ModelId)
 
void cacheInvalid (ModelId, sv_frame_t startFrame, sv_frame_t endFrame)
 
void preferenceChanged (PropertyContainer::PropertyName name)
 

Protected Member Functions

int getColourScaleWidth (QPainter &) const
 
void illuminateLocalFeatures (LayerGeometryProvider *v, QPainter &painter) const
 
double getEffectiveMinFrequency () const
 
double getEffectiveMaxFrequency () const
 
bool getXBinRange (LayerGeometryProvider *v, int x, double &windowMin, double &windowMax) const
 
bool getYBinRange (LayerGeometryProvider *v, int y, double &freqBinMin, double &freqBinMax) const
 
bool getYBinSourceRange (LayerGeometryProvider *v, int y, double &freqMin, double &freqMax) const
 
bool getAdjustedYBinSourceRange (LayerGeometryProvider *v, int x, int y, double &freqMin, double &freqMax, double &adjFreqMin, double &adjFreqMax) const
 
bool getXBinSourceRange (LayerGeometryProvider *v, int x, RealTime &timeMin, RealTime &timeMax) const
 
bool getXYBinSourceRange (LayerGeometryProvider *v, int x, int y, double &min, double &max, double &phaseMin, double &phaseMax) const
 
int getWindowIncrement () const
 
int getFFTSize () const
 
void checkCacheSpace (int *suggestedPeakDivisor, bool *createWholeCache) const
 
void recreateFFTModel ()
 
void invalidateMagnitudes ()
 
Colour3DPlotRenderergetRenderer (LayerGeometryProvider *) const
 
void invalidateRenderers ()
 
void deleteDerivedModels ()
 
void paintWithRenderer (LayerGeometryProvider *v, QPainter &paint, QRect rect) const
 
void paintDetailedScale (LayerGeometryProvider *v, QPainter &paint, QRect rect) const
 
void paintDetailedScalePhase (LayerGeometryProvider *v, QPainter &paint, QRect rect) const
 
void updateMeasureRectYCoords (LayerGeometryProvider *v, const MeasureRect &r) const override
 
void setMeasureRectYCoord (LayerGeometryProvider *v, MeasureRect &r, bool start, int y) const override
 
void connectSignals (ModelId)
 
virtual sv_frame_t alignToReference (LayerGeometryProvider *v, sv_frame_t frame) const
 
virtual sv_frame_t alignFromReference (LayerGeometryProvider *v, sv_frame_t frame) const
 
bool clipboardHasDifferentAlignment (LayerGeometryProvider *v, const Clipboard &clip) const
 
void addMeasureRectToSet (const MeasureRect &r)
 
void deleteMeasureRectFromSet (const MeasureRect &r)
 
void updateMeasurePixrects (LayerGeometryProvider *v) const
 
virtual void setMeasureRectFromPixrect (LayerGeometryProvider *v, MeasureRect &r, QRect pixrect) const
 
MeasureRectSet::const_iterator findFocusedMeasureRect (QPoint) const
 
void paintMeasurementRect (LayerGeometryProvider *v, QPainter &paint, const MeasureRect &r, bool focus) const
 
bool valueExtentsMatchMine (LayerGeometryProvider *v) const
 

Static Protected Member Functions

static std::pair< ColourScaleType, double > convertToColourScale (int value)
 
static int convertFromColourScale (ColourScaleType type, double multiple)
 
static std::pair< ColumnNormalization, bool > convertToColumnNorm (int value)
 
static int convertFromColumnNorm (ColumnNormalization norm, bool visible)
 

Protected Attributes

ModelId m_model
 
int m_channel
 
int m_windowSize
 
WindowType m_windowType
 
int m_windowHopLevel
 
int m_oversampling
 
float m_gain
 
float m_initialGain
 
float m_threshold
 
float m_initialThreshold
 
int m_colourRotation
 
int m_initialRotation
 
int m_minFrequency
 
int m_maxFrequency
 
int m_initialMaxFrequency
 
bool m_verticallyFixed
 
ColourScaleType m_colourScale
 
double m_colourScaleMultiple
 
int m_colourMap
 
bool m_colourInverted
 
QColor m_crosshairColour
 
BinScale m_binScale
 
BinDisplay m_binDisplay
 
ColumnNormalization m_normalization
 
bool m_normalizeVisibleArea
 
int m_lastEmittedZoomStep
 
bool m_synchronous
 
bool m_haveDetailedScale
 
bool m_exiting
 
ModelId m_fftModel
 
ModelId m_wholeCache
 
ModelId m_peakCache
 
int m_peakCacheDivisor
 
std::vector< ModelId > m_exporters
 
ViewMagMap m_viewMags
 
ViewMagMap m_lastRenderedMags
 
ViewRendererMap m_renderers
 
MeasureRectSet m_measureRects
 
MeasureRect m_draggingRect
 
bool m_haveDraggingRect
 
bool m_haveCurrentMeasureRect
 
QPoint m_currentMeasureRectPoint
 
QString m_presentationName
 

Detailed Description

SpectrogramLayer represents waveform data (obtained from a DenseTimeValueModel) in spectrogram form.

Definition at line 51 of file SpectrogramLayer.h.

Member Typedef Documentation

typedef std::map<int, MagnitudeRange> SpectrogramLayer::ViewMagMap
protected

Definition at line 344 of file SpectrogramLayer.h.

typedef std::map<int, Colour3DPlotRenderer *> SpectrogramLayer::ViewRendererMap
protected

Definition at line 349 of file SpectrogramLayer.h.

typedef std::set<MeasureRect> Layer::MeasureRectSet
protectedinherited

Definition at line 692 of file Layer.h.

Member Enumeration Documentation

Enumerator
FullRangeDb 
MelodicRange 
MelodicPeaks 

Definition at line 57 of file SpectrogramLayer.h.

enum Layer::VerticalPosition
inherited
Enumerator
PositionTop 
PositionMiddle 
PositionBottom 

Definition at line 140 of file Layer.h.

enum Layer::SnapType
inherited
Enumerator
SnapLeft 
SnapRight 
SnapNeighbouring 

Definition at line 195 of file Layer.h.

enum Layer::ColourSignificance
inherited
Enumerator
ColourAbsent 
ColourIrrelevant 
ColourDistinguishes 
ColourAndBackgroundSignificant 
ColourHasMeaningfulValue 

Definition at line 348 of file Layer.h.

Constructor & Destructor Documentation

SpectrogramLayer::~SpectrogramLayer ( )

Definition at line 132 of file SpectrogramLayer.cpp.

References deleteDerivedModels(), and invalidateRenderers().

Member Function Documentation

const ZoomConstraint* SpectrogramLayer::getZoomConstraint ( ) const
inlineoverridevirtual

Return a zoom constraint object defining the supported zoom levels for this layer.

If this returns zero, the layer will support any integer zoom level.

Reimplemented from Layer.

Definition at line 66 of file SpectrogramLayer.h.

ModelId SpectrogramLayer::getExportModel ( LayerGeometryProvider ) const
overridevirtual

Return the ID of a model representing the contents of this layer in a form suitable for export to a tabular file format such as CSV.

In most cases this will be the same as returned by getModel(). The exceptions are those layers such as SpectrogramLayer, that are "only" alternative views of time-domain sample data. For such layers, getModel() will return the backing time-domain data, for example as a ReadOnlyWaveFileModel; but getExportModel() will return a model, possibly "local to" the layer, which adapts this into the form shown in the layer for a given view so that the export matches the layer's visible contents.

Because this is supposed to match the contents of the view rather than the backing model, it's necessary to pass in a view (or LayerGeometryProvider) so that the layer can retrieve its vertical extents for export.

Reimplemented from Layer.

Definition at line 147 of file SpectrogramLayer.cpp.

References Colour3DPlotExporter::Parameters::binDisplay, Colour3DPlotExporter::Sources::fft, Colour3DPlotExporter::Parameters::gain, getWindowSize(), m_binDisplay, m_colourScale, m_exporters, m_fftModel, m_gain, m_normalization, m_threshold, Colour3DPlotExporter::Parameters::normalization, Phase, Colour3DPlotExporter::Sources::provider, Colour3DPlotExporter::Parameters::scaleFactor, Colour3DPlotExporter::Sources::source, Colour3DPlotExporter::Parameters::threshold, and Colour3DPlotExporter::Sources::verticalBinLayer.

Referenced by getModel().

void SpectrogramLayer::paint ( LayerGeometryProvider ,
QPainter &  ,
QRect   
) const
overridevirtual

Paint the given rectangle of this layer onto the given view using the given painter, superimposing it on top of any existing material in that view.

The LayerGeometryProvider (an interface implemented by View) is provided here because it is possible for one layer to exist in more than one view, so the dimensions of the view may vary from one paint call to another (without any view having been resized).

Implements Layer.

Definition at line 1711 of file SpectrogramLayer.cpp.

References LayerGeometryProvider::getZoomLevel(), illuminateLocalFeatures(), m_model, and paintWithRenderer().

Referenced by getModel().

void SpectrogramLayer::setSynchronousPainting ( bool  )
overridevirtual

Enable or disable synchronous painting.

If synchronous painting is enabled, a call to paint() must complete painting the entire rectangle before it returns. If synchronous painting is disabled (which should be the default), the paint() call may defer painting some regions if data is not yet available, by calling back on its view to schedule another update. Synchronous painting is necessary when rendering to an image. Simple layer types will always paint synchronously, and so may ignore this.

Reimplemented from Layer.

Definition at line 1568 of file SpectrogramLayer.cpp.

References m_synchronous.

Referenced by getModel().

int SpectrogramLayer::getVerticalScaleWidth ( LayerGeometryProvider v,
bool  detailed,
QPainter &  paint 
) const
overridevirtual

Implements Layer.

Definition at line 2177 of file SpectrogramLayer.cpp.

References getColourScaleWidth(), Log, m_binScale, m_maxFrequency, and m_model.

Referenced by getCrosshairExtents(), getModel(), and paintCrosshairs().

void SpectrogramLayer::paintVerticalScale ( LayerGeometryProvider v,
bool  detailed,
QPainter &  paint,
QRect  rect 
) const
overridevirtual
bool SpectrogramLayer::getCrosshairExtents ( LayerGeometryProvider ,
QPainter &  ,
QPoint  cursorPos,
std::vector< QRect > &  extents 
) const
overridevirtual

Reimplemented from Layer.

Definition at line 1925 of file SpectrogramLayer.cpp.

References LayerGeometryProvider::getPaintHeight(), getVerticalScaleWidth(), and m_haveDetailedScale.

Referenced by getModel().

void SpectrogramLayer::paintCrosshairs ( LayerGeometryProvider v,
QPainter &  paint,
QPoint  cursorPos 
) const
overridevirtual
QString SpectrogramLayer::getFeatureDescription ( LayerGeometryProvider v,
QPoint &  pos 
) const
overridevirtual
bool SpectrogramLayer::snapToFeatureFrame ( LayerGeometryProvider ,
sv_frame_t &  ,
int &  resolution,
SnapType  ,
int   
) const
overridevirtual

Adjust the given frame to snap to the nearest feature, if possible.

If snap is SnapLeft or SnapRight, adjust the frame to match that of the nearest feature in the given direction regardless of how far away it is. If snap is SnapNeighbouring, adjust the frame to that of the nearest feature in either direction if it is close, and leave it alone (returning false) otherwise. SnapNeighbouring should always choose the same feature that would be used in an editing operation through calls to editStart etc.

If ycoord is non-negative, it contains the y coordinate at which the interaction that prompts this snap is taking place (e.g. of the mouse press used for a selection action). Layers that have objects at multiple different heights may choose to use this information. If the current action has no particular y coordinate associated with it, ycoord will be passed as -1.

Return true if a suitable feature was found and frame adjusted accordingly. Return false if no suitable feature was available (and leave frame unmodified). If returning true, also return the resolution of the model in this layer in sample frames.

Reimplemented from Layer.

Definition at line 1888 of file SpectrogramLayer.cpp.

References getWindowIncrement(), Layer::SnapLeft, Layer::SnapNeighbouring, and Layer::SnapRight.

Referenced by getModel().

void SpectrogramLayer::measureDoubleClick ( LayerGeometryProvider v,
QMouseEvent *  e 
)
overridevirtual
bool SpectrogramLayer::hasLightBackground ( ) const
overridevirtual

Reimplemented from Layer.

Definition at line 1159 of file SpectrogramLayer.cpp.

References ColourMapper::hasLightBackground(), m_colourInverted, and m_colourMap.

Referenced by getModel().

void SpectrogramLayer::setModel ( ModelId  model)
Layer::PropertyList SpectrogramLayer::getProperties ( ) const
override

Definition at line 283 of file SpectrogramLayer.cpp.

Referenced by getModel().

QString SpectrogramLayer::getPropertyLabel ( const PropertyName &  name) const
override

Definition at line 303 of file SpectrogramLayer.cpp.

Referenced by getModel().

QString SpectrogramLayer::getPropertyIconName ( const PropertyName &  ) const
override

Definition at line 322 of file SpectrogramLayer.cpp.

Referenced by getModel().

Layer::PropertyType SpectrogramLayer::getPropertyType ( const PropertyName &  name) const
override

Definition at line 328 of file SpectrogramLayer.cpp.

Referenced by getModel().

QString SpectrogramLayer::getPropertyGroupName ( const PropertyName &  name) const
override

Definition at line 338 of file SpectrogramLayer.cpp.

Referenced by getModel().

QString SpectrogramLayer::getPropertyValueLabel ( const PropertyName &  name,
int  value 
) const
override

Definition at line 512 of file SpectrogramLayer.cpp.

References ColourMapper::getColourMapLabel().

Referenced by getModel().

QString SpectrogramLayer::getPropertyValueIconName ( const PropertyName &  name,
int  value 
) const
override

Definition at line 610 of file SpectrogramLayer.cpp.

Referenced by getModel().

RangeMapper * SpectrogramLayer::getNewPropertyRangeMapper ( const PropertyName &  name) const
override

Definition at line 626 of file SpectrogramLayer.cpp.

Referenced by getModel().

void SpectrogramLayer::setChannel ( int  ch)

Specify the channel to use from the source model.

A value of -1 means to mix all available channels. The default is channel 0.

Definition at line 766 of file SpectrogramLayer.cpp.

References invalidateRenderers(), Layer::layerParametersChanged(), m_channel, and recreateFFTModel().

Referenced by getModel(), and setProperties().

int SpectrogramLayer::getChannel ( ) const

Definition at line 778 of file SpectrogramLayer.cpp.

References m_channel.

Referenced by getModel().

void SpectrogramLayer::setWindowSize ( int  ws)
int SpectrogramLayer::getWindowSize ( ) const

Definition at line 800 of file SpectrogramLayer.cpp.

References m_windowSize.

Referenced by getExportModel(), getModel(), and getRenderer().

void SpectrogramLayer::setWindowHopLevel ( int  level)
int SpectrogramLayer::getWindowHopLevel ( ) const

Definition at line 816 of file SpectrogramLayer.cpp.

References m_windowHopLevel.

Referenced by getModel().

void SpectrogramLayer::setOversampling ( int  oversampling)
int SpectrogramLayer::getOversampling ( ) const

Definition at line 832 of file SpectrogramLayer.cpp.

References m_oversampling.

Referenced by getModel().

void SpectrogramLayer::setWindowType ( WindowType  type)
WindowType SpectrogramLayer::getWindowType ( ) const

Definition at line 852 of file SpectrogramLayer.cpp.

References m_windowType.

Referenced by getModel(), and preferenceChanged().

void SpectrogramLayer::setGain ( float  gain)

Set the gain multiplier for sample values in this view.

The default is 1.0.

Definition at line 858 of file SpectrogramLayer.cpp.

References invalidateRenderers(), Layer::layerParametersChanged(), and m_gain.

Referenced by getModel(), setProperties(), and setProperty().

float SpectrogramLayer::getGain ( ) const

Definition at line 873 of file SpectrogramLayer.cpp.

References m_gain.

Referenced by getModel().

void SpectrogramLayer::setThreshold ( float  threshold)

Set the threshold for sample values to qualify for being shown in the FFT, in voltage units.

The default is 10^-8 (-80dB).

Definition at line 879 of file SpectrogramLayer.cpp.

References invalidateRenderers(), Layer::layerParametersChanged(), and m_threshold.

Referenced by getModel(), setProperties(), and setProperty().

float SpectrogramLayer::getThreshold ( ) const

Definition at line 891 of file SpectrogramLayer.cpp.

References m_threshold.

Referenced by getModel().

void SpectrogramLayer::setVerticallyFixed ( )

Mark the spectrogram layer as having a fixed range in the vertical axis.

This indicates that the visible frequency range is determined entirely by the configuration requested on construction, and that setMinFrequency, setMaxFrequency, and setDisplayExtents will never be called. This may allow some cache-size-related optimisations. It should be called immediately after construction, if at all.

Note that this cannot be reversed on a given object (this call takes no argument and there is no inverse call).

Definition at line 139 of file SpectrogramLayer.cpp.

References m_verticallyFixed, and recreateFFTModel().

Referenced by getModel().

int SpectrogramLayer::getMinFrequency ( ) const

Definition at line 916 of file SpectrogramLayer.cpp.

References m_minFrequency.

Referenced by getModel().

int SpectrogramLayer::getMaxFrequency ( ) const

Definition at line 941 of file SpectrogramLayer.cpp.

References m_maxFrequency.

Referenced by getModel(), and recreateFFTModel().

void SpectrogramLayer::setColourScale ( ColourScaleType  colourScale)

Specify the scale for sample levels.

See ColourScale and WaveformLayer for comparison and details of meter and dB scaling. The default is LogColourScale.

Definition at line 967 of file SpectrogramLayer.cpp.

References invalidateRenderers(), Layer::layerParametersChanged(), and m_colourScale.

Referenced by getModel(), setProperties(), setProperty(), and SpectrogramLayer().

ColourScaleType SpectrogramLayer::getColourScale ( ) const

Definition at line 979 of file SpectrogramLayer.cpp.

References m_colourScale.

Referenced by getModel().

void SpectrogramLayer::setColourScaleMultiple ( double  multiple)

Specify multiple factor for colour scale.

This is 2.0 for log-power spectrogram and 1.0 otherwise.

Definition at line 985 of file SpectrogramLayer.cpp.

References invalidateRenderers(), Layer::layerParametersChanged(), and m_colourScaleMultiple.

Referenced by getModel(), setProperties(), and setProperty().

double SpectrogramLayer::getColourScaleMultiple ( ) const

Definition at line 997 of file SpectrogramLayer.cpp.

References m_colourScaleMultiple.

Referenced by getModel().

void SpectrogramLayer::setBinScale ( BinScale  binScale)

Specify the scale for the y axis.

Definition at line 1021 of file SpectrogramLayer.cpp.

References invalidateRenderers(), Layer::layerParametersChanged(), and m_binScale.

Referenced by getModel(), setProperties(), setProperty(), and SpectrogramLayer().

BinScale SpectrogramLayer::getBinScale ( ) const

Definition at line 1032 of file SpectrogramLayer.cpp.

References m_binScale.

Referenced by getModel().

void SpectrogramLayer::setBinDisplay ( BinDisplay  binDisplay)

Specify the processing of frequency bins for the y axis.

Definition at line 1038 of file SpectrogramLayer.cpp.

References invalidateRenderers(), Layer::layerParametersChanged(), and m_binDisplay.

Referenced by getModel(), setProperties(), setProperty(), and SpectrogramLayer().

BinDisplay SpectrogramLayer::getBinDisplay ( ) const

Definition at line 1049 of file SpectrogramLayer.cpp.

References m_binDisplay.

Referenced by getModel().

void SpectrogramLayer::setNormalization ( ColumnNormalization  n)

Specify the normalization mode for individual columns.

Definition at line 1055 of file SpectrogramLayer.cpp.

References invalidateMagnitudes(), invalidateRenderers(), Layer::layerParametersChanged(), and m_normalization.

Referenced by getModel(), setProperties(), setProperty(), and SpectrogramLayer().

ColumnNormalization SpectrogramLayer::getNormalization ( ) const

Definition at line 1067 of file SpectrogramLayer.cpp.

References m_normalization.

Referenced by getModel().

void SpectrogramLayer::setNormalizeVisibleArea ( bool  n)

Specify whether to normalize the visible area.

Definition at line 1073 of file SpectrogramLayer.cpp.

References invalidateMagnitudes(), invalidateRenderers(), Layer::layerParametersChanged(), and m_normalizeVisibleArea.

Referenced by getModel(), setProperties(), and setProperty().

bool SpectrogramLayer::getNormalizeVisibleArea ( ) const

Definition at line 1085 of file SpectrogramLayer.cpp.

References m_normalizeVisibleArea.

Referenced by getModel().

void SpectrogramLayer::setColourMap ( int  map)

Specify the colour map.

See ColourMapper for the colour map values.

Definition at line 1003 of file SpectrogramLayer.cpp.

References invalidateRenderers(), Layer::layerParametersChanged(), and m_colourMap.

Referenced by getModel(), setProperties(), setProperty(), and SpectrogramLayer().

int SpectrogramLayer::getColourMap ( ) const

Definition at line 1015 of file SpectrogramLayer.cpp.

References m_colourMap.

Referenced by getModel().

void SpectrogramLayer::setColourRotation ( int  r)

Specify the colourmap rotation for the colour scale.

Definition at line 947 of file SpectrogramLayer.cpp.

References invalidateRenderers(), Layer::layerParametersChanged(), and m_colourRotation.

Referenced by getModel(), setProperties(), and setProperty().

int SpectrogramLayer::getColourRotation ( ) const

Referenced by getModel().

VerticalPosition SpectrogramLayer::getPreferredFrameCountPosition ( ) const
inlineoverridevirtual

Reimplemented from Layer.

Definition at line 215 of file SpectrogramLayer.h.

References Layer::PositionTop.

bool SpectrogramLayer::isLayerOpaque ( ) const
inlineoverridevirtual

This should return true if the layer completely obscures any underlying layers.

It's used to determine whether the view can safely draw any selection rectangles under the layer instead of over it, in the case where the layer is not scrollable and therefore needs to be redrawn each time (so that the selection rectangle can be cached).

Reimplemented from Layer.

Definition at line 219 of file SpectrogramLayer.h.

ColourSignificance SpectrogramLayer::getLayerColourSignificance ( ) const
inlineoverridevirtual

This should return the degree of meaning associated with colour in this layer.

If ColourAbsent, the layer does not use colour. If ColourIrrelevant, the layer is coloured and the colour may be set by the user, but it doesn't really matter what the colour is (for example, in a time ruler layer). If ColourDistinguishes, then the colour is used to distinguish this layer from other similar layers (e.g. for data layers). If ColourAndBackgroundSignificant, then the layer should be given greater weight than ColourDistinguishes layers when choosing a background colour (e.g. for waveforms). If ColourHasMeaningfulValue, colours are actually meaningful – the view will then show selections using unfilled rectangles instead of translucent filled rectangles, so as not to disturb the colours underneath.

Implements Layer.

Definition at line 221 of file SpectrogramLayer.h.

References cacheInvalid(), Layer::ColourHasMeaningfulValue, getBinForY(), getCompletion(), getCurrentVerticalZoomStep(), getDisplayExtents(), getError(), getFrequencyForY(), getNewVerticalZoomRangeMapper(), getSliceableModel(), getValueExtents(), getVerticalZoomSteps(), getYForBin(), getYForFrequency(), getYScaleValue(), isLayerScrollable(), preferenceChanged(), setDisplayExtents(), setLayerDormant(), setProperties(), setVerticalZoomStep(), and toXml().

double SpectrogramLayer::getYForFrequency ( const LayerGeometryProvider v,
double  frequency 
) const
double SpectrogramLayer::getFrequencyForY ( const LayerGeometryProvider v,
int  y 
) const
double SpectrogramLayer::getYForBin ( const LayerGeometryProvider v,
double  bin 
) const
overridevirtual
double SpectrogramLayer::getBinForY ( const LayerGeometryProvider ,
double  y 
) const
overridevirtual

Return the bin number, possibly fractional, at the given y coordinate.

Note that the whole numbers occur at the positions at which the bins "start" (i.e. the bottom of the visible bin, if the vertical scale is the usual way up).

Implements VerticalBinLayer.

Definition at line 1231 of file SpectrogramLayer.cpp.

References getEffectiveMaxFrequency(), getEffectiveMinFrequency(), getFFTSize(), LayerGeometryProvider::getFrequencyForY(), Log, m_binScale, and m_model.

Referenced by getLayerColourSignificance(), and getYBinRange().

int SpectrogramLayer::getCompletion ( LayerGeometryProvider ) const
overridevirtual

Return the proportion of background work complete in drawing this view, as a percentage – in most cases this will be the value returned by pointer from a call to the underlying model's isReady(int *) call.

The view may choose to show a progress meter if it finds that this returns < 100 at any given moment.

Reimplemented from Layer.

Definition at line 1795 of file SpectrogramLayer.cpp.

References m_fftModel.

Referenced by getLayerColourSignificance().

QString SpectrogramLayer::getError ( LayerGeometryProvider ) const
overridevirtual

Return an error string if any errors have occurred while loading or processing data for the given view.

Return the empty string if no error has occurred.

Reimplemented from Layer.

Definition at line 1807 of file SpectrogramLayer.cpp.

References m_fftModel.

Referenced by getLayerColourSignificance().

bool SpectrogramLayer::getValueExtents ( double &  min,
double &  max,
bool &  logarithmic,
QString &  unit 
) const
overridevirtual

Return the minimum and maximum values for the y axis of the model in this layer, as well as whether the layer is configured to use a logarithmic y axis display.

Also return the unit for these values if known.

This function returns the "normal" extents for the layer, not necessarily the extents actually in use in the display (see getDisplayExtents).

Implements Layer.

Definition at line 1815 of file SpectrogramLayer.cpp.

References getFFTSize(), Log, m_binScale, and m_model.

Referenced by getLayerColourSignificance().

bool SpectrogramLayer::getDisplayExtents ( double &  ,
double &   
) const
overridevirtual

Return the minimum and maximum values within the visible area for the y axis of this layer.

Return false if the layer has no display extents of its own. This could be because the layer is "auto-aligning" against another layer with the same units elsewhere in the view, or because the layer has no concept of a vertical scale at all.

Reimplemented from Layer.

Definition at line 1831 of file SpectrogramLayer.cpp.

References getEffectiveMaxFrequency(), and getEffectiveMinFrequency().

Referenced by getCurrentVerticalZoomStep(), and getLayerColourSignificance().

bool SpectrogramLayer::setDisplayExtents ( double  ,
double   
)
overridevirtual

Set the displayed minimum and maximum values for the y axis to the given range, if supported.

Return false if not supported on this layer (and set nothing). In most cases, layers that return false for getDisplayExtents should also return false for this function.

Reimplemented from Layer.

Definition at line 1841 of file SpectrogramLayer.cpp.

References getCurrentVerticalZoomStep(), invalidateMagnitudes(), invalidateRenderers(), Layer::layerParametersChanged(), m_lastEmittedZoomStep, m_maxFrequency, m_minFrequency, m_model, m_verticallyFixed, and Layer::verticalZoomChanged().

Referenced by getLayerColourSignificance().

bool SpectrogramLayer::getYScaleValue ( const LayerGeometryProvider ,
int  ,
double &  ,
QString &   
) const
overridevirtual

Return the value and unit at the given y coordinate in the given view.

Reimplemented from Layer.

Definition at line 1879 of file SpectrogramLayer.cpp.

References getFrequencyForY().

Referenced by getLayerColourSignificance().

void SpectrogramLayer::setProperties ( const QXmlAttributes &  )
overridevirtual
void SpectrogramLayer::setLayerDormant ( const LayerGeometryProvider v,
bool  dormant 
)
overridevirtual

Indicate that a layer is not currently visible in the given view and is not expected to become visible in the near future (for example because the user has explicitly removed or hidden it).

The layer may respond by (for example) freeing any cache memory it is using, until next time its paint method is called, when it should set itself un-dormant again.

A layer class that overrides this function must also call this class's implementation.

Reimplemented from Layer.

Definition at line 1091 of file SpectrogramLayer.cpp.

References invalidateRenderers(), Layer::isLayerDormant(), and Layer::setLayerDormant().

Referenced by getLayerColourSignificance().

bool SpectrogramLayer::isLayerScrollable ( const LayerGeometryProvider ) const
overridevirtual

This should return true if the layer can safely be scrolled automatically by a given view (simply copying the existing data and then refreshing the exposed area) without altering its meaning.

For the view widget as a whole this is usually not possible because of invariant (non-scrolling) material displayed over the top, but the widget may be able to optimise scrolling better if it is known that individual views can be scrolled safely in this way.

Reimplemented from Layer.

Definition at line 1115 of file SpectrogramLayer.cpp.

Referenced by getLayerColourSignificance().

int SpectrogramLayer::getVerticalZoomSteps ( int &  ) const
overridevirtual

Get the number of vertical zoom steps available for this layer.

If vertical zooming is not available, return 0. The meaning of "zooming" is entirely up to the layer – changing the zoom level may cause the layer to reset its display extents or change another property such as display gain. However, layers are advised for consistency to treat smaller zoom steps as "more distant" or "zoomed out" and larger ones as "closer" or "zoomed in".

Layers that provide this facility should also emit the verticalZoomChanged signal if their vertical zoom changes due to factors other than setVerticalZoomStep being called.

Reimplemented from Layer.

Definition at line 2491 of file SpectrogramLayer.cpp.

References getFFTSize(), SpectrogramRangeMapper::getPositionForValue(), m_initialMaxFrequency, and m_model.

Referenced by getLayerColourSignificance().

int SpectrogramLayer::getCurrentVerticalZoomStep ( ) const
overridevirtual

Get the current vertical zoom step.

A layer may support finer control over ranges etc than is available through the integer zoom step mechanism; if this one does, it should just return the nearest of the available zoom steps to the current settings.

Reimplemented from Layer.

Definition at line 2515 of file SpectrogramLayer.cpp.

References getDisplayExtents(), getFFTSize(), SpectrogramRangeMapper::getPositionForValue(), and m_model.

Referenced by getLayerColourSignificance(), setDisplayExtents(), and setProperty().

void SpectrogramLayer::setVerticalZoomStep ( int  )
overridevirtual

Set the vertical zoom step.

The meaning of "zooming" is entirely up to the layer – changing the zoom level may cause the layer to reset its display extents or change another property such as display gain.

Reimplemented from Layer.

Definition at line 2530 of file SpectrogramLayer.cpp.

References getFFTSize(), SpectrogramRangeMapper::getValueForPosition(), Log, m_binScale, m_maxFrequency, m_minFrequency, m_model, setMaxFrequency(), and setMinFrequency().

Referenced by getLayerColourSignificance().

RangeMapper * SpectrogramLayer::getNewVerticalZoomRangeMapper ( ) const
overridevirtual

Create and return a range mapper for vertical zoom step values.

See the RangeMapper documentation for more details. The returned value is allocated on the heap and will be deleted by the caller.

Reimplemented from Layer.

Definition at line 2599 of file SpectrogramLayer.cpp.

References getFFTSize(), and m_model.

Referenced by getLayerColourSignificance().

ModelId SpectrogramLayer::getSliceableModel ( ) const
overridevirtual

Implements SliceableLayer.

Definition at line 1553 of file SpectrogramLayer.cpp.

References m_fftModel.

Referenced by getLayerColourSignificance().

void SpectrogramLayer::cacheInvalid ( ModelId  )
protectedslot

Definition at line 1124 of file SpectrogramLayer.cpp.

References invalidateMagnitudes(), and invalidateRenderers().

Referenced by getLayerColourSignificance(), and setModel().

void SpectrogramLayer::cacheInvalid ( ModelId  ,
sv_frame_t  startFrame,
sv_frame_t  endFrame 
)
protectedslot

Definition at line 1135 of file SpectrogramLayer.cpp.

References invalidateMagnitudes(), and invalidateRenderers().

void SpectrogramLayer::preferenceChanged ( PropertyContainer::PropertyName  name)
protectedslot
pair< ColourScaleType, double > SpectrogramLayer::convertToColourScale ( int  value)
staticprotected

Definition at line 202 of file SpectrogramLayer.cpp.

References Linear, Log, Meter, and Phase.

Referenced by setProperties().

int SpectrogramLayer::convertFromColourScale ( ColourScaleType  type,
double  multiple 
)
staticprotected

Definition at line 215 of file SpectrogramLayer.cpp.

References Absolute, Linear, Log, Meter, Phase, and PlusMinusOne.

Referenced by getPropertyRangeAndValue(), and toXml().

std::pair< ColumnNormalization, bool > SpectrogramLayer::convertToColumnNorm ( int  value)
staticprotected

Definition at line 229 of file SpectrogramLayer.cpp.

Referenced by setProperty().

int SpectrogramLayer::convertFromColumnNorm ( ColumnNormalization  norm,
bool  visible 
)
staticprotected

Definition at line 241 of file SpectrogramLayer.cpp.

Referenced by getPropertyRangeAndValue().

int SpectrogramLayer::getColourScaleWidth ( QPainter &  paint) const
protected
void SpectrogramLayer::illuminateLocalFeatures ( LayerGeometryProvider v,
QPainter &  painter 
) const
protected
double SpectrogramLayer::getEffectiveMinFrequency ( ) const
protected
double SpectrogramLayer::getEffectiveMaxFrequency ( ) const
protected
bool SpectrogramLayer::getXBinRange ( LayerGeometryProvider v,
int  x,
double &  windowMin,
double &  windowMax 
) const
protected
bool SpectrogramLayer::getYBinRange ( LayerGeometryProvider v,
int  y,
double &  freqBinMin,
double &  freqBinMax 
) const
protected
bool SpectrogramLayer::getYBinSourceRange ( LayerGeometryProvider v,
int  y,
double &  freqMin,
double &  freqMax 
) const
protected

Definition at line 1300 of file SpectrogramLayer.cpp.

References getFFTSize(), getYBinRange(), and m_model.

Referenced by getFeatureDescription(), and illuminateLocalFeatures().

bool SpectrogramLayer::getAdjustedYBinSourceRange ( LayerGeometryProvider v,
int  x,
int  y,
double &  freqMin,
double &  freqMax,
double &  adjFreqMin,
double &  adjFreqMax 
) const
protected
bool SpectrogramLayer::getXBinSourceRange ( LayerGeometryProvider v,
int  x,
RealTime &  timeMin,
RealTime &  timeMax 
) const
protected

Definition at line 1278 of file SpectrogramLayer.cpp.

References getWindowIncrement(), getXBinRange(), m_model, and m_windowSize.

Referenced by getFeatureDescription().

bool SpectrogramLayer::getXYBinSourceRange ( LayerGeometryProvider v,
int  x,
int  y,
double &  min,
double &  max,
double &  phaseMin,
double &  phaseMax 
) const
protected

Definition at line 1391 of file SpectrogramLayer.cpp.

References getFFTSize(), getXBinRange(), getYBinRange(), m_fftModel, and m_model.

Referenced by getFeatureDescription().

int SpectrogramLayer::getWindowIncrement ( ) const
inlineprotected
void SpectrogramLayer::checkCacheSpace ( int *  suggestedPeakDivisor,
bool *  createWholeCache 
) const
protected

Definition at line 1511 of file SpectrogramLayer.cpp.

References m_fftModel.

Referenced by recreateFFTModel().

void SpectrogramLayer::invalidateMagnitudes ( )
protected
void SpectrogramLayer::deleteDerivedModels ( )
protected

Definition at line 181 of file SpectrogramLayer.cpp.

References m_exporters, m_fftModel, m_peakCache, and m_wholeCache.

Referenced by recreateFFTModel(), and ~SpectrogramLayer().

void SpectrogramLayer::paintDetailedScale ( LayerGeometryProvider v,
QPainter &  paint,
QRect  rect 
) const
protected
void SpectrogramLayer::paintDetailedScalePhase ( LayerGeometryProvider v,
QPainter &  paint,
QRect  rect 
) const
protected

Definition at line 2387 of file SpectrogramLayer.cpp.

References getColourScaleWidth(), and getRenderer().

Referenced by paintDetailedScale().

void SpectrogramLayer::updateMeasureRectYCoords ( LayerGeometryProvider v,
const MeasureRect r 
) const
overrideprotectedvirtual
void SpectrogramLayer::setMeasureRectYCoord ( LayerGeometryProvider v,
MeasureRect r,
bool  start,
int  y 
) const
overrideprotectedvirtual

Reimplemented from Layer.

Definition at line 2621 of file SpectrogramLayer.cpp.

References Layer::MeasureRect::endY, getFrequencyForY(), and Layer::MeasureRect::startY.

virtual int VerticalBinLayer::getIYForBin ( const LayerGeometryProvider v,
int  bin 
) const
inlinevirtualinherited

As getYForBin, but rounding to integer values.

Definition at line 42 of file VerticalBinLayer.h.

References VerticalBinLayer::getBinForY(), and VerticalBinLayer::getYForBin().

Referenced by Colour3DPlotLayer::paintVerticalScale().

virtual int VerticalBinLayer::getIBinForY ( const LayerGeometryProvider v,
int  y 
) const
inlinevirtualinherited

As getBinForY, but rounding to integer values.

Definition at line 57 of file VerticalBinLayer.h.

References VerticalBinLayer::getBinForY().

Referenced by Colour3DPlotLayer::getFeatureDescription().

ModelId Layer::getSourceModel ( ) const
inherited

Return the ID of the source model for the model represented in this layer.

If the model has no other source, or there is no model here, return None.

Definition at line 68 of file Layer.cpp.

References Layer::getModel().

Referenced by View::paintEvent().

virtual bool Layer::supportsOtherZoomLevels ( ) const
inlinevirtualinherited

Return true if this layer can handle zoom levels other than those supported by its zoom constraint (presumably less efficiently or accurately than the officially supported zoom levels).

If true, the layer will unenthusistically accept any integer zoom level from 1 to the maximum returned by its zoom constraint.

Definition at line 114 of file Layer.h.

References Layer::paint().

virtual VerticalPosition Layer::getPreferredTimeRulerPosition ( ) const
inlinevirtualinherited

Definition at line 143 of file Layer.h.

References Layer::PositionMiddle.

QString Layer::getPropertyContainerIconName ( ) const
overrideinherited
QString Layer::getPropertyContainerName ( ) const
inlineoverrideinherited
void Layer::setPresentationName ( QString  name)
virtualinherited

Definition at line 87 of file Layer.cpp.

References Layer::m_presentationName.

Referenced by Layer::getPropertyContainerName().

bool Layer::isPresentationNameSet ( ) const
virtualinherited

Definition at line 93 of file Layer.cpp.

References Layer::m_presentationName.

Referenced by Layer::getPropertyContainerName().

virtual QPixmap Layer::getLayerPresentationPixmap ( QSize  ) const
inlinevirtualinherited

Reimplemented in SingleColourLayer.

Definition at line 165 of file Layer.h.

References Layer::getVerticalScaleWidth().

virtual int Layer::getHorizontalScaleHeight ( LayerGeometryProvider ,
QPainter &   
) const
inlinevirtualinherited

Reimplemented in SpectrumLayer.

Definition at line 173 of file Layer.h.

Referenced by SliceLayer::paint(), and SliceLayer::paintVerticalScale().

void Layer::paintMeasurementRects ( LayerGeometryProvider v,
QPainter &  paint,
bool  showFocus,
QPoint  focusPoint 
) const
virtualinherited
bool Layer::nearestMeasurementRectChanged ( LayerGeometryProvider v,
QPoint  prev,
QPoint  now 
) const
virtualinherited
virtual QString Layer::getLabelPreceding ( sv_frame_t  ) const
inlinevirtualinherited

Reimplemented in RegionLayer, TimeValueLayer, BoxLayer, and TimeInstantLayer.

Definition at line 191 of file Layer.h.

virtual bool Layer::snapToSimilarFeature ( LayerGeometryProvider ,
sv_frame_t &  ,
int &  resolution,
SnapType   
) const
inlinevirtualinherited

Adjust the given frame to snap to the next feature that has "effectively" the same value as the feature prior to the given frame, if possible.

The snap type must be SnapLeft (snap to the time of the next feature prior to the one preceding the given frame that has a similar value to it) or SnapRight (snap to the time of the next feature following the given frame that has a similar value to the feature preceding it). Other values are not permitted.

Return true if a suitable feature was found and frame adjusted accordingly. Return false if no suitable feature was available (and leave frame unmodified). If returning true, also return the resolution of the model in this layer in sample frames.

Reimplemented in RegionLayer, and TimeValueLayer.

Definition at line 251 of file Layer.h.

Referenced by TimeValueLayer::snapToSimilarFeature(), and RegionLayer::snapToSimilarFeature().

virtual void Layer::drawStart ( LayerGeometryProvider ,
QMouseEvent *   
)
inlinevirtualinherited

Reimplemented in NoteLayer, RegionLayer, TimeValueLayer, BoxLayer, FlexiNoteLayer, ImageLayer, TimeInstantLayer, and TextLayer.

Definition at line 264 of file Layer.h.

Referenced by Pane::mousePressEvent().

virtual void Layer::drawDrag ( LayerGeometryProvider ,
QMouseEvent *   
)
inlinevirtualinherited

Reimplemented in NoteLayer, RegionLayer, TimeValueLayer, BoxLayer, FlexiNoteLayer, ImageLayer, TimeInstantLayer, and TextLayer.

Definition at line 265 of file Layer.h.

Referenced by Pane::mouseMoveEvent().

virtual void Layer::drawEnd ( LayerGeometryProvider ,
QMouseEvent *   
)
inlinevirtualinherited

Reimplemented in NoteLayer, RegionLayer, TimeValueLayer, BoxLayer, FlexiNoteLayer, ImageLayer, TimeInstantLayer, and TextLayer.

Definition at line 266 of file Layer.h.

Referenced by Pane::mouseReleaseEvent().

virtual void Layer::eraseStart ( LayerGeometryProvider ,
QMouseEvent *   
)
inlinevirtualinherited

Reimplemented in NoteLayer, RegionLayer, TimeValueLayer, BoxLayer, FlexiNoteLayer, TimeInstantLayer, and TextLayer.

Definition at line 268 of file Layer.h.

Referenced by Pane::mousePressEvent().

virtual void Layer::eraseDrag ( LayerGeometryProvider ,
QMouseEvent *   
)
inlinevirtualinherited

Reimplemented in NoteLayer, RegionLayer, TimeValueLayer, BoxLayer, FlexiNoteLayer, TimeInstantLayer, and TextLayer.

Definition at line 269 of file Layer.h.

Referenced by Pane::mouseMoveEvent().

virtual void Layer::eraseEnd ( LayerGeometryProvider ,
QMouseEvent *   
)
inlinevirtualinherited

Reimplemented in NoteLayer, RegionLayer, TimeValueLayer, BoxLayer, FlexiNoteLayer, TimeInstantLayer, and TextLayer.

Definition at line 270 of file Layer.h.

Referenced by Pane::mouseReleaseEvent().

virtual void Layer::editStart ( LayerGeometryProvider ,
QMouseEvent *   
)
inlinevirtualinherited

Reimplemented in NoteLayer, RegionLayer, TimeValueLayer, BoxLayer, FlexiNoteLayer, ImageLayer, TimeInstantLayer, and TextLayer.

Definition at line 272 of file Layer.h.

Referenced by Pane::mouseMoveEvent().

virtual void Layer::editDrag ( LayerGeometryProvider ,
QMouseEvent *   
)
inlinevirtualinherited

Reimplemented in NoteLayer, RegionLayer, TimeValueLayer, BoxLayer, FlexiNoteLayer, ImageLayer, TimeInstantLayer, and TextLayer.

Definition at line 273 of file Layer.h.

Referenced by Pane::mouseMoveEvent().

virtual void Layer::editEnd ( LayerGeometryProvider ,
QMouseEvent *   
)
inlinevirtualinherited

Reimplemented in NoteLayer, RegionLayer, TimeValueLayer, BoxLayer, FlexiNoteLayer, ImageLayer, TimeInstantLayer, and TextLayer.

Definition at line 274 of file Layer.h.

Referenced by Pane::mouseReleaseEvent().

virtual void Layer::splitStart ( LayerGeometryProvider ,
QMouseEvent *   
)
inlinevirtualinherited

Reimplemented in FlexiNoteLayer.

Definition at line 276 of file Layer.h.

Referenced by Pane::mousePressEvent().

virtual void Layer::splitEnd ( LayerGeometryProvider ,
QMouseEvent *   
)
inlinevirtualinherited

Reimplemented in FlexiNoteLayer.

Definition at line 277 of file Layer.h.

Referenced by Pane::mouseReleaseEvent().

virtual void Layer::addNote ( LayerGeometryProvider ,
QMouseEvent *   
)
inlinevirtualinherited
void Layer::measureEnd ( LayerGeometryProvider v,
QMouseEvent *  e 
)
virtualinherited
virtual bool Layer::haveCurrentMeasureRect ( ) const
inlinevirtualinherited

Definition at line 289 of file Layer.h.

References Layer::deleteCurrentMeasureRect(), and Layer::m_haveCurrentMeasureRect.

virtual bool Layer::editOpen ( LayerGeometryProvider ,
QMouseEvent *   
)
inlinevirtualinherited

Open an editor on the item under the mouse (e.g.

on double-click). If there is no item or editing is not supported, return false.

Reimplemented in NoteLayer, FlexiNoteLayer, RegionLayer, TimeValueLayer, ImageLayer, BoxLayer, TextLayer, and TimeInstantLayer.

Definition at line 299 of file Layer.h.

Referenced by Pane::mouseDoubleClickEvent().

virtual void Layer::moveSelection ( Selection  ,
sv_frame_t   
)
inlinevirtualinherited

Reimplemented in NoteLayer, FlexiNoteLayer, RegionLayer, TimeValueLayer, BoxLayer, TimeInstantLayer, ImageLayer, and TextLayer.

Definition at line 301 of file Layer.h.

Referenced by Pane::editSelectionEnd().

virtual void Layer::resizeSelection ( Selection  ,
Selection   
)
inlinevirtualinherited

Reimplemented in NoteLayer, FlexiNoteLayer, RegionLayer, TimeValueLayer, BoxLayer, TimeInstantLayer, ImageLayer, and TextLayer.

Definition at line 302 of file Layer.h.

Referenced by Pane::editSelectionEnd().

virtual void Layer::deleteSelection ( Selection  )
inlinevirtualinherited

Reimplemented in NoteLayer, FlexiNoteLayer, RegionLayer, TimeValueLayer, BoxLayer, TimeInstantLayer, ImageLayer, and TextLayer.

Definition at line 303 of file Layer.h.

virtual void Layer::copy ( LayerGeometryProvider ,
Selection  ,
Clipboard &   
)
inlinevirtualinherited

Reimplemented in NoteLayer, FlexiNoteLayer, RegionLayer, TimeValueLayer, BoxLayer, TimeInstantLayer, ImageLayer, and TextLayer.

Definition at line 305 of file Layer.h.

virtual bool Layer::paste ( LayerGeometryProvider ,
const Clipboard &  ,
sv_frame_t  ,
bool   
)
inlinevirtualinherited

Paste from the given clipboard onto the layer at the given frame offset.

If interactive is true, the layer may ask the user about paste options through a dialog if desired, and may return false if the user cancelled the paste operation. This function should return true if a paste actually occurred.

Reimplemented in NoteLayer, FlexiNoteLayer, RegionLayer, TimeValueLayer, BoxLayer, TimeInstantLayer, ImageLayer, and TextLayer.

Definition at line 314 of file Layer.h.

virtual bool Layer::isLayerEditable ( ) const
inlinevirtualinherited

This should return true if the layer can be edited by the user.

If this is the case, the appropriate edit tools may be made available by the application and the layer's drawStart/Drag/End and editStart/Drag/End methods should be implemented.

Reimplemented in TimeValueLayer, FlexiNoteLayer, RegionLayer, NoteLayer, BoxLayer, TimeInstantLayer, ImageLayer, and TextLayer.

Definition at line 382 of file Layer.h.

Referenced by Pane::mouseDoubleClickEvent(), Pane::mouseMoveEvent(), Pane::mousePressEvent(), Pane::mouseReleaseEvent(), Pane::shouldIlluminateLocalSelection(), and Pane::updateContextHelp().

void Layer::setObjectName ( const QString &  name)
virtualinherited

Definition at line 122 of file Layer.cpp.

References Layer::layerNameChanged().

Referenced by LayerFactory::createLayer(), and Layer::getError().

void Layer::toBriefXml ( QTextStream &  stream,
QString  indent = "",
QString  extraAttributes = "" 
) const
virtualinherited

Produce XML containing the layer's ID and type.

This is used to refer to the layer in the display section of the SV session file, for a layer that has already been described in the data section.

Definition at line 691 of file Layer.cpp.

References LayerFactory::getInstance(), Layer::getModel(), and Layer::m_presentationName.

Referenced by Layer::getError().

void Layer::addMeasurementRect ( const QXmlAttributes &  attributes)
virtualinherited

Add a measurement rectangle from the given XML attributes (presumably taken from a measurement element).

Does not use a command.

Definition at line 333 of file Layer.cpp.

References Layer::addMeasureRectToSet(), Layer::MeasureRect::endFrame, Layer::MeasureRect::endY, Layer::MeasureRect::haveFrames, Layer::MeasureRect::pixrect, Layer::MeasureRect::startFrame, and Layer::MeasureRect::startY.

Referenced by Layer::getError().

std::shared_ptr< PlayParameters > Layer::getPlayParameters ( )
overrideinherited

Return the play parameters for this layer, if any.

The return value is a shared_ptr that can be passed to (e.g.) PlayParameterRepository::EditCommand to change the parameters.

Definition at line 129 of file Layer.cpp.

References Layer::getModel().

Referenced by LayerTreeModel::data(), Layer::getError(), LayerTreeModel::LayerTreeModel(), LayerTreeModel::playParametersAudibilityChanged(), and LayerTreeModel::setData().

virtual bool Layer::needsTextLabelHeight ( ) const
inlinevirtualinherited

True if this layer will need to place text labels when it is painted.

The view will take into account how many layers are requesting this, and will provide a distinct y-coord to each layer on request via View::getTextLabelHeight().

Reimplemented in TimeValueLayer, SpectrumLayer, and TimeInstantLayer.

Definition at line 468 of file Layer.h.

virtual bool Layer::hasTimeXAxis ( ) const
inlinevirtualinherited

Return true if the X axis on the layer is time proportional to audio frames, false otherwise.

Almost all layer types return true here: the exceptions are spectrum and slice layers.

Reimplemented in SliceLayer.

Definition at line 475 of file Layer.h.

Referenced by Layer::getXScaleValue(), Layer::measureStart(), Pane::mouseMoveEvent(), Layer::setMeasureRectFromPixrect(), and Pane::zoomToRegion().

virtual void Layer::zoomToRegion ( const LayerGeometryProvider ,
QRect   
)
inlinevirtualinherited

Update the X and Y axis scales, where appropriate, to focus on the given rectangular region.

This should only be overridden by layers whose hasTimeXAxis() returns false - the pane handles zooming appropriately in every "normal" case.

Reimplemented in SliceLayer.

Definition at line 483 of file Layer.h.

References Layer::getValueExtents().

Referenced by Pane::zoomToRegion().

virtual bool Layer::adoptExtents ( double  ,
double  ,
QString   
)
inlinevirtualinherited

Consider using the given value extents and units for this layer.

This may be called on a new layer when added, to prepare it for editing, and the extents are those of the layer underneath it. May not be appropriate for most layer types.

Reimplemented in BoxLayer.

Definition at line 532 of file Layer.h.

References Layer::getXScaleValue().

bool Layer::getXScaleValue ( const LayerGeometryProvider v,
int  x,
double &  value,
QString &  unit 
) const
virtualinherited

Return the value and unit at the given x coordinate in the given view.

This is for descriptive purposes using the measurement tool. The default implementation works correctly if the layer hasTimeXAxis().

Reimplemented in SpectrumLayer.

Definition at line 160 of file Layer.cpp.

References LayerGeometryProvider::getFrameForX(), Layer::getModel(), and Layer::hasTimeXAxis().

Referenced by Layer::adoptExtents(), and View::drawMeasurementRect().

bool Layer::getYScaleDifference ( const LayerGeometryProvider v,
int  y0,
int  y1,
double &  diff,
QString &  unit 
) const
virtualinherited

Return the difference between the values at the given y coordinates in the given view, and the unit of the difference.

The default implementation just calls getYScaleValue twice and returns the difference, with the same unit.

Reimplemented in WaveformLayer, and SpectrumLayer.

Definition at line 173 of file Layer.cpp.

References Layer::getYScaleValue().

Referenced by View::drawMeasurementRect(), SpectrumLayer::getYScaleDifference(), and Layer::getYScaleValue().

virtual bool Layer::canExistWithoutModel ( ) const
inlinevirtualinherited
void Layer::showLayer ( LayerGeometryProvider view,
bool  show 
)
slotinherited

Change the visibility status (dormancy) of the layer in the given view.

Definition at line 153 of file Layer.cpp.

References Layer::layerParametersChanged(), and Layer::setLayerDormant().

Referenced by Layer::canExistWithoutModel(), ShowLayerCommand::execute(), LayerTreeModel::setData(), and ShowLayerCommand::unexecute().

void Layer::modelCompletionChanged ( ModelId  )
signalinherited
void Layer::modelAlignmentCompletionChanged ( ModelId  )
signalinherited
void Layer::modelChangedWithin ( ModelId  ,
sv_frame_t  startFrame,
sv_frame_t  endFrame 
)
signalinherited
void Layer::layerParametersChanged ( )
signalinherited

Referenced by Layer::canExistWithoutModel(), preferenceChanged(), WaveformLayer::setAggressiveCacheing(), WaveformLayer::setAutoNormalize(), SingleColourLayer::setBaseColour(), setBinDisplay(), SliceLayer::setBinScale(), Colour3DPlotLayer::setBinScale(), setBinScale(), SpectrumLayer::setChannel(), setChannel(), WaveformLayer::setChannel(), WaveformLayer::setChannelMode(), Colour3DPlotLayer::setColourMap(), setColourMap(), setColourRotation(), Colour3DPlotLayer::setColourScale(), setColourScale(), setColourScaleMultiple(), SliceLayer::setDisplayExtents(), NoteLayer::setDisplayExtents(), FlexiNoteLayer::setDisplayExtents(), TimeValueLayer::setDisplayExtents(), Colour3DPlotLayer::setDisplayExtents(), setDisplayExtents(), TimeValueLayer::setDrawSegmentDivisions(), SliceLayer::setEnergyScale(), TimeValueLayer::setFillColourMap(), RegionLayer::setFillColourMap(), SliceLayer::setFillColourMap(), WaveformLayer::setGain(), Colour3DPlotLayer::setGain(), SliceLayer::setGain(), setGain(), Colour3DPlotLayer::setInvertVertical(), setMaxFrequency(), WaveformLayer::setMiddleLineHeight(), setMinFrequency(), SpectrumLayer::setModel(), WaveformLayer::setModel(), Colour3DPlotLayer::setNormalization(), setNormalization(), SliceLayer::setNormalize(), Colour3DPlotLayer::setNormalizeVisibleArea(), setNormalizeVisibleArea(), Colour3DPlotLayer::setOpaque(), SpectrumLayer::setOversampling(), setOversampling(), TimeInstantLayer::setPlotStyle(), SliceLayer::setPlotStyle(), TimeValueLayer::setPlotStyle(), RegionLayer::setPlotStyle(), SliceLayer::setSamplingMode(), WaveformLayer::setScale(), TimeValueLayer::setShowDerivative(), WaveformLayer::setShowMeans(), SpectrumLayer::setShowPeaks(), SliceLayer::setSliceableModel(), Colour3DPlotLayer::setSmooth(), SliceLayer::setThreshold(), setThreshold(), BoxLayer::setVerticalScale(), RegionLayer::setVerticalScale(), NoteLayer::setVerticalScale(), TimeValueLayer::setVerticalScale(), FlexiNoteLayer::setVerticalScale(), Colour3DPlotLayer::setVerticalZoomStep(), SpectrumLayer::setWindowHopLevel(), setWindowHopLevel(), SpectrumLayer::setWindowSize(), setWindowSize(), SpectrumLayer::setWindowType(), setWindowType(), and Layer::showLayer().

void Layer::layerParameterRangesChanged ( )
signalinherited
void Layer::layerMeasurementRectsChanged ( )
signalinherited
void Layer::layerNameChanged ( )
signalinherited
void Layer::verticalZoomChanged ( )
signalinherited
bool Layer::clipboardHasDifferentAlignment ( LayerGeometryProvider v,
const Clipboard &  clip 
) const
protectedinherited
void Layer::addMeasureRectToSet ( const MeasureRect r)
inlineprotectedinherited

Definition at line 682 of file Layer.h.

References Layer::layerMeasurementRectsChanged(), and Layer::m_measureRects.

Referenced by Layer::addMeasurementRect().

void Layer::deleteMeasureRectFromSet ( const MeasureRect r)
inlineprotectedinherited

Definition at line 687 of file Layer.h.

References Layer::layerMeasurementRectsChanged(), and Layer::m_measureRects.

void Layer::setMeasureRectFromPixrect ( LayerGeometryProvider v,
MeasureRect r,
QRect  pixrect 
) const
protectedvirtualinherited
Layer::MeasureRectSet::const_iterator Layer::findFocusedMeasureRect ( QPoint  focusPoint) const
protectedinherited
bool Layer::valueExtentsMatchMine ( LayerGeometryProvider v) const
protectedinherited

Member Data Documentation

int SpectrogramLayer::m_channel
protected

Definition at line 269 of file SpectrogramLayer.h.

Referenced by getChannel(), recreateFFTModel(), setChannel(), and toXml().

int SpectrogramLayer::m_windowSize
protected
WindowType SpectrogramLayer::m_windowType
protected

Definition at line 271 of file SpectrogramLayer.h.

Referenced by getWindowType(), recreateFFTModel(), and setWindowType().

int SpectrogramLayer::m_windowHopLevel
protected
int SpectrogramLayer::m_oversampling
protected
float SpectrogramLayer::m_gain
protected
float SpectrogramLayer::m_initialGain
protected

Definition at line 275 of file SpectrogramLayer.h.

Referenced by getPropertyRangeAndValue().

float SpectrogramLayer::m_threshold
protected
float SpectrogramLayer::m_initialThreshold
protected

Definition at line 277 of file SpectrogramLayer.h.

Referenced by getPropertyRangeAndValue().

int SpectrogramLayer::m_colourRotation
protected
int SpectrogramLayer::m_initialRotation
protected

Definition at line 279 of file SpectrogramLayer.h.

Referenced by getPropertyRangeAndValue().

int SpectrogramLayer::m_minFrequency
protected
int SpectrogramLayer::m_initialMaxFrequency
protected

Definition at line 282 of file SpectrogramLayer.h.

Referenced by getVerticalZoomSteps(), and SpectrogramLayer().

bool SpectrogramLayer::m_verticallyFixed
protected
ColourScaleType SpectrogramLayer::m_colourScale
protected
double SpectrogramLayer::m_colourScaleMultiple
protected
int SpectrogramLayer::m_colourMap
protected
bool SpectrogramLayer::m_colourInverted
protected

Definition at line 287 of file SpectrogramLayer.h.

Referenced by getRenderer(), and hasLightBackground().

QColor SpectrogramLayer::m_crosshairColour
mutableprotected

Definition at line 288 of file SpectrogramLayer.h.

Referenced by getRenderer(), and paintCrosshairs().

ColumnNormalization SpectrogramLayer::m_normalization
protected
bool SpectrogramLayer::m_normalizeVisibleArea
protected
int SpectrogramLayer::m_lastEmittedZoomStep
protected

Definition at line 293 of file SpectrogramLayer.h.

Referenced by setDisplayExtents(), and setProperty().

bool SpectrogramLayer::m_synchronous
protected

Definition at line 294 of file SpectrogramLayer.h.

Referenced by paintWithRenderer(), and setSynchronousPainting().

bool SpectrogramLayer::m_haveDetailedScale
mutableprotected

Definition at line 296 of file SpectrogramLayer.h.

Referenced by getCrosshairExtents(), paintCrosshairs(), and paintVerticalScale().

bool SpectrogramLayer::m_exiting
protected

Definition at line 303 of file SpectrogramLayer.h.

ModelId SpectrogramLayer::m_wholeCache
protected

Definition at line 334 of file SpectrogramLayer.h.

Referenced by deleteDerivedModels(), getRenderer(), and recreateFFTModel().

ModelId SpectrogramLayer::m_peakCache
protected

Definition at line 335 of file SpectrogramLayer.h.

Referenced by deleteDerivedModels(), getRenderer(), and recreateFFTModel().

int SpectrogramLayer::m_peakCacheDivisor
protected

Definition at line 336 of file SpectrogramLayer.h.

Referenced by recreateFFTModel().

std::vector<ModelId> SpectrogramLayer::m_exporters
mutableprotected

Definition at line 338 of file SpectrogramLayer.h.

Referenced by deleteDerivedModels(), and getExportModel().

ViewMagMap SpectrogramLayer::m_viewMags
mutableprotected
ViewMagMap SpectrogramLayer::m_lastRenderedMags
mutableprotected

Definition at line 346 of file SpectrogramLayer.h.

Referenced by getRenderer(), and paintWithRenderer().

ViewRendererMap SpectrogramLayer::m_renderers
mutableprotected

Definition at line 350 of file SpectrogramLayer.h.

Referenced by getRenderer(), invalidateRenderers(), and paintWithRenderer().

MeasureRect Layer::m_draggingRect
protectedinherited
bool Layer::m_haveDraggingRect
protectedinherited
bool Layer::m_haveCurrentMeasureRect
mutableprotectedinherited
QPoint Layer::m_currentMeasureRectPoint
mutableprotectedinherited

Definition at line 697 of file Layer.h.

Referenced by Layer::deleteCurrentMeasureRect(), and Layer::paintMeasurementRects().

QString Layer::m_presentationName
protectedinherited

The documentation for this class was generated from the following files: