Mercurial > hg > svgui
comparison view/View.cpp @ 1146:74f2706995b7 3.0-integration
Merge work on unified spectrogram and colour 3d plot caching renderer
author | Chris Cannam |
---|---|
date | Fri, 05 Aug 2016 15:05:02 +0100 |
parents | 179ea8a2f650 |
children | 0edfed2c8482 |
comparison
equal
deleted
inserted
replaced
1056:b4fd6c67fce5 | 1146:74f2706995b7 |
---|---|
22 #include "base/Preferences.h" | 22 #include "base/Preferences.h" |
23 #include "ViewProxy.h" | 23 #include "ViewProxy.h" |
24 | 24 |
25 #include "layer/TimeRulerLayer.h" | 25 #include "layer/TimeRulerLayer.h" |
26 #include "layer/SingleColourLayer.h" | 26 #include "layer/SingleColourLayer.h" |
27 #include "layer/PaintAssistant.h" | |
28 | |
27 #include "data/model/PowerOfSqrtTwoZoomConstraint.h" | 29 #include "data/model/PowerOfSqrtTwoZoomConstraint.h" |
28 #include "data/model/RangeSummarisableTimeValueModel.h" | 30 #include "data/model/RangeSummarisableTimeValueModel.h" |
29 | 31 |
30 #include "widgets/IconLoader.h" | 32 #include "widgets/IconLoader.h" |
31 | 33 |
411 return h - (h * (frequency - minf)) / (maxf - minf); | 413 return h - (h * (frequency - minf)) / (maxf - minf); |
412 } | 414 } |
413 } | 415 } |
414 | 416 |
415 double | 417 double |
416 View::getFrequencyForY(int y, | 418 View::getFrequencyForY(double y, |
417 double minf, | 419 double minf, |
418 double maxf, | 420 double maxf, |
419 bool logarithmic) const | 421 bool logarithmic) const |
420 { | 422 { |
421 int h = height(); | 423 double h = height(); |
422 | 424 |
423 if (logarithmic) { | 425 if (logarithmic) { |
424 | 426 |
425 static double lastminf = 0.0, lastmaxf = 0.0; | 427 static double lastminf = 0.0, lastmaxf = 0.0; |
426 static double logminf = 0.0, logmaxf = 0.0; | 428 static double logminf = 0.0, logmaxf = 0.0; |
808 m_followZoom = f; | 810 m_followZoom = f; |
809 emit propertyContainerPropertyChanged(m_propertyContainer); | 811 emit propertyContainerPropertyChanged(m_propertyContainer); |
810 } | 812 } |
811 | 813 |
812 void | 814 void |
813 View::drawVisibleText(QPainter &paint, int x, int y, QString text, TextStyle style) const | |
814 { | |
815 if (style == OutlinedText || style == OutlinedItalicText) { | |
816 | |
817 paint.save(); | |
818 | |
819 if (style == OutlinedItalicText) { | |
820 QFont f(paint.font()); | |
821 f.setItalic(true); | |
822 paint.setFont(f); | |
823 } | |
824 | |
825 QColor penColour, surroundColour, boxColour; | |
826 | |
827 penColour = getForeground(); | |
828 surroundColour = getBackground(); | |
829 boxColour = surroundColour; | |
830 boxColour.setAlpha(127); | |
831 | |
832 paint.setPen(Qt::NoPen); | |
833 paint.setBrush(boxColour); | |
834 | |
835 QRect r = paint.fontMetrics().boundingRect(text); | |
836 r.translate(QPoint(x, y)); | |
837 // cerr << "drawVisibleText: r = " << r.x() << "," <<r.y() << " " << r.width() << "x" << r.height() << endl; | |
838 paint.drawRect(r); | |
839 paint.setBrush(Qt::NoBrush); | |
840 | |
841 paint.setPen(surroundColour); | |
842 | |
843 for (int dx = -1; dx <= 1; ++dx) { | |
844 for (int dy = -1; dy <= 1; ++dy) { | |
845 if (!(dx || dy)) continue; | |
846 paint.drawText(x + dx, y + dy, text); | |
847 } | |
848 } | |
849 | |
850 paint.setPen(penColour); | |
851 | |
852 paint.drawText(x, y, text); | |
853 | |
854 paint.restore(); | |
855 | |
856 } else { | |
857 | |
858 cerr << "ERROR: View::drawVisibleText: Boxed style not yet implemented!" << endl; | |
859 } | |
860 } | |
861 | |
862 void | |
863 View::setPlaybackFollow(PlaybackFollowMode m) | 815 View::setPlaybackFollow(PlaybackFollowMode m) |
864 { | 816 { |
865 m_followPlay = m; | 817 m_followPlay = m; |
866 emit propertyContainerPropertyChanged(m_propertyContainer); | 818 emit propertyContainerPropertyChanged(m_propertyContainer); |
867 } | 819 } |
2367 | 2319 |
2368 dxy = r.y() + r.height() + fontAscent + 2; | 2320 dxy = r.y() + r.height() + fontAscent + 2; |
2369 } | 2321 } |
2370 | 2322 |
2371 if (axs != "") { | 2323 if (axs != "") { |
2372 drawVisibleText(paint, axx, axy, axs, OutlinedText); | 2324 PaintAssistant::drawVisibleText(this, paint, axx, axy, axs, PaintAssistant::OutlinedText); |
2373 axy += fontHeight; | 2325 axy += fontHeight; |
2374 } | 2326 } |
2375 | 2327 |
2376 if (ays != "") { | 2328 if (ays != "") { |
2377 drawVisibleText(paint, axx, axy, ays, OutlinedText); | 2329 PaintAssistant::drawVisibleText(this, paint, axx, axy, ays, PaintAssistant::OutlinedText); |
2378 axy += fontHeight; | 2330 axy += fontHeight; |
2379 } | 2331 } |
2380 | 2332 |
2381 if (bxs != "") { | 2333 if (bxs != "") { |
2382 drawVisibleText(paint, bxx, bxy, bxs, OutlinedText); | 2334 PaintAssistant::drawVisibleText(this, paint, bxx, bxy, bxs, PaintAssistant::OutlinedText); |
2383 bxy += fontHeight; | 2335 bxy += fontHeight; |
2384 } | 2336 } |
2385 | 2337 |
2386 if (bys != "") { | 2338 if (bys != "") { |
2387 drawVisibleText(paint, bxx, bxy, bys, OutlinedText); | 2339 PaintAssistant::drawVisibleText(this, paint, bxx, bxy, bys, PaintAssistant::OutlinedText); |
2388 bxy += fontHeight; | 2340 bxy += fontHeight; |
2389 } | 2341 } |
2390 | 2342 |
2391 if (dxs != "") { | 2343 if (dxs != "") { |
2392 drawVisibleText(paint, dxx, dxy, dxs, OutlinedText); | 2344 PaintAssistant::drawVisibleText(this, paint, dxx, dxy, dxs, PaintAssistant::OutlinedText); |
2393 dxy += fontHeight; | 2345 dxy += fontHeight; |
2394 } | 2346 } |
2395 | 2347 |
2396 if (dys != "") { | 2348 if (dys != "") { |
2397 drawVisibleText(paint, dxx, dxy, dys, OutlinedText); | 2349 PaintAssistant::drawVisibleText(this, paint, dxx, dxy, dys, PaintAssistant::OutlinedText); |
2398 dxy += fontHeight; | 2350 dxy += fontHeight; |
2399 } | 2351 } |
2400 | 2352 |
2401 paint.restore(); | 2353 paint.restore(); |
2402 } | 2354 } |