Mercurial > hg > svgui
comparison layer/SpectrogramLayer.cpp @ 586:1ae54a29e59e
Merge from debug-output branch
author | Chris Cannam |
---|---|
date | Tue, 14 Jun 2011 14:48:29 +0100 |
parents | f4960f8ce798 |
children | 4806715f7a19 |
comparison
equal
deleted
inserted
replaced
583:4c484636d5ec | 586:1ae54a29e59e |
---|---|
576 | 576 |
577 //!!! when are views removed from the map? on setLayerDormant? | 577 //!!! when are views removed from the map? on setLayerDormant? |
578 const View *v = i->first; | 578 const View *v = i->first; |
579 | 579 |
580 #ifdef DEBUG_SPECTROGRAM_REPAINT | 580 #ifdef DEBUG_SPECTROGRAM_REPAINT |
581 std::cerr << "SpectrogramLayer::invalidateImageCaches(" | 581 DEBUG << "SpectrogramLayer::invalidateImageCaches(" |
582 << startFrame << ", " << endFrame << "): view range is " | 582 << startFrame << ", " << endFrame << "): view range is " |
583 << v->getStartFrame() << ", " << v->getEndFrame() | 583 << v->getStartFrame() << ", " << v->getEndFrame() |
584 << std::endl; | 584 << endl; |
585 | 585 |
586 std::cerr << "Valid area was: " << i->second.validArea.x() << ", " | 586 std::cerr << "Valid area was: " << i->second.validArea.x() << ", " |
587 << i->second.validArea.y() << " " | 587 << i->second.validArea.y() << " " |
588 << i->second.validArea.width() << "x" | 588 << i->second.validArea.width() << "x" |
589 << i->second.validArea.height() << std::endl; | 589 << i->second.validArea.height() << std::endl; |
596 #endif | 596 #endif |
597 return; | 597 return; |
598 } | 598 } |
599 int x = v->getXForFrame(startFrame); | 599 int x = v->getXForFrame(startFrame); |
600 #ifdef DEBUG_SPECTROGRAM_REPAINT | 600 #ifdef DEBUG_SPECTROGRAM_REPAINT |
601 std::cerr << "clipping from 0 to " << x-1 << std::endl; | 601 DEBUG << "clipping from 0 to " << x-1 << endl; |
602 #endif | 602 #endif |
603 if (x > 1) { | 603 if (x > 1) { |
604 i->second.validArea &= | 604 i->second.validArea &= |
605 QRect(0, 0, x-1, v->height()); | 605 QRect(0, 0, x-1, v->height()); |
606 } else { | 606 } else { |
613 #endif | 613 #endif |
614 return; | 614 return; |
615 } | 615 } |
616 int x = v->getXForFrame(endFrame); | 616 int x = v->getXForFrame(endFrame); |
617 #ifdef DEBUG_SPECTROGRAM_REPAINT | 617 #ifdef DEBUG_SPECTROGRAM_REPAINT |
618 std::cerr << "clipping from " << x+1 << " to " << v->width() | 618 DEBUG << "clipping from " << x+1 << " to " << v->width() |
619 << std::endl; | 619 << endl; |
620 #endif | 620 #endif |
621 if (x < v->width()) { | 621 if (x < v->width()) { |
622 i->second.validArea &= | 622 i->second.validArea &= |
623 QRect(x+1, 0, v->width()-(x+1), v->height()); | 623 QRect(x+1, 0, v->width()-(x+1), v->height()); |
624 } else { | 624 } else { |
636 } | 636 } |
637 | 637 |
638 void | 638 void |
639 SpectrogramLayer::preferenceChanged(PropertyContainer::PropertyName name) | 639 SpectrogramLayer::preferenceChanged(PropertyContainer::PropertyName name) |
640 { | 640 { |
641 std::cerr << "SpectrogramLayer::preferenceChanged(" << name.toStdString() << ")" << std::endl; | 641 DEBUG << "SpectrogramLayer::preferenceChanged(" << name << ")" << endl; |
642 | 642 |
643 if (name == "Window Type") { | 643 if (name == "Window Type") { |
644 setWindowType(Preferences::getInstance()->getWindowType()); | 644 setWindowType(Preferences::getInstance()->getWindowType()); |
645 return; | 645 return; |
646 } | 646 } |
762 } | 762 } |
763 | 763 |
764 void | 764 void |
765 SpectrogramLayer::setGain(float gain) | 765 SpectrogramLayer::setGain(float gain) |
766 { | 766 { |
767 // std::cerr << "SpectrogramLayer::setGain(" << gain << ") (my gain is now " | 767 // DEBUG << "SpectrogramLayer::setGain(" << gain << ") (my gain is now " |
768 // << m_gain << ")" << std::endl; | 768 // << m_gain << ")" << endl; |
769 | 769 |
770 if (m_gain == gain) return; | 770 if (m_gain == gain) return; |
771 | 771 |
772 invalidateImageCaches(); | 772 invalidateImageCaches(); |
773 | 773 |
803 void | 803 void |
804 SpectrogramLayer::setMinFrequency(size_t mf) | 804 SpectrogramLayer::setMinFrequency(size_t mf) |
805 { | 805 { |
806 if (m_minFrequency == mf) return; | 806 if (m_minFrequency == mf) return; |
807 | 807 |
808 // std::cerr << "SpectrogramLayer::setMinFrequency: " << mf << std::endl; | 808 // DEBUG << "SpectrogramLayer::setMinFrequency: " << mf << endl; |
809 | 809 |
810 invalidateImageCaches(); | 810 invalidateImageCaches(); |
811 invalidateMagnitudes(); | 811 invalidateMagnitudes(); |
812 | 812 |
813 m_minFrequency = mf; | 813 m_minFrequency = mf; |
824 void | 824 void |
825 SpectrogramLayer::setMaxFrequency(size_t mf) | 825 SpectrogramLayer::setMaxFrequency(size_t mf) |
826 { | 826 { |
827 if (m_maxFrequency == mf) return; | 827 if (m_maxFrequency == mf) return; |
828 | 828 |
829 // std::cerr << "SpectrogramLayer::setMaxFrequency: " << mf << std::endl; | 829 // DEBUG << "SpectrogramLayer::setMaxFrequency: " << mf << endl; |
830 | 830 |
831 invalidateImageCaches(); | 831 invalidateImageCaches(); |
832 invalidateMagnitudes(); | 832 invalidateMagnitudes(); |
833 | 833 |
834 m_maxFrequency = mf; | 834 m_maxFrequency = mf; |
949 } | 949 } |
950 | 950 |
951 void | 951 void |
952 SpectrogramLayer::setNormalizeVisibleArea(bool n) | 952 SpectrogramLayer::setNormalizeVisibleArea(bool n) |
953 { | 953 { |
954 std::cerr << "SpectrogramLayer::setNormalizeVisibleArea(" << n | 954 DEBUG << "SpectrogramLayer::setNormalizeVisibleArea(" << n |
955 << ") (from " << m_normalizeVisibleArea << ")" << std::endl; | 955 << ") (from " << m_normalizeVisibleArea << ")" << endl; |
956 | 956 |
957 if (m_normalizeVisibleArea == n) return; | 957 if (m_normalizeVisibleArea == n) return; |
958 | 958 |
959 invalidateImageCaches(); | 959 invalidateImageCaches(); |
960 invalidateMagnitudes(); | 960 invalidateMagnitudes(); |
973 SpectrogramLayer::setLayerDormant(const View *v, bool dormant) | 973 SpectrogramLayer::setLayerDormant(const View *v, bool dormant) |
974 { | 974 { |
975 if (dormant) { | 975 if (dormant) { |
976 | 976 |
977 #ifdef DEBUG_SPECTROGRAM_REPAINT | 977 #ifdef DEBUG_SPECTROGRAM_REPAINT |
978 std::cerr << "SpectrogramLayer::setLayerDormant(" << dormant << ")" | 978 DEBUG << "SpectrogramLayer::setLayerDormant(" << dormant << ")" |
979 << std::endl; | 979 << endl; |
980 #endif | 980 #endif |
981 | 981 |
982 if (isLayerDormant(v)) { | 982 if (isLayerDormant(v)) { |
983 return; | 983 return; |
984 } | 984 } |
1018 | 1018 |
1019 void | 1019 void |
1020 SpectrogramLayer::cacheInvalid() | 1020 SpectrogramLayer::cacheInvalid() |
1021 { | 1021 { |
1022 #ifdef DEBUG_SPECTROGRAM_REPAINT | 1022 #ifdef DEBUG_SPECTROGRAM_REPAINT |
1023 std::cerr << "SpectrogramLayer::cacheInvalid()" << std::endl; | 1023 DEBUG << "SpectrogramLayer::cacheInvalid()" << endl; |
1024 #endif | 1024 #endif |
1025 | 1025 |
1026 invalidateImageCaches(); | 1026 invalidateImageCaches(); |
1027 invalidateMagnitudes(); | 1027 invalidateMagnitudes(); |
1028 } | 1028 } |
1029 | 1029 |
1030 void | 1030 void |
1031 SpectrogramLayer::cacheInvalid(size_t from, size_t to) | 1031 SpectrogramLayer::cacheInvalid(size_t from, size_t to) |
1032 { | 1032 { |
1033 #ifdef DEBUG_SPECTROGRAM_REPAINT | 1033 #ifdef DEBUG_SPECTROGRAM_REPAINT |
1034 std::cerr << "SpectrogramLayer::cacheInvalid(" << from << ", " << to << ")" << std::endl; | 1034 DEBUG << "SpectrogramLayer::cacheInvalid(" << from << ", " << to << ")" << endl; |
1035 #endif | 1035 #endif |
1036 | 1036 |
1037 invalidateImageCaches(from, to); | 1037 invalidateImageCaches(from, to); |
1038 invalidateMagnitudes(); | 1038 invalidateMagnitudes(); |
1039 } | 1039 } |
1044 if (!m_model) return; | 1044 if (!m_model) return; |
1045 | 1045 |
1046 bool allDone = true; | 1046 bool allDone = true; |
1047 | 1047 |
1048 #ifdef DEBUG_SPECTROGRAM_REPAINT | 1048 #ifdef DEBUG_SPECTROGRAM_REPAINT |
1049 std::cerr << "SpectrogramLayer::fillTimerTimedOut: have " << m_fftModels.size() << " FFT models associated with views" << std::endl; | 1049 DEBUG << "SpectrogramLayer::fillTimerTimedOut: have " << m_fftModels.size() << " FFT models associated with views" << endl; |
1050 #endif | 1050 #endif |
1051 | 1051 |
1052 for (ViewFFTMap::iterator i = m_fftModels.begin(); | 1052 for (ViewFFTMap::iterator i = m_fftModels.begin(); |
1053 i != m_fftModels.end(); ++i) { | 1053 i != m_fftModels.end(); ++i) { |
1054 | 1054 |
1058 if (model) { | 1058 if (model) { |
1059 | 1059 |
1060 size_t fill = model->getFillExtent(); | 1060 size_t fill = model->getFillExtent(); |
1061 | 1061 |
1062 #ifdef DEBUG_SPECTROGRAM_REPAINT | 1062 #ifdef DEBUG_SPECTROGRAM_REPAINT |
1063 std::cerr << "SpectrogramLayer::fillTimerTimedOut: extent for " << model << ": " << fill << ", last " << lastFill << ", total " << m_model->getEndFrame() << std::endl; | 1063 DEBUG << "SpectrogramLayer::fillTimerTimedOut: extent for " << model << ": " << fill << ", last " << lastFill << ", total " << m_model->getEndFrame() << endl; |
1064 #endif | 1064 #endif |
1065 | 1065 |
1066 if (fill >= lastFill) { | 1066 if (fill >= lastFill) { |
1067 if (fill >= m_model->getEndFrame() && lastFill > 0) { | 1067 if (fill >= m_model->getEndFrame() && lastFill > 0) { |
1068 #ifdef DEBUG_SPECTROGRAM_REPAINT | 1068 #ifdef DEBUG_SPECTROGRAM_REPAINT |
1627 size_t fftSize = getFFTSize(v); | 1627 size_t fftSize = getFFTSize(v); |
1628 | 1628 |
1629 if (m_fftModels.find(v) != m_fftModels.end()) { | 1629 if (m_fftModels.find(v) != m_fftModels.end()) { |
1630 if (m_fftModels[v].first == 0) { | 1630 if (m_fftModels[v].first == 0) { |
1631 #ifdef DEBUG_SPECTROGRAM_REPAINT | 1631 #ifdef DEBUG_SPECTROGRAM_REPAINT |
1632 std::cerr << "SpectrogramLayer::getFFTModel(" << v << "): Found null model" << std::endl; | 1632 DEBUG << "SpectrogramLayer::getFFTModel(" << v << "): Found null model" << endl; |
1633 #endif | 1633 #endif |
1634 return 0; | 1634 return 0; |
1635 } | 1635 } |
1636 if (m_fftModels[v].first->getHeight() != fftSize / 2 + 1) { | 1636 if (m_fftModels[v].first->getHeight() != fftSize / 2 + 1) { |
1637 #ifdef DEBUG_SPECTROGRAM_REPAINT | 1637 #ifdef DEBUG_SPECTROGRAM_REPAINT |
1638 std::cerr << "SpectrogramLayer::getFFTModel(" << v << "): Found a model with the wrong height (" << m_fftModels[v].first->getHeight() << ", wanted " << (fftSize / 2 + 1) << ")" << std::endl; | 1638 DEBUG << "SpectrogramLayer::getFFTModel(" << v << "): Found a model with the wrong height (" << m_fftModels[v].first->getHeight() << ", wanted " << (fftSize / 2 + 1) << ")" << endl; |
1639 #endif | 1639 #endif |
1640 delete m_fftModels[v].first; | 1640 delete m_fftModels[v].first; |
1641 m_fftModels.erase(v); | 1641 m_fftModels.erase(v); |
1642 delete m_peakCaches[v]; | 1642 delete m_peakCaches[v]; |
1643 m_peakCaches.erase(v); | 1643 m_peakCaches.erase(v); |
1644 } else { | 1644 } else { |
1645 #ifdef DEBUG_SPECTROGRAM_REPAINT | 1645 #ifdef DEBUG_SPECTROGRAM_REPAINT |
1646 std::cerr << "SpectrogramLayer::getFFTModel(" << v << "): Found a good model of height " << m_fftModels[v].first->getHeight() << std::endl; | 1646 DEBUG << "SpectrogramLayer::getFFTModel(" << v << "): Found a good model of height " << m_fftModels[v].first->getHeight() << endl; |
1647 #endif | 1647 #endif |
1648 return m_fftModels[v].first; | 1648 return m_fftModels[v].first; |
1649 } | 1649 } |
1650 } | 1650 } |
1651 | 1651 |
1762 } | 1762 } |
1763 | 1763 |
1764 int s0 = int(std::min(s00, s10) + 0.0001); | 1764 int s0 = int(std::min(s00, s10) + 0.0001); |
1765 int s1 = int(std::max(s01, s11) + 0.0001); | 1765 int s1 = int(std::max(s01, s11) + 0.0001); |
1766 | 1766 |
1767 // std::cerr << "SpectrogramLayer::updateViewMagnitudes: x0 = " << x0 << ", x1 = " << x1 << ", s00 = " << s00 << ", s11 = " << s11 << " s0 = " << s0 << ", s1 = " << s1 << std::endl; | 1767 // DEBUG << "SpectrogramLayer::updateViewMagnitudes: x0 = " << x0 << ", x1 = " << x1 << ", s00 = " << s00 << ", s11 = " << s11 << " s0 = " << s0 << ", s1 = " << s1 << endl; |
1768 | 1768 |
1769 if (int(m_columnMags.size()) <= s1) { | 1769 if (int(m_columnMags.size()) <= s1) { |
1770 m_columnMags.resize(s1 + 1); | 1770 m_columnMags.resize(s1 + 1); |
1771 } | 1771 } |
1772 | 1772 |
1775 mag.sample(m_columnMags[s]); | 1775 mag.sample(m_columnMags[s]); |
1776 } | 1776 } |
1777 } | 1777 } |
1778 | 1778 |
1779 #ifdef DEBUG_SPECTROGRAM_REPAINT | 1779 #ifdef DEBUG_SPECTROGRAM_REPAINT |
1780 std::cerr << "SpectrogramLayer::updateViewMagnitudes returning from cols " | 1780 DEBUG << "SpectrogramLayer::updateViewMagnitudes returning from cols " |
1781 << s0 << " -> " << s1 << " inclusive" << std::endl; | 1781 << s0 << " -> " << s1 << " inclusive" << endl; |
1782 #endif | 1782 #endif |
1783 | 1783 |
1784 if (!mag.isSet()) return false; | 1784 if (!mag.isSet()) return false; |
1785 if (mag == m_viewMags[v]) return false; | 1785 if (mag == m_viewMags[v]) return false; |
1786 m_viewMags[v] = mag; | 1786 m_viewMags[v] = mag; |
1800 // It's practically FORTRAN 77 in its clarity and linearity. | 1800 // It's practically FORTRAN 77 in its clarity and linearity. |
1801 | 1801 |
1802 Profiler profiler("SpectrogramLayer::paint", false); | 1802 Profiler profiler("SpectrogramLayer::paint", false); |
1803 | 1803 |
1804 #ifdef DEBUG_SPECTROGRAM_REPAINT | 1804 #ifdef DEBUG_SPECTROGRAM_REPAINT |
1805 std::cerr << "SpectrogramLayer::paint(): m_model is " << m_model << ", zoom level is " << v->getZoomLevel() << ", m_updateTimer " << m_updateTimer << std::endl; | 1805 DEBUG << "SpectrogramLayer::paint(): m_model is " << m_model << ", zoom level is " << v->getZoomLevel() << ", m_updateTimer " << m_updateTimer << endl; |
1806 | 1806 |
1807 std::cerr << "rect is " << rect.x() << "," << rect.y() << " " << rect.width() << "x" << rect.height() << std::endl; | 1807 std::cerr << "rect is " << rect.x() << "," << rect.y() << " " << rect.width() << "x" << rect.height() << std::endl; |
1808 #endif | 1808 #endif |
1809 | 1809 |
1810 long startFrame = v->getStartFrame(); | 1810 long startFrame = v->getStartFrame(); |
1814 if (!m_model || !m_model->isOK() || !m_model->isReady()) { | 1814 if (!m_model || !m_model->isOK() || !m_model->isReady()) { |
1815 return; | 1815 return; |
1816 } | 1816 } |
1817 | 1817 |
1818 if (isLayerDormant(v)) { | 1818 if (isLayerDormant(v)) { |
1819 std::cerr << "SpectrogramLayer::paint(): Layer is dormant, making it undormant again" << std::endl; | 1819 DEBUG << "SpectrogramLayer::paint(): Layer is dormant, making it undormant again" << endl; |
1820 } | 1820 } |
1821 | 1821 |
1822 // Need to do this even if !isLayerDormant, as that could mean v | 1822 // Need to do this even if !isLayerDormant, as that could mean v |
1823 // is not in the dormancy map at all -- we need it to be present | 1823 // is not in the dormancy map at all -- we need it to be present |
1824 // and accountable for when determining whether we need the cache | 1824 // and accountable for when determining whether we need the cache |
1835 } | 1835 } |
1836 */ | 1836 */ |
1837 ImageCache &cache = m_imageCaches[v]; | 1837 ImageCache &cache = m_imageCaches[v]; |
1838 | 1838 |
1839 #ifdef DEBUG_SPECTROGRAM_REPAINT | 1839 #ifdef DEBUG_SPECTROGRAM_REPAINT |
1840 std::cerr << "SpectrogramLayer::paint(): image cache valid area " << cache. | 1840 DEBUG << "SpectrogramLayer::paint(): image cache valid area " << cache. |
1841 | 1841 |
1842 validArea.x() << ", " << cache.validArea.y() << ", " << cache.validArea.width() << "x" << cache.validArea.height() << std::endl; | 1842 validArea.x() << ", " << cache.validArea.y() << ", " << cache.validArea.width() << "x" << cache.validArea.height() << endl; |
1843 #endif | 1843 #endif |
1844 | 1844 |
1845 #ifdef DEBUG_SPECTROGRAM_REPAINT | 1845 #ifdef DEBUG_SPECTROGRAM_REPAINT |
1846 bool stillCacheing = (m_updateTimer != 0); | 1846 bool stillCacheing = (m_updateTimer != 0); |
1847 std::cerr << "SpectrogramLayer::paint(): Still cacheing = " << stillCacheing << std::endl; | 1847 DEBUG << "SpectrogramLayer::paint(): Still cacheing = " << stillCacheing << endl; |
1848 #endif | 1848 #endif |
1849 | 1849 |
1850 int zoomLevel = v->getZoomLevel(); | 1850 int zoomLevel = v->getZoomLevel(); |
1851 | 1851 |
1852 int x0 = 0; | 1852 int x0 = 0; |
2200 #endif | 2200 #endif |
2201 | 2201 |
2202 bool runOutOfData = false; | 2202 bool runOutOfData = false; |
2203 | 2203 |
2204 if (w == 0) { | 2204 if (w == 0) { |
2205 std::cerr << "*** NOTE: w == 0" << std::endl; | 2205 DEBUG << "*** NOTE: w == 0" << endl; |
2206 } | 2206 } |
2207 | 2207 |
2208 #ifdef DEBUG_SPECTROGRAM_REPAINT | 2208 #ifdef DEBUG_SPECTROGRAM_REPAINT |
2209 size_t pixels = 0; | 2209 size_t pixels = 0; |
2210 #endif | 2210 #endif |
2361 | 2361 |
2362 Profiler profiler2("SpectrogramLayer::paint: draw image"); | 2362 Profiler profiler2("SpectrogramLayer::paint: draw image"); |
2363 | 2363 |
2364 if (recreateWholeImageCache) { | 2364 if (recreateWholeImageCache) { |
2365 #ifdef DEBUG_SPECTROGRAM_REPAINT | 2365 #ifdef DEBUG_SPECTROGRAM_REPAINT |
2366 std::cerr << "Recreating image cache: width = " << v->width() | 2366 DEBUG << "Recreating image cache: width = " << v->width() |
2367 << ", height = " << h << std::endl; | 2367 << ", height = " << h << endl; |
2368 #endif | 2368 #endif |
2369 cache.image = QImage(v->width(), h, QImage::Format_ARGB32_Premultiplied); | 2369 cache.image = QImage(v->width(), h, QImage::Format_ARGB32_Premultiplied); |
2370 } | 2370 } |
2371 | 2371 |
2372 if (w > 0) { | 2372 if (w > 0) { |
2373 #ifdef DEBUG_SPECTROGRAM_REPAINT | 2373 #ifdef DEBUG_SPECTROGRAM_REPAINT |
2374 std::cerr << "Painting " << w << "x" << h | 2374 DEBUG << "Painting " << w << "x" << h |
2375 << " from draw buffer at " << 0 << "," << 0 | 2375 << " from draw buffer at " << 0 << "," << 0 |
2376 << " to " << w << "x" << h << " on cache at " | 2376 << " to " << w << "x" << h << " on cache at " |
2377 << x0 << "," << 0 << std::endl; | 2377 << x0 << "," << 0 << endl; |
2378 #endif | 2378 #endif |
2379 | 2379 |
2380 QPainter cachePainter(&cache.image); | 2380 QPainter cachePainter(&cache.image); |
2381 | 2381 |
2382 if (bufferBinResolution) { | 2382 if (bufferBinResolution) { |
2383 int scaledLeft = v->getXForFrame(leftBoundaryFrame); | 2383 int scaledLeft = v->getXForFrame(leftBoundaryFrame); |
2384 int scaledRight = v->getXForFrame(rightBoundaryFrame); | 2384 int scaledRight = v->getXForFrame(rightBoundaryFrame); |
2385 #ifdef DEBUG_SPECTROGRAM_REPAINT | 2385 #ifdef DEBUG_SPECTROGRAM_REPAINT |
2386 cerr << "Rescaling image from " << bufwid | 2386 DEBUG << "Rescaling image from " << bufwid |
2387 << "x" << h << " to " | 2387 << "x" << h << " to " |
2388 << scaledRight-scaledLeft << "x" << h << endl; | 2388 << scaledRight-scaledLeft << "x" << h << endl; |
2389 #endif | 2389 #endif |
2390 Preferences::SpectrogramXSmoothing xsmoothing = | 2390 Preferences::SpectrogramXSmoothing xsmoothing = |
2391 Preferences::getInstance()->getSpectrogramXSmoothing(); | 2391 Preferences::getInstance()->getSpectrogramXSmoothing(); |
2392 // cerr << "xsmoothing == " << xsmoothing << endl; | 2392 // DEBUG << "xsmoothing == " << xsmoothing << endl; |
2393 QImage scaled = m_drawBuffer.scaled | 2393 QImage scaled = m_drawBuffer.scaled |
2394 (scaledRight - scaledLeft, h, | 2394 (scaledRight - scaledLeft, h, |
2395 Qt::IgnoreAspectRatio, | 2395 Qt::IgnoreAspectRatio, |
2396 ((xsmoothing == Preferences::SpectrogramXInterpolated) ? | 2396 ((xsmoothing == Preferences::SpectrogramXInterpolated) ? |
2397 Qt::SmoothTransformation : Qt::FastTransformation)); | 2397 Qt::SmoothTransformation : Qt::FastTransformation)); |
2398 int scaledLeftCrop = v->getXForFrame(leftCropFrame); | 2398 int scaledLeftCrop = v->getXForFrame(leftCropFrame); |
2399 int scaledRightCrop = v->getXForFrame(rightCropFrame); | 2399 int scaledRightCrop = v->getXForFrame(rightCropFrame); |
2400 #ifdef DEBUG_SPECTROGRAM_REPAINT | 2400 #ifdef DEBUG_SPECTROGRAM_REPAINT |
2401 cerr << "Drawing image region of width " << scaledRightCrop - scaledLeftCrop << " to " | 2401 DEBUG << "Drawing image region of width " << scaledRightCrop - scaledLeftCrop << " to " |
2402 << scaledLeftCrop << " from " << scaledLeftCrop - scaledLeft << endl; | 2402 << scaledLeftCrop << " from " << scaledLeftCrop - scaledLeft << endl; |
2403 #endif | 2403 #endif |
2404 cachePainter.drawImage | 2404 cachePainter.drawImage |
2405 (QRect(scaledLeftCrop, 0, | 2405 (QRect(scaledLeftCrop, 0, |
2406 scaledRightCrop - scaledLeftCrop, h), | 2406 scaledRightCrop - scaledLeftCrop, h), |
2417 } | 2417 } |
2418 | 2418 |
2419 QRect pr = rect & cache.validArea; | 2419 QRect pr = rect & cache.validArea; |
2420 | 2420 |
2421 #ifdef DEBUG_SPECTROGRAM_REPAINT | 2421 #ifdef DEBUG_SPECTROGRAM_REPAINT |
2422 std::cerr << "Painting " << pr.width() << "x" << pr.height() | 2422 DEBUG << "Painting " << pr.width() << "x" << pr.height() |
2423 << " from cache at " << pr.x() << "," << pr.y() | 2423 << " from cache at " << pr.x() << "," << pr.y() |
2424 << " to window" << std::endl; | 2424 << " to window" << endl; |
2425 #endif | 2425 #endif |
2426 | 2426 |
2427 paint.drawImage(pr.x(), pr.y(), cache.image, | 2427 paint.drawImage(pr.x(), pr.y(), cache.image, |
2428 pr.x(), pr.y(), pr.width(), pr.height()); | 2428 pr.x(), pr.y(), pr.width(), pr.height()); |
2429 //!!! | 2429 //!!! |
2437 | 2437 |
2438 if (!m_normalizeVisibleArea || !overallMagChanged) { | 2438 if (!m_normalizeVisibleArea || !overallMagChanged) { |
2439 | 2439 |
2440 if (cache.validArea.x() > 0) { | 2440 if (cache.validArea.x() > 0) { |
2441 #ifdef DEBUG_SPECTROGRAM_REPAINT | 2441 #ifdef DEBUG_SPECTROGRAM_REPAINT |
2442 std::cerr << "SpectrogramLayer::paint() updating left (0, " | 2442 DEBUG << "SpectrogramLayer::paint() updating left (0, " |
2443 << cache.validArea.x() << ")" << std::endl; | 2443 << cache.validArea.x() << ")" << endl; |
2444 #endif | 2444 #endif |
2445 v->update(0, 0, cache.validArea.x(), h); | 2445 v->update(0, 0, cache.validArea.x(), h); |
2446 } | 2446 } |
2447 | 2447 |
2448 if (cache.validArea.x() + cache.validArea.width() < | 2448 if (cache.validArea.x() + cache.validArea.width() < |
2449 cache.image.width()) { | 2449 cache.image.width()) { |
2450 #ifdef DEBUG_SPECTROGRAM_REPAINT | 2450 #ifdef DEBUG_SPECTROGRAM_REPAINT |
2451 std::cerr << "SpectrogramLayer::paint() updating right (" | 2451 DEBUG << "SpectrogramLayer::paint() updating right (" |
2452 << cache.validArea.x() + cache.validArea.width() | 2452 << cache.validArea.x() + cache.validArea.width() |
2453 << ", " | 2453 << ", " |
2454 << cache.image.width() - (cache.validArea.x() + | 2454 << cache.image.width() - (cache.validArea.x() + |
2455 cache.validArea.width()) | 2455 cache.validArea.width()) |
2456 << ")" << std::endl; | 2456 << ")" << endl; |
2457 #endif | 2457 #endif |
2458 v->update(cache.validArea.x() + cache.validArea.width(), | 2458 v->update(cache.validArea.x() + cache.validArea.width(), |
2459 0, | 2459 0, |
2460 cache.image.width() - (cache.validArea.x() + | 2460 cache.image.width() - (cache.validArea.x() + |
2461 cache.validArea.width()), | 2461 cache.validArea.width()), |
2470 } | 2470 } |
2471 | 2471 |
2472 illuminateLocalFeatures(v, paint); | 2472 illuminateLocalFeatures(v, paint); |
2473 | 2473 |
2474 #ifdef DEBUG_SPECTROGRAM_REPAINT | 2474 #ifdef DEBUG_SPECTROGRAM_REPAINT |
2475 std::cerr << "SpectrogramLayer::paint() returning" << std::endl; | 2475 DEBUG << "SpectrogramLayer::paint() returning" << endl; |
2476 #endif | 2476 #endif |
2477 | 2477 |
2478 if (!m_synchronous) { | 2478 if (!m_synchronous) { |
2479 m_lastPaintBlockWidth = paintBlockWidth; | 2479 m_lastPaintBlockWidth = paintBlockWidth; |
2480 (void)gettimeofday(&tv, 0); | 2480 (void)gettimeofday(&tv, 0); |
2705 MagnitudeRange mag; | 2705 MagnitudeRange mag; |
2706 | 2706 |
2707 if (sx != psx) { | 2707 if (sx != psx) { |
2708 if (fft) { | 2708 if (fft) { |
2709 #ifdef DEBUG_SPECTROGRAM_REPAINT | 2709 #ifdef DEBUG_SPECTROGRAM_REPAINT |
2710 cerr << "Retrieving column " << sx << " from fft directly" << endl; | 2710 DEBUG << "Retrieving column " << sx << " from fft directly" << endl; |
2711 #endif | 2711 #endif |
2712 if (m_colourScale == PhaseColourScale) { | 2712 if (m_colourScale == PhaseColourScale) { |
2713 fft->getPhasesAt(sx, autoarray, minbin, maxbin - minbin + 1); | 2713 fft->getPhasesAt(sx, autoarray, minbin, maxbin - minbin + 1); |
2714 } else if (m_normalizeColumns) { | 2714 } else if (m_normalizeColumns) { |
2715 fft->getNormalizedMagnitudesAt(sx, autoarray, minbin, maxbin - minbin + 1); | 2715 fft->getNormalizedMagnitudesAt(sx, autoarray, minbin, maxbin - minbin + 1); |
2716 } else { | 2716 } else { |
2717 fft->getMagnitudesAt(sx, autoarray, minbin, maxbin - minbin + 1); | 2717 fft->getMagnitudesAt(sx, autoarray, minbin, maxbin - minbin + 1); |
2718 } | 2718 } |
2719 } else { | 2719 } else { |
2720 #ifdef DEBUG_SPECTROGRAM_REPAINT | 2720 #ifdef DEBUG_SPECTROGRAM_REPAINT |
2721 cerr << "Retrieving column " << sx << " from peaks cache" << endl; | 2721 DEBUG << "Retrieving column " << sx << " from peaks cache" << endl; |
2722 #endif | 2722 #endif |
2723 c = sourceModel->getColumn(sx); | 2723 c = sourceModel->getColumn(sx); |
2724 if (m_normalizeColumns) { | 2724 if (m_normalizeColumns) { |
2725 for (int y = 0; y < h; ++y) { | 2725 for (int y = 0; y < h; ++y) { |
2726 if (c[y] > columnMax) columnMax = c[y]; | 2726 if (c[y] > columnMax) columnMax = c[y]; |
2898 if (m_updateTimer == 0) return 100; | 2898 if (m_updateTimer == 0) return 100; |
2899 if (m_fftModels.find(v) == m_fftModels.end()) return 100; | 2899 if (m_fftModels.find(v) == m_fftModels.end()) return 100; |
2900 | 2900 |
2901 size_t completion = m_fftModels[v].first->getCompletion(); | 2901 size_t completion = m_fftModels[v].first->getCompletion(); |
2902 #ifdef DEBUG_SPECTROGRAM_REPAINT | 2902 #ifdef DEBUG_SPECTROGRAM_REPAINT |
2903 std::cerr << "SpectrogramLayer::getCompletion: completion = " << completion << std::endl; | 2903 DEBUG << "SpectrogramLayer::getCompletion: completion = " << completion << endl; |
2904 #endif | 2904 #endif |
2905 return completion; | 2905 return completion; |
2906 } | 2906 } |
2907 | 2907 |
2908 QString | 2908 QString |
2931 SpectrogramLayer::getDisplayExtents(float &min, float &max) const | 2931 SpectrogramLayer::getDisplayExtents(float &min, float &max) const |
2932 { | 2932 { |
2933 min = getEffectiveMinFrequency(); | 2933 min = getEffectiveMinFrequency(); |
2934 max = getEffectiveMaxFrequency(); | 2934 max = getEffectiveMaxFrequency(); |
2935 | 2935 |
2936 // std::cerr << "SpectrogramLayer::getDisplayExtents: " << min << "->" << max << std::endl; | 2936 // DEBUG << "SpectrogramLayer::getDisplayExtents: " << min << "->" << max << endl; |
2937 return true; | 2937 return true; |
2938 } | 2938 } |
2939 | 2939 |
2940 bool | 2940 bool |
2941 SpectrogramLayer::setDisplayExtents(float min, float max) | 2941 SpectrogramLayer::setDisplayExtents(float min, float max) |
2942 { | 2942 { |
2943 if (!m_model) return false; | 2943 if (!m_model) return false; |
2944 | 2944 |
2945 // std::cerr << "SpectrogramLayer::setDisplayExtents: " << min << "->" << max << std::endl; | 2945 // DEBUG << "SpectrogramLayer::setDisplayExtents: " << min << "->" << max << endl; |
2946 | 2946 |
2947 if (min < 0) min = 0; | 2947 if (min < 0) min = 0; |
2948 if (max > m_model->getSampleRate()/2) max = m_model->getSampleRate()/2; | 2948 if (max > m_model->getSampleRate()/2) max = m_model->getSampleRate()/2; |
2949 | 2949 |
2950 size_t minf = lrintf(min); | 2950 size_t minf = lrintf(min); |
3549 size_t initialMax = m_initialMaxFrequency; | 3549 size_t initialMax = m_initialMaxFrequency; |
3550 if (initialMax == 0) initialMax = sr / 2; | 3550 if (initialMax == 0) initialMax = sr / 2; |
3551 | 3551 |
3552 defaultStep = mapper.getPositionForValue(initialMax) - minStep; | 3552 defaultStep = mapper.getPositionForValue(initialMax) - minStep; |
3553 | 3553 |
3554 // std::cerr << "SpectrogramLayer::getVerticalZoomSteps: " << maxStep - minStep << " (" << maxStep <<"-" << minStep << "), default is " << defaultStep << " (from initial max freq " << initialMax << ")" << std::endl; | 3554 // DEBUG << "SpectrogramLayer::getVerticalZoomSteps: " << maxStep - minStep << " (" << maxStep <<"-" << minStep << "), default is " << defaultStep << " (from initial max freq " << initialMax << ")" << endl; |
3555 | 3555 |
3556 return maxStep - minStep; | 3556 return maxStep - minStep; |
3557 } | 3557 } |
3558 | 3558 |
3559 int | 3559 int |
3564 float dmin, dmax; | 3564 float dmin, dmax; |
3565 getDisplayExtents(dmin, dmax); | 3565 getDisplayExtents(dmin, dmax); |
3566 | 3566 |
3567 SpectrogramRangeMapper mapper(m_model->getSampleRate(), m_fftSize); | 3567 SpectrogramRangeMapper mapper(m_model->getSampleRate(), m_fftSize); |
3568 int n = mapper.getPositionForValue(dmax - dmin); | 3568 int n = mapper.getPositionForValue(dmax - dmin); |
3569 // std::cerr << "SpectrogramLayer::getCurrentVerticalZoomStep: " << n << std::endl; | 3569 // DEBUG << "SpectrogramLayer::getCurrentVerticalZoomStep: " << n << endl; |
3570 return n; | 3570 return n; |
3571 } | 3571 } |
3572 | 3572 |
3573 void | 3573 void |
3574 SpectrogramLayer::setVerticalZoomStep(int step) | 3574 SpectrogramLayer::setVerticalZoomStep(int step) |
3630 } | 3630 } |
3631 if (newmax > mmax) { | 3631 if (newmax > mmax) { |
3632 newmax = mmax; | 3632 newmax = mmax; |
3633 } | 3633 } |
3634 | 3634 |
3635 // std::cerr << "SpectrogramLayer::setVerticalZoomStep: " << step << ": " << newmin << " -> " << newmax << " (range " << newdist << ")" << std::endl; | 3635 // DEBUG << "SpectrogramLayer::setVerticalZoomStep: " << step << ": " << newmin << " -> " << newmax << " (range " << newdist << ")" << endl; |
3636 | 3636 |
3637 setMinFrequency(lrintf(newmin)); | 3637 setMinFrequency(lrintf(newmin)); |
3638 setMaxFrequency(lrintf(newmax)); | 3638 setMaxFrequency(lrintf(newmax)); |
3639 } | 3639 } |
3640 | 3640 |
3652 if (r.startY > 0.0) y0 = getYForFrequency(v, r.startY); | 3652 if (r.startY > 0.0) y0 = getYForFrequency(v, r.startY); |
3653 | 3653 |
3654 int y1 = y0; | 3654 int y1 = y0; |
3655 if (r.endY > 0.0) y1 = getYForFrequency(v, r.endY); | 3655 if (r.endY > 0.0) y1 = getYForFrequency(v, r.endY); |
3656 | 3656 |
3657 // std::cerr << "SpectrogramLayer::updateMeasureRectYCoords: start " << r.startY << " -> " << y0 << ", end " << r.endY << " -> " << y1 << std::endl; | 3657 // DEBUG << "SpectrogramLayer::updateMeasureRectYCoords: start " << r.startY << " -> " << y0 << ", end " << r.endY << " -> " << y1 << endl; |
3658 | 3658 |
3659 r.pixrect = QRect(r.pixrect.x(), y0, r.pixrect.width(), y1 - y0); | 3659 r.pixrect = QRect(r.pixrect.x(), y0, r.pixrect.width(), y1 - y0); |
3660 } | 3660 } |
3661 | 3661 |
3662 void | 3662 void |
3666 r.startY = getFrequencyForY(v, y); | 3666 r.startY = getFrequencyForY(v, y); |
3667 r.endY = r.startY; | 3667 r.endY = r.startY; |
3668 } else { | 3668 } else { |
3669 r.endY = getFrequencyForY(v, y); | 3669 r.endY = getFrequencyForY(v, y); |
3670 } | 3670 } |
3671 // std::cerr << "SpectrogramLayer::setMeasureRectYCoord: start " << r.startY << " <- " << y << ", end " << r.endY << " <- " << y << std::endl; | 3671 // DEBUG << "SpectrogramLayer::setMeasureRectYCoord: start " << r.startY << " <- " << y << ", end " << r.endY << " <- " << y << endl; |
3672 | 3672 |
3673 } | 3673 } |
3674 | 3674 |
3675 void | 3675 void |
3676 SpectrogramLayer::toXml(QTextStream &stream, | 3676 SpectrogramLayer::toXml(QTextStream &stream, |
3742 float threshold = attributes.value("threshold").toFloat(&ok); | 3742 float threshold = attributes.value("threshold").toFloat(&ok); |
3743 if (ok) setThreshold(threshold); | 3743 if (ok) setThreshold(threshold); |
3744 | 3744 |
3745 size_t minFrequency = attributes.value("minFrequency").toUInt(&ok); | 3745 size_t minFrequency = attributes.value("minFrequency").toUInt(&ok); |
3746 if (ok) { | 3746 if (ok) { |
3747 std::cerr << "SpectrogramLayer::setProperties: setting min freq to " << minFrequency << std::endl; | 3747 DEBUG << "SpectrogramLayer::setProperties: setting min freq to " << minFrequency << endl; |
3748 setMinFrequency(minFrequency); | 3748 setMinFrequency(minFrequency); |
3749 } | 3749 } |
3750 | 3750 |
3751 size_t maxFrequency = attributes.value("maxFrequency").toUInt(&ok); | 3751 size_t maxFrequency = attributes.value("maxFrequency").toUInt(&ok); |
3752 if (ok) { | 3752 if (ok) { |
3753 std::cerr << "SpectrogramLayer::setProperties: setting max freq to " << maxFrequency << std::endl; | 3753 DEBUG << "SpectrogramLayer::setProperties: setting max freq to " << maxFrequency << endl; |
3754 setMaxFrequency(maxFrequency); | 3754 setMaxFrequency(maxFrequency); |
3755 } | 3755 } |
3756 | 3756 |
3757 ColourScale colourScale = (ColourScale) | 3757 ColourScale colourScale = (ColourScale) |
3758 attributes.value("colourScale").toInt(&ok); | 3758 attributes.value("colourScale").toInt(&ok); |