Mercurial > hg > svgui
comparison layer/ColourScale.h @ 1324:13d9b422f7fe zoom
Merge from default branch
author | Chris Cannam |
---|---|
date | Mon, 17 Sep 2018 13:51:31 +0100 |
parents | a34a2a25907c |
children | d79e21855aef |
comparison
equal
deleted
inserted
replaced
1183:57d192e26331 | 1324:13d9b422f7fe |
---|---|
33 */ | 33 */ |
34 class ColourScale | 34 class ColourScale |
35 { | 35 { |
36 public: | 36 public: |
37 struct Parameters { | 37 struct Parameters { |
38 Parameters() : colourMap(0), scaleType(ColourScaleType::Linear), | 38 Parameters() : colourMap(0), scaleType(ColourScaleType::Linear), |
39 minValue(0.0), maxValue(1.0), | 39 minValue(0.0), maxValue(1.0), |
40 threshold(0.0), gain(1.0), multiple(1.0) { } | 40 threshold(0.0), gain(1.0), multiple(1.0) { } |
41 | 41 |
42 /** A colour map index as used by ColourMapper */ | 42 /** A colour map index as used by ColourMapper */ |
43 int colourMap; | 43 int colourMap; |
44 | 44 |
45 /** Distribution for the scale */ | 45 /** Distribution for the scale */ |
46 ColourScaleType scaleType; | 46 ColourScaleType scaleType; |
47 | 47 |
48 /** Minimum value in source range */ | 48 /** Minimum value in source range */ |
49 double minValue; | 49 double minValue; |
50 | 50 |
51 /** Maximum value in source range. Must be > minValue */ | 51 /** Maximum value in source range. Must be > minValue */ |
52 double maxValue; | 52 double maxValue; |
53 | 53 |
54 /** Threshold below which every value is mapped to background | 54 /** Threshold below which every value is mapped to background |
55 pixel 0 */ | 55 pixel 0 */ |
56 double threshold; | 56 double threshold; |
57 | 57 |
58 /** Gain to apply before thresholding, mapping, and clamping */ | 58 /** Gain to apply before thresholding, mapping, and clamping */ |
59 double gain; | 59 double gain; |
60 | 60 |
61 /** Multiple to apply after thresholding and mapping. In most | 61 /** Multiple to apply after thresholding and mapping. In most |
62 * cases the gain parameter is the one you want instead of | 62 * cases the gain parameter is the one you want instead of |
63 * this, but this can be used for example with Log scale to | 63 * this, but this can be used for example with Log scale to |
64 * produce the log of some power of the original value, | 64 * produce the log of some power of the original value, |
104 /** | 104 /** |
105 * Return the colour corresponding to the given value. This is | 105 * Return the colour corresponding to the given value. This is |
106 * equivalent to getColourForPixel(getPixel(value), rotation). | 106 * equivalent to getColourForPixel(getPixel(value), rotation). |
107 */ | 107 */ |
108 QColor getColour(double value, int rotation) const { | 108 QColor getColour(double value, int rotation) const { |
109 return getColourForPixel(getPixel(value), rotation); | 109 return getColourForPixel(getPixel(value), rotation); |
110 } | 110 } |
111 | 111 |
112 private: | 112 private: |
113 Parameters m_params; | 113 Parameters m_params; |
114 ColourMapper m_mapper; | 114 ColourMapper m_mapper; |