Mercurial > hg > svgui
diff layer/Colour3DPlotLayer.cpp @ 1057:218be6cf2d4f spectrogram-minor-refactor
Merge from default branch
author | Chris Cannam |
---|---|
date | Mon, 13 Jun 2016 12:46:36 +0100 |
parents | 38a53c7b81f6 |
children | 5144d7185fb5 |
line wrap: on
line diff
--- a/layer/Colour3DPlotLayer.cpp Wed Feb 03 16:51:37 2016 +0000 +++ b/layer/Colour3DPlotLayer.cpp Mon Jun 13 12:46:36 2016 +0100 @@ -849,8 +849,12 @@ paint.save(); QFont font = paint.font(); - font.setPixelSize(int(font.pixelSize() * 0.65)); - paint.setFont(font); + if (font.pixelSize() > 0) { + int newSize = int(font.pixelSize() * 0.65); + if (newSize < 6) newSize = 6; + font.setPixelSize(newSize); + paint.setFont(font); + } int msw = paint.fontMetrics().width(maxstr); @@ -975,25 +979,27 @@ } void -Colour3DPlotLayer::fillCache(int firstBin, int lastBin) const +Colour3DPlotLayer::fillCache(int firstColumn, int lastColumn) const { + // This call requests a (perhaps partial) fill of the cache + // between model columns firstColumn and lastColumn inclusive. + // The cache itself always has size sufficient to contain the + // whole model, but its validity may be less, depending on which + // regions have been requested via calls to this function. Note + // that firstColumn and lastColumn are *model* column numbers. If + // the model starts at a frame > 0, a firstColumn of zero still + // corresponds to the first column in the model, not the first + // column on the resulting rendered layer. + Profiler profiler("Colour3DPlotLayer::fillCache", true); - sv_frame_t modelStart = m_model->getStartFrame(); - sv_frame_t modelEnd = m_model->getEndFrame(); - int modelResolution = m_model->getResolution(); - - int modelStartBin = int(modelStart / modelResolution); - int modelEndBin = int(modelEnd / modelResolution); + int cacheWidth = m_model->getWidth(); + int cacheHeight = m_model->getHeight(); #ifdef DEBUG_COLOUR_3D_PLOT_LAYER_PAINT - cerr << "Colour3DPlotLayer::fillCache: range " << firstBin << " -> " << lastBin << " of model range " << modelStartBin << " -> " << modelEndBin << " (model resolution " << modelResolution << ")" << endl; + cerr << "Colour3DPlotLayer::fillCache: range " << firstColumn << " -> " << lastColumn << " (cache size will be " << cacheWidth << " x " << cacheHeight << ")" << endl; #endif - int cacheWidth = modelEndBin - modelStartBin + 1; - if (lastBin > modelEndBin) cacheWidth = lastBin - modelStartBin + 1; - int cacheHeight = m_model->getHeight(); - if (m_cache && m_cache->height() != cacheHeight) { // height has changed: delete everything rather than resizing #ifdef DEBUG_COLOUR_3D_PLOT_LAYER_PAINT @@ -1027,8 +1033,7 @@ #ifdef DEBUG_COLOUR_3D_PLOT_LAYER_PAINT cerr << "Colour3DPlotLayer::fillCache: Have no cache, making one" << endl; #endif - m_cache = new QImage - (cacheWidth, cacheHeight, QImage::Format_Indexed8); + m_cache = new QImage(cacheWidth, cacheHeight, QImage::Format_Indexed8); m_cache->setColorCount(256); m_cache->fill(0); if (!m_normalizeVisibleArea) { @@ -1050,20 +1055,21 @@ << " peaks cache size = " << m_peaksCache->width() << "x" << m_peaksCache->height() << endl; #endif - if (m_cacheValidStart <= firstBin && m_cacheValidEnd >= lastBin) { + if (m_cacheValidStart <= firstColumn && m_cacheValidEnd >= lastColumn) { #ifdef DEBUG_COLOUR_3D_PLOT_LAYER_PAINT cerr << "Cache is valid in this region already" << endl; #endif return; } - int fillStart = firstBin; - int fillEnd = lastBin; + int fillStart = firstColumn; + int fillEnd = lastColumn; - if (fillStart < modelStartBin) fillStart = modelStartBin; - if (fillStart > modelEndBin) fillStart = modelEndBin; - if (fillEnd < modelStartBin) fillEnd = modelStartBin; - if (fillEnd > modelEndBin) fillEnd = modelEndBin; + if (fillStart >= cacheWidth) fillStart = cacheWidth-1; + if (fillStart < 0) fillStart = 0; + if (fillEnd >= cacheWidth) fillEnd = cacheWidth-1; + if (fillEnd < 0) fillEnd = 0; + if (fillEnd < fillStart) fillEnd = fillStart; bool normalizeVisible = (m_normalizeVisibleArea && !m_normalizeColumns); @@ -1293,6 +1299,14 @@ return; } + if (m_model->getWidth() == 0) { +#ifdef DEBUG_COLOUR_3D_PLOT_LAYER_PAINT + cerr << "Colour3DPlotLayer::paint(): model width == 0, " + << "nothing to paint (yet)" << endl; +#endif + return; + } + if (m_normalizeVisibleArea && !m_normalizeColumns) rect = v->getPaintRect(); sv_frame_t modelStart = m_model->getStartFrame(); @@ -1316,6 +1330,7 @@ double srRatio = v->getViewManager()->getMainModelSampleRate() / m_model->getSampleRate(); + // the s-prefix values are source, i.e. model, column and bin numbers int sx0 = int((double(v->getFrameForX(x0)) / srRatio - double(modelStart)) / modelResolution); int sx1 = int((double(v->getFrameForX(x1)) / srRatio - double(modelStart)) @@ -1360,12 +1375,12 @@ for (int sx = sx0; sx <= sx1; ++sx) { - sv_frame_t fx = sx * modelResolution; + sv_frame_t fx = sx * modelResolution + modelStart; if (fx + modelResolution <= modelStart || fx > modelEnd) continue; - int rx0 = v->getXForFrame(int(double(fx + modelStart) * srRatio)); - int rx1 = v->getXForFrame(int(double(fx + modelStart + modelResolution + 1) * srRatio)); + int rx0 = v->getXForFrame(int(double(fx) * srRatio)); + int rx1 = v->getXForFrame(int(double(fx + modelResolution + 1) * srRatio)); int rw = rx1 - rx0; if (rw < 1) rw = 1; @@ -1422,10 +1437,12 @@ double value = m_model->getValueAt(sx, sy); snprintf(labelbuf, buflen, "%06f", value); QString text(labelbuf); - paint.setPen(v->getBackground()); - paint.drawText(rx0 + 2, - ry0 - h / sh - 1 + 2 + paint.fontMetrics().ascent(), - text); + v->drawVisibleText + (paint, + rx0 + 2, + ry0 - h / sh - 1 + 2 + paint.fontMetrics().ascent(), + text, + View::OutlinedText); } } }