comparison layer/Colour3DPlotLayer.cpp @ 706:97ea68f62c1f imaf_enc

Merge from default branch
author Chris Cannam
date Thu, 05 Dec 2013 09:47:02 +0000
parents 1a0dfcbffaf1
children 67e6d518ac27
comparison
equal deleted inserted replaced
678:26c5f7fd4807 706:97ea68f62c1f
687 687
688 if (m_invertVertical) sy = m_model->getHeight() - sy - 1; 688 if (m_invertVertical) sy = m_model->getHeight() - sy - 1;
689 689
690 float value = m_model->getValueAt(sx0, sy); 690 float value = m_model->getValueAt(sx0, sy);
691 691
692 // std::cerr << "bin value (" << sx0 << "," << sy << ") is " << value << std::endl; 692 // cerr << "bin value (" << sx0 << "," << sy << ") is " << value << endl;
693 693
694 QString binName = m_model->getBinName(sy); 694 QString binName = m_model->getBinName(sy);
695 if (binName == "") binName = QString("[%1]").arg(sy + 1); 695 if (binName == "") binName = QString("[%1]").arg(sy + 1);
696 else binName = QString("%1 [%2]").arg(binName).arg(sy + 1); 696 else binName = QString("%1 [%2]").arg(binName).arg(sy + 1);
697 697
784 if (pixel >= 0 && pixel < 256) { 784 if (pixel >= 0 && pixel < 256) {
785 QRgb c = m_cache->color(pixel); 785 QRgb c = m_cache->color(pixel);
786 paint.setPen(QColor(qRed(c), qGreen(c), qBlue(c))); 786 paint.setPen(QColor(qRed(c), qGreen(c), qBlue(c)));
787 paint.drawLine(5, 11 + y, cw - 5, 11 + y); 787 paint.drawLine(5, 11 + y, cw - 5, 11 + y);
788 } else { 788 } else {
789 std::cerr << "WARNING: Colour3DPlotLayer::paintVerticalScale: value " << value << ", mmin " << mmin << ", mmax " << mmax << " leads to invalid pixel " << pixel << std::endl; 789 cerr << "WARNING: Colour3DPlotLayer::paintVerticalScale: value " << value << ", mmin " << mmin << ", mmax " << mmax << " leads to invalid pixel " << pixel << endl;
790 } 790 }
791 } 791 }
792 792
793 QString minstr = QString("%1").arg(min); 793 QString minstr = QString("%1").arg(min);
794 QString maxstr = QString("%1").arg(max); 794 QString maxstr = QString("%1").arg(max);
968 m_cacheValidEnd = 0; 968 m_cacheValidEnd = 0;
969 } 969 }
970 970
971 if (m_cacheValidStart <= firstBin && m_cacheValidEnd >= lastBin) { 971 if (m_cacheValidStart <= firstBin && m_cacheValidEnd >= lastBin) {
972 #ifdef DEBUG_COLOUR_3D_PLOT_LAYER_PAINT 972 #ifdef DEBUG_COLOUR_3D_PLOT_LAYER_PAINT
973 std::cerr << "Cache is valid in this region already" << std::endl; 973 cerr << "Cache is valid in this region already" << endl;
974 #endif 974 #endif
975 return; 975 return;
976 } 976 }
977 977
978 size_t fillStart = firstBin; 978 size_t fillStart = firstBin;
1004 m_cacheValidStart = fillStart; 1004 m_cacheValidStart = fillStart;
1005 m_cacheValidEnd = fillEnd; 1005 m_cacheValidEnd = fillEnd;
1006 } 1006 }
1007 1007
1008 #ifdef DEBUG_COLOUR_3D_PLOT_LAYER_PAINT 1008 #ifdef DEBUG_COLOUR_3D_PLOT_LAYER_PAINT
1009 std::cerr << "Cache size " << cacheWidth << "x" << cacheHeight << " will be valid from " << m_cacheValidStart << " to " << m_cacheValidEnd << std::endl; 1009 cerr << "Cache size " << cacheWidth << "x" << cacheHeight << " will be valid from " << m_cacheValidStart << " to " << m_cacheValidEnd << endl;
1010 #endif 1010 #endif
1011 1011
1012 DenseThreeDimensionalModel::Column values; 1012 DenseThreeDimensionalModel::Column values;
1013 1013
1014 float min = m_model->getMinimumLevel(); 1014 float min = m_model->getMinimumLevel();
1227 return; 1227 return;
1228 } 1228 }
1229 1229
1230 #ifdef DEBUG_COLOUR_3D_PLOT_LAYER_PAINT 1230 #ifdef DEBUG_COLOUR_3D_PLOT_LAYER_PAINT
1231 SVDEBUG << "Colour3DPlotLayer::paint: w " << x1-x0 << ", h " << h << ", sx0 " << sx0 << ", sx1 " << sx1 << ", sw " << sx1-sx0 << ", sh " << sh << endl; 1231 SVDEBUG << "Colour3DPlotLayer::paint: w " << x1-x0 << ", h " << h << ", sx0 " << sx0 << ", sx1 " << sx1 << ", sw " << sx1-sx0 << ", sh " << sh << endl;
1232 std::cerr << "Colour3DPlotLayer: sample rate is " << m_model->getSampleRate() << ", resolution " << m_model->getResolution() << std::endl; 1232 cerr << "Colour3DPlotLayer: sample rate is " << m_model->getSampleRate() << ", resolution " << m_model->getResolution() << endl;
1233 #endif 1233 #endif
1234 1234
1235 QPoint illuminatePos; 1235 QPoint illuminatePos;
1236 bool illuminate = v->shouldIlluminateLocalFeatures(this, illuminatePos); 1236 bool illuminate = v->shouldIlluminateLocalFeatures(this, illuminatePos);
1237 char labelbuf[10]; 1237 char labelbuf[10];
1287 paint.setPen(v->getForeground()); 1287 paint.setPen(v->getForeground());
1288 } 1288 }
1289 } 1289 }
1290 1290
1291 #ifdef DEBUG_COLOUR_3D_PLOT_LAYER_PAINT 1291 #ifdef DEBUG_COLOUR_3D_PLOT_LAYER_PAINT
1292 // std::cerr << "rect " << r.x() << "," << r.y() << " " 1292 // cerr << "rect " << r.x() << "," << r.y() << " "
1293 // << r.width() << "x" << r.height() << std::endl; 1293 // << r.width() << "x" << r.height() << endl;
1294 #endif 1294 #endif
1295 1295
1296 paint.drawRect(r); 1296 paint.drawRect(r);
1297 1297
1298 if (showLabel) { 1298 if (showLabel) {
1348 1348
1349 int zoomLevel = v->getZoomLevel(); 1349 int zoomLevel = v->getZoomLevel();
1350 1350
1351 QImage *source = m_cache; 1351 QImage *source = m_cache;
1352 1352
1353 std::cerr << "modelResolution " << modelResolution << ", srRatio " 1353 SVDEBUG << "modelResolution " << modelResolution << ", srRatio "
1354 << srRatio << ", m_peakResolution " << m_peakResolution 1354 << srRatio << ", m_peakResolution " << m_peakResolution
1355 << ", zoomLevel " << zoomLevel << ", result " 1355 << ", zoomLevel " << zoomLevel << ", result "
1356 << ((modelResolution * srRatio * m_peakResolution) / zoomLevel) 1356 << ((modelResolution * srRatio * m_peakResolution) / zoomLevel)
1357 << std::endl; 1357 << endl;
1358 1358
1359 if (m_peaksCache) { 1359 if (m_peaksCache) {
1360 if (((modelResolution * srRatio * m_peakResolution) / zoomLevel) < 1) { 1360 if (((modelResolution * srRatio * m_peakResolution) / zoomLevel) < 1) {
1361 SVDEBUG << "using peaks cache" << endl; 1361 SVDEBUG << "using peaks cache" << endl;
1362 source = m_peaksCache; 1362 source = m_peaksCache;
1363 modelResolution *= m_peakResolution; 1363 modelResolution *= m_peakResolution;
1364 } else { 1364 } else {
1365 std::cerr << "not using peaks cache" << std::endl; 1365 SVDEBUG << "not using peaks cache" << endl;
1366 } 1366 }
1367 } else { 1367 } else {
1368 std::cerr << "have no peaks cache" << std::endl; 1368 SVDEBUG << "have no peaks cache" << endl;
1369 } 1369 }
1370 1370
1371 int psy1i = -1; 1371 int psy1i = -1;
1372 int sw = source->width(); 1372 int sw = source->width();
1373 1373