Mercurial > hg > svgui
diff layer/SpectrogramLayer.cpp @ 1027:dade9bfc7695 spectrogram-minor-refactor
Fix return value from paintDrawBuffer in rightToLeft case; propagate timing change to PeakFrequencies version as well
author | Chris Cannam |
---|---|
date | Tue, 26 Jan 2016 14:44:26 +0000 |
parents | 53110ace211f |
children | 78ece8cdfaee |
line wrap: on
line diff
--- a/layer/SpectrogramLayer.cpp Tue Jan 26 13:19:53 2016 +0000 +++ b/layer/SpectrogramLayer.cpp Tue Jan 26 14:44:26 2016 +0000 @@ -2292,6 +2292,10 @@ float *values = (float *)alloca((maxbin - minbin + 1) * sizeof(float)); #endif + int minColumns = 4; + double maxTime = 0.15; // seconds; only for non-synchronous drawing + auto startTime = chrono::steady_clock::now(); + int start = 0; int finish = w; int step = 1; @@ -2302,8 +2306,12 @@ step = -1; } + int columnCount = 0; + for (int x = start; x != finish; x += step) { + ++columnCount; + if (binforx[x] < 0) continue; int sx0 = binforx[x]; @@ -2382,9 +2390,23 @@ } } } + + if (!m_synchronous) { + if (columnCount >= minColumns) { + auto t = chrono::steady_clock::now(); + double diff = chrono::duration<double>(t - startTime).count(); + if (diff > maxTime) { +#ifdef DEBUG_SPECTROGRAM_REPAINT + cerr << "SpectrogramLayer::paintDrawBufferPeakFrequencies: Max time " << maxTime << " sec exceeded after " + << x << " columns with time " << diff << endl; +#endif + return columnCount; + } + } + } } - return w; + return columnCount; } int @@ -2400,13 +2422,6 @@ { Profiler profiler("SpectrogramLayer::paintDrawBuffer"); - //!!! todo: propagate to paintDrawBufferPeakFrequencies - - int minColumns = 4; - double maxTime = 0.1; // seconds; only for non-synchronous drawing - - auto startTime = chrono::steady_clock::now(); - int minbin = int(binfory[0] + 0.0001); int maxbin = int(binfory[h-1]); @@ -2457,6 +2472,10 @@ const float *values = autoarray; DenseThreeDimensionalModel::Column c; + int minColumns = 4; + double maxTime = 0.1; // seconds; only for non-synchronous drawing + auto startTime = chrono::steady_clock::now(); + int start = 0; int finish = w; int step = 1; @@ -2466,8 +2485,12 @@ finish = -1; step = -1; } + + int columnCount = 0; for (int x = start; x != finish; x += step) { + + ++columnCount; if (binforx[x] < 0) continue; @@ -2638,7 +2661,7 @@ } if (!m_synchronous) { - if (x >= minColumns) { + if (columnCount >= minColumns) { auto t = chrono::steady_clock::now(); double diff = chrono::duration<double>(t - startTime).count(); if (diff > maxTime) { @@ -2646,13 +2669,13 @@ cerr << "SpectrogramLayer::paintDrawBuffer: Max time " << maxTime << " sec exceeded after " << x << " columns with time " << diff << endl; #endif - return x; + return columnCount; } } } } - return w; + return columnCount; } void