# HG changeset patch # User Chris Cannam # Date 1233840687 0 # Node ID 6a5327c0a40f3bdd97be82c8f8b01b0e575e2011 # Parent c860cab859041e3d0f6348aeb66abaeabf40a483 * Re-enable column normalization diff -r c860cab85904 -r 6a5327c0a40f layer/SpectrogramLayer.cpp --- a/layer/SpectrogramLayer.cpp Thu Feb 05 12:05:28 2009 +0000 +++ b/layer/SpectrogramLayer.cpp Thu Feb 05 13:31:27 2009 +0000 @@ -2281,13 +2281,14 @@ if (getXBinRange(v, x + x0, s0, s1)) { binforx[x] = int(s0 + 0.0001); } else { - binforx[x] = 0; //??? + binforx[x] = -1; //??? } } if (m_drawBuffer.width() < bufwid || m_drawBuffer.height() < h) { m_drawBuffer = QImage(bufwid, h, QImage::Format_Indexed8); } usePeaksCache = (increment * 8) < zoomLevel; + if (m_colourScale == PhaseColourScale) usePeaksCache = false; } m_drawBuffer.setNumColors(256); @@ -2511,6 +2512,9 @@ if (binforx[x] < 0) continue; + float columnGain = m_gain; + float columnMax = 0.f; + int sx0 = binforx[x] / divisor; int sx1 = sx0; if (x+1 < w) sx1 = binforx[x+1] / divisor; @@ -2538,12 +2542,23 @@ #ifdef DEBUG_SPECTROGRAM_REPAINT cerr << "Retrieving column " << sx << " from fft directly" << endl; #endif - fft->getMagnitudesAt(sx, values, minbin, maxbin - minbin + 1); + if (m_colourScale == PhaseColourScale) { + fft->getPhasesAt(sx, values, minbin, maxbin - minbin + 1); + } else if (m_normalizeColumns) { + fft->getNormalizedMagnitudesAt(sx, values, minbin, maxbin - minbin + 1); + } else { + fft->getMagnitudesAt(sx, values, minbin, maxbin - minbin + 1); + } } else { #ifdef DEBUG_SPECTROGRAM_REPAINT cerr << "Retrieving column " << sx << " from peaks cache" << endl; #endif c = sourceModel->getColumn(sx); + if (m_normalizeColumns) { + for (int y = 0; y < h; ++y) { + if (c[y] > columnMax) columnMax = c[y]; + } + } } psx = sx; } @@ -2587,6 +2602,10 @@ } } + if (m_normalizeColumns && columnMax > 0.f) { + columnGain /= columnMax; + } + for (int y = 0; y < h; ++y) { float peak = peaks[y]; @@ -2596,7 +2615,7 @@ peak /= (m_fftSize/2.f); } //!!! mag.sample(value); - peak *= m_gain; + peak *= columnGain; } unsigned char peakpix = getDisplayValue(v, peak);