comparison layer/WaveformLayer.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
286 } 286 }
287 287
288 void 288 void
289 WaveformLayer::setChannel(int channel) 289 WaveformLayer::setChannel(int channel)
290 { 290 {
291 // std::cerr << "WaveformLayer::setChannel(" << channel << ")" << std::endl; 291 // DEBUG << "WaveformLayer::setChannel(" << channel << ")" << endl;
292 292
293 if (m_channel == channel) return; 293 if (m_channel == channel) return;
294 m_channel = channel; 294 m_channel = channel;
295 m_cacheValid = false; 295 m_cacheValid = false;
296 emit layerParametersChanged(); 296 emit layerParametersChanged();
380 } 380 }
381 381
382 merging = (m_channelMode == MergeChannels && rawChannels > 1); 382 merging = (m_channelMode == MergeChannels && rawChannels > 1);
383 mixing = (m_channelMode == MixChannels && rawChannels > 1); 383 mixing = (m_channelMode == MixChannels && rawChannels > 1);
384 384
385 // std::cerr << "WaveformLayer::getChannelArrangement: min " << min << ", max " << max << ", merging " << merging << ", channels " << channels << std::endl; 385 // DEBUG << "WaveformLayer::getChannelArrangement: min " << min << ", max " << max << ", merging " << merging << ", channels " << channels << endl;
386 386
387 return channels; 387 return channels;
388 } 388 }
389 389
390 bool 390 bool
472 472
473 int zoomLevel = v->getZoomLevel(); 473 int zoomLevel = v->getZoomLevel();
474 474
475 #ifdef DEBUG_WAVEFORM_PAINT 475 #ifdef DEBUG_WAVEFORM_PAINT
476 Profiler profiler("WaveformLayer::paint", true); 476 Profiler profiler("WaveformLayer::paint", true);
477 std::cerr << "WaveformLayer::paint (" << rect.x() << "," << rect.y() 477 DEBUG << "WaveformLayer::paint (" << rect.x() << "," << rect.y()
478 << ") [" << rect.width() << "x" << rect.height() << "]: zoom " << zoomLevel << ", start " << startFrame << std::endl; 478 << ") [" << rect.width() << "x" << rect.height() << "]: zoom " << zoomLevel << ", start " << startFrame << endl;
479 #endif 479 #endif
480 480
481 size_t channels = 0, minChannel = 0, maxChannel = 0; 481 size_t channels = 0, minChannel = 0, maxChannel = 0;
482 bool mergingChannels = false, mixingChannels = false; 482 bool mergingChannels = false, mixingChannels = false;
483 483
492 QPainter *paint; 492 QPainter *paint;
493 493
494 if (m_aggressive) { 494 if (m_aggressive) {
495 495
496 #ifdef DEBUG_WAVEFORM_PAINT 496 #ifdef DEBUG_WAVEFORM_PAINT
497 std::cerr << "WaveformLayer::paint: aggressive is true" << std::endl; 497 DEBUG << "WaveformLayer::paint: aggressive is true" << endl;
498 #endif 498 #endif
499 499
500 if (m_cacheValid && (zoomLevel != m_cacheZoomLevel)) { 500 if (m_cacheValid && (zoomLevel != m_cacheZoomLevel)) {
501 m_cacheValid = false; 501 m_cacheValid = false;
502 } 502 }
503 503
504 if (!m_cache || m_cache->width() != w || m_cache->height() != h) { 504 if (!m_cache || m_cache->width() != w || m_cache->height() != h) {
505 #ifdef DEBUG_WAVEFORM_PAINT 505 #ifdef DEBUG_WAVEFORM_PAINT
506 if (m_cache) { 506 if (m_cache) {
507 std::cerr << "WaveformLayer::paint: cache size " << m_cache->width() << "x" << m_cache->height() << " differs from view size " << w << "x" << h << ": regenerating aggressive cache" << std::endl; 507 DEBUG << "WaveformLayer::paint: cache size " << m_cache->width() << "x" << m_cache->height() << " differs from view size " << w << "x" << h << ": regenerating aggressive cache" << endl;
508 } 508 }
509 #endif 509 #endif
510 delete m_cache; 510 delete m_cache;
511 m_cache = new QPixmap(w, h); 511 m_cache = new QPixmap(w, h);
512 m_cacheValid = false; 512 m_cacheValid = false;
560 560
561 getSourceFramesForX(v, x0, modelZoomLevel, frame0, spare); 561 getSourceFramesForX(v, x0, modelZoomLevel, frame0, spare);
562 getSourceFramesForX(v, x1, modelZoomLevel, spare, frame1); 562 getSourceFramesForX(v, x1, modelZoomLevel, spare, frame1);
563 563
564 #ifdef DEBUG_WAVEFORM_PAINT 564 #ifdef DEBUG_WAVEFORM_PAINT
565 std::cerr << "Painting waveform from " << frame0 << " to " << frame1 << " (" << (x1-x0+1) << " pixels at zoom " << zoomLevel << " and model zoom " << modelZoomLevel << ")" << std::endl; 565 DEBUG << "Painting waveform from " << frame0 << " to " << frame1 << " (" << (x1-x0+1) << " pixels at zoom " << zoomLevel << " and model zoom " << modelZoomLevel << ")" << endl;
566 #endif 566 #endif
567 567
568 RangeSummarisableTimeValueModel::RangeBlock *ranges = 568 RangeSummarisableTimeValueModel::RangeBlock *ranges =
569 new RangeSummarisableTimeValueModel::RangeBlock; 569 new RangeSummarisableTimeValueModel::RangeBlock;
570 570
701 701
702 size_t i0 = (f0 - frame0) / modelZoomLevel; 702 size_t i0 = (f0 - frame0) / modelZoomLevel;
703 size_t i1 = (f1 - frame0) / modelZoomLevel; 703 size_t i1 = (f1 - frame0) / modelZoomLevel;
704 704
705 #ifdef DEBUG_WAVEFORM_PAINT 705 #ifdef DEBUG_WAVEFORM_PAINT
706 std::cerr << "WaveformLayer::paint: pixel " << x << ": i0 " << i0 << " (f " << f0 << "), i1 " << i1 << " (f " << f1 << ")" << std::endl; 706 DEBUG << "WaveformLayer::paint: pixel " << x << ": i0 " << i0 << " (f " << f0 << "), i1 " << i1 << " (f " << f1 << ")" << endl;
707 #endif 707 #endif
708 708
709 if (i1 > i0 + 1) { 709 if (i1 > i0 + 1) {
710 std::cerr << "WaveformLayer::paint: ERROR: i1 " << i1 << " > i0 " << i0 << " plus one (zoom = " << zoomLevel << ", model zoom = " << modelZoomLevel << ")" << std::endl; 710 DEBUG << "WaveformLayer::paint: ERROR: i1 " << i1 << " > i0 " << i0 << " plus one (zoom = " << zoomLevel << ", model zoom = " << modelZoomLevel << ")" << endl;
711 } 711 }
712 712
713 if (ranges && i0 < ranges->size()) { 713 if (ranges && i0 < ranges->size()) {
714 714
715 range = (*ranges)[i0]; 715 range = (*ranges)[i0];