forked from embeddedmz/QwtWaterfallplot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathColorMaps.cpp
76 lines (63 loc) · 2.35 KB
/
ColorMaps.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
#include "ColorMaps.h"
#include <QColor>
namespace ColorMaps
{
ControlPoints BlackBodyRadiation()
{
const double rgbPoints[] = {
0, 0, 0, 0,
0.4, 0.901960784314, 0, 0,
0.8, 0.901960784314, 0.901960784314, 0,
1, 1, 1, 1 };
ControlPoints ctrlPts;
for (size_t rgb = 0; rgb < sizeof(rgbPoints) / sizeof(double); rgb += 4)
{
ctrlPts.push_back(ControlPoint(rgbPoints[rgb],
rgbPoints[rgb + 1],
rgbPoints[rgb + 2],
rgbPoints[rgb + 3]));
}
return ctrlPts;
}
ControlPoints CoolToWarm()
{
const double rgbPoints[] = {
0, 0.23137254902000001, 0.298039215686, 0.75294117647100001,
0.5, 0.86499999999999999, 0.86499999999999999, 0.86499999999999999,
1, 0.70588235294099999, 0.015686274509800001, 0.149019607843 };
ControlPoints ctrlPts;
for (size_t rgb = 0; rgb < sizeof(rgbPoints) / sizeof(double); rgb += 4)
{
ctrlPts.push_back(ControlPoint(rgbPoints[rgb],
rgbPoints[rgb + 1],
rgbPoints[rgb + 2],
rgbPoints[rgb + 3]));
}
return ctrlPts;
}
ControlPoints Jet()
{
QColor darkBlue(Qt::darkBlue); // 0.0
QColor blue(Qt::blue); // 0.2
QColor cyan(Qt::cyan); // 0.4
QColor yellow(Qt::yellow); // 0.6
QColor red(Qt::red); // 0.8
QColor darkRed(Qt::darkRed); // 1.0
const double rgbPoints[] = {
0.0, darkBlue.redF(), darkBlue.greenF(), darkBlue.blueF(),
0.2, blue.redF(), blue.greenF(), blue.blueF(),
0.4, cyan.redF(), cyan.greenF(), cyan.blueF(),
0.6, yellow.redF(), yellow.greenF(), yellow.blueF(),
0.8, red.redF(), red.greenF(), red.blueF(),
1.0, darkRed.redF(), darkRed.greenF(), darkRed.blueF() };
ControlPoints ctrlPts;
for (size_t rgb = 0; rgb < sizeof(rgbPoints) / sizeof(double); rgb += 4)
{
ctrlPts.push_back(ControlPoint(rgbPoints[rgb],
rgbPoints[rgb + 1],
rgbPoints[rgb + 2],
rgbPoints[rgb + 3]));
}
return ctrlPts;
}
}