annotate layer/ColourScaleLayer.h @ 1127:9fb8dfd7ce4c spectrogram-minor-refactor

Fix threshold in spectrogram -- it wasn't working in the last release. There is a new protocol for this. Formerly the threshold parameter had a range from -50dB to 0 with the default at -50, and -50 treated internally as "no threshold". However, there was a hardcoded, hidden internal threshold for spectrogram colour mapping at -80dB with anything below this being rounded to zero. Now the threshold parameter has range -81 to -1 with the default at -80, -81 is treated internally as "no threshold", and there is no hidden internal threshold. So the default behaviour is the same as before, an effective -80dB threshold, but it is now possible to change this in both directions. Sessions reloaded from prior versions may look slightly different because, if the session says there should be no threshold, there will now actually be no threshold instead of having the hidden internal one. Still need to do something in the UI to make it apparent that the -81dB setting removes the threshold entirely. This is at least no worse than the previous, also obscured, magic -50dB setting.
author Chris Cannam
date Mon, 01 Aug 2016 16:21:01 +0100
parents c98a1fe7c7f5
children
rev   line source
Chris@699 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@699 2
Chris@699 3 /*
Chris@699 4 Sonic Visualiser
Chris@699 5 An audio file viewer and annotation editor.
Chris@699 6 Centre for Digital Music, Queen Mary, University of London.
Chris@699 7 This file copyright 2006-2013 Chris Cannam and QMUL.
Chris@699 8
Chris@699 9 This program is free software; you can redistribute it and/or
Chris@699 10 modify it under the terms of the GNU General Public License as
Chris@699 11 published by the Free Software Foundation; either version 2 of the
Chris@699 12 License, or (at your option) any later version. See the file
Chris@699 13 COPYING included with this distribution for more information.
Chris@699 14 */
Chris@699 15
Chris@699 16 #ifndef COLOUR_SCALE_LAYER_H
Chris@699 17 #define COLOUR_SCALE_LAYER_H
Chris@699 18
Chris@699 19 #include <QString>
Chris@699 20 #include <QColor>
Chris@699 21
Chris@918 22 class LayerGeometryProvider;
Chris@918 23
Chris@1066 24 /**
Chris@1066 25 * Interface for layers in which a colour scale represents (or can
Chris@1066 26 * sometimes represent, depending on the display mode) the sample
Chris@1066 27 * value. For example, TimeValueLayer uses colour scale when in
Chris@1066 28 * segment mode and so provides this interface for use by the
Chris@1066 29 * LogColourScale or LinearColourScale scale renderers.
Chris@1066 30 */
Chris@699 31 class ColourScaleLayer
Chris@699 32 {
Chris@699 33 public:
Chris@699 34 virtual QString getScaleUnits() const = 0;
Chris@918 35 virtual QColor getColourForValue(LayerGeometryProvider *v, double value) const = 0;
Chris@699 36 };
Chris@699 37
Chris@699 38 #endif
Chris@699 39