comparison widgets/WindowShapePreview.cpp @ 946:36cddc3de023 alignment_view

Merge from default branch
author Chris Cannam
date Mon, 20 Apr 2015 09:19:52 +0100
parents 4a578a360011
children 6645b6b8356f
comparison
equal deleted inserted replaced
897:499b637f2a26 946:36cddc3de023
30 #include <alloca.h> 30 #include <alloca.h>
31 #endif 31 #endif
32 32
33 WindowShapePreview::WindowShapePreview(QWidget *parent) : 33 WindowShapePreview::WindowShapePreview(QWidget *parent) :
34 QFrame(parent), 34 QFrame(parent),
35 m_windowType(WindowType(999)) 35 m_windowType(HanningWindow)
36 { 36 {
37 QHBoxLayout *layout = new QHBoxLayout; 37 QHBoxLayout *layout = new QHBoxLayout;
38 layout->setMargin(0); 38 layout->setMargin(0);
39 setLayout(layout); 39 setLayout(layout);
40 m_windowTimeExampleLabel = new QLabel; 40 m_windowTimeExampleLabel = new QLabel;
49 49
50 void 50 void
51 WindowShapePreview::updateLabels() 51 WindowShapePreview::updateLabels()
52 { 52 {
53 int step = 24; 53 int step = 24;
54 int peak = 48; 54 float peak = 48;
55 int w = step * 4, h = 64; 55 int w = step * 4, h = 64;
56 WindowType type = m_windowType; 56 WindowType type = m_windowType;
57 Window<float> windower = Window<float>(type, step * 2); 57 Window<float> windower = Window<float>(type, step * 2);
58 58
59 QPixmap timeLabel(w, h + 1); 59 QPixmap timeLabel(w, h + 1);
60 timeLabel.fill(Qt::white); 60 timeLabel.fill(Qt::white);
61 QPainter timePainter(&timeLabel); 61 QPainter timePainter(&timeLabel);
62 62
63 QPainterPath path; 63 QPainterPath path;
64 64
65 path.moveTo(0, h - peak + 1); 65 path.moveTo(0, float(h) - peak + 1);
66 path.lineTo(w, h - peak + 1); 66 path.lineTo(w, float(h) - peak + 1);
67 67
68 timePainter.setPen(Qt::gray); 68 timePainter.setPen(Qt::gray);
69 timePainter.setRenderHint(QPainter::Antialiasing, true); 69 timePainter.setRenderHint(QPainter::Antialiasing, true);
70 timePainter.drawPath(path); 70 timePainter.drawPath(path);
71 71
82 for (int i = 0; i < step * 2; ++i) { 82 for (int i = 0; i < step * 2; ++i) {
83 acc[j * step + i] += windower.getValue(i); 83 acc[j * step + i] += windower.getValue(i);
84 } 84 }
85 } 85 }
86 for (int i = 0; i < w; ++i) { 86 for (int i = 0; i < w; ++i) {
87 int y = h - int(peak * acc[i] + 0.001) + 1; 87 int y = h - int(peak * acc[i] + 0.001f) + 1;
88 if (i == 0) path.moveTo(i, y); 88 if (i == 0) path.moveTo(i, y);
89 else path.lineTo(i, y); 89 else path.lineTo(i, y);
90 } 90 }
91 91
92 timePainter.drawPath(path); 92 timePainter.drawPath(path);
148 bool first = true; 148 bool first = true;
149 for (int i = 0; i < fftsize/2; ++i) { 149 for (int i = 0; i < fftsize/2; ++i) {
150 float power = output[i][0] * output[i][0] + output[i][1] * output[i][1]; 150 float power = output[i][0] * output[i][0] + output[i][1] * output[i][1];
151 float db = mindb; 151 float db = mindb;
152 if (power > 0) { 152 if (power > 0) {
153 db = 20 * log10(power); 153 db = 20.f * log10f(power);
154 if (first || db > maxdb) maxdb = db; 154 if (first || db > maxdb) maxdb = db;
155 if (first || db < mindb) mindb = db; 155 if (first || db < mindb) mindb = db;
156 first = false; 156 first = false;
157 } 157 }
158 } 158 }
165 165
166 float maxval = maxdb + -mindb; 166 float maxval = maxdb + -mindb;
167 167
168 // float ly = h - ((-80.f + -mindb) / maxval) * peak + 1; 168 // float ly = h - ((-80.f + -mindb) / maxval) * peak + 1;
169 169
170 path.moveTo(0, h - peak + 1); 170 path.moveTo(0, float(h) - peak + 1);
171 path.lineTo(fw, h - peak + 1); 171 path.lineTo(fw, float(h) - peak + 1);
172 172
173 freqPainter.setPen(Qt::gray); 173 freqPainter.setPen(Qt::gray);
174 freqPainter.setRenderHint(QPainter::Antialiasing, true); 174 freqPainter.setRenderHint(QPainter::Antialiasing, true);
175 freqPainter.drawPath(path); 175 freqPainter.drawPath(path);
176 176
179 179
180 // cerr << "maxdb = " << maxdb << ", mindb = " << mindb << ", maxval = " <<maxval << endl; 180 // cerr << "maxdb = " << maxdb << ", mindb = " << mindb << ", maxval = " <<maxval << endl;
181 181
182 for (int i = 0; i < fftsize/2; ++i) { 182 for (int i = 0; i < fftsize/2; ++i) {
183 float power = output[i][0] * output[i][0] + output[i][1] * output[i][1]; 183 float power = output[i][0] * output[i][0] + output[i][1] * output[i][1];
184 float db = 20 * log10(power); 184 float db = 20.f * log10f(power);
185 float val = db + -mindb; 185 float val = db + -mindb;
186 if (val < 0) val = 0; 186 if (val < 0) val = 0;
187 float norm = val / maxval; 187 float norm = val / maxval;
188 float x = (fw / float(fftsize/2)) * i; 188 float x = (float(fw) / float(fftsize/2)) * float(i);
189 float y = h - norm * peak + 1; 189 float y = float(h) - norm * peak + 1;
190 if (i == 0) path.moveTo(x, y); 190 if (i == 0) path.moveTo(x, y);
191 else path.lineTo(x, y); 191 else path.lineTo(x, y);
192 } 192 }
193 193
194 freqPainter.setRenderHint(QPainter::Antialiasing, true); 194 freqPainter.setRenderHint(QPainter::Antialiasing, true);