comparison view/View.cpp @ 684:917039d333bb tonioni

Merge from default branch
author Chris Cannam
date Tue, 26 Nov 2013 14:38:48 +0000
parents 1a0dfcbffaf1
children 596414d20ef0
comparison
equal deleted inserted replaced
680:ced5f158eda7 684:917039d333bb
41 41
42 #include <unistd.h> 42 #include <unistd.h>
43 43
44 //#define DEBUG_VIEW_WIDGET_PAINT 1 44 //#define DEBUG_VIEW_WIDGET_PAINT 1
45 45
46 using std::cerr; 46
47 using std::endl; 47
48 48
49 View::View(QWidget *w, bool showProgress) : 49 View::View(QWidget *w, bool showProgress) :
50 QFrame(w), 50 QFrame(w),
51 m_centreFrame(0), 51 m_centreFrame(0),
52 m_zoomLevel(1024), 52 m_zoomLevel(1024),
323 int newPixel = m_centreFrame / m_zoomLevel; 323 int newPixel = m_centreFrame / m_zoomLevel;
324 324
325 if (newPixel != formerPixel) { 325 if (newPixel != formerPixel) {
326 326
327 #ifdef DEBUG_VIEW_WIDGET_PAINT 327 #ifdef DEBUG_VIEW_WIDGET_PAINT
328 std::cout << "View(" << this << ")::setCentreFrame: newPixel " << newPixel << ", formerPixel " << formerPixel << std::endl; 328 cout << "View(" << this << ")::setCentreFrame: newPixel " << newPixel << ", formerPixel " << formerPixel << endl;
329 #endif 329 #endif
330 update(); 330 update();
331 331
332 changeVisible = true; 332 changeVisible = true;
333 } 333 }
334 334
335 if (e) { 335 if (e) {
336 size_t rf = alignToReference(f); 336 size_t rf = alignToReference(f);
337 #ifdef DEBUG_VIEW_WIDGET_PAINT 337 #ifdef DEBUG_VIEW_WIDGET_PAINT
338 std::cerr << "View[" << this << "]::setCentreFrame(" << f 338 cerr << "View[" << this << "]::setCentreFrame(" << f
339 << "): emitting centreFrameChanged(" 339 << "): emitting centreFrameChanged("
340 << rf << ")" << std::endl; 340 << rf << ")" << endl;
341 #endif 341 #endif
342 emit centreFrameChanged(rf, m_followPan, m_followPlay); 342 emit centreFrameChanged(rf, m_followPan, m_followPlay);
343 } 343 }
344 } 344 }
345 345
434 434
435 int 435 int
436 View::getZoomLevel() const 436 View::getZoomLevel() const
437 { 437 {
438 #ifdef DEBUG_VIEW_WIDGET_PAINT 438 #ifdef DEBUG_VIEW_WIDGET_PAINT
439 // std::cout << "zoom level: " << m_zoomLevel << std::endl; 439 // cout << "zoom level: " << m_zoomLevel << endl;
440 #endif 440 #endif
441 return m_zoomLevel; 441 return m_zoomLevel;
442 } 442 }
443 443
444 void 444 void
751 paint.setPen(Qt::NoPen); 751 paint.setPen(Qt::NoPen);
752 paint.setBrush(boxColour); 752 paint.setBrush(boxColour);
753 753
754 QRect r = paint.fontMetrics().boundingRect(text); 754 QRect r = paint.fontMetrics().boundingRect(text);
755 r.translate(QPoint(x, y)); 755 r.translate(QPoint(x, y));
756 // std::cerr << "drawVisibleText: r = " << r.x() << "," <<r.y() << " " << r.width() << "x" << r.height() << std::endl; 756 // cerr << "drawVisibleText: r = " << r.x() << "," <<r.y() << " " << r.width() << "x" << r.height() << endl;
757 paint.drawRect(r); 757 paint.drawRect(r);
758 paint.setBrush(Qt::NoBrush); 758 paint.setBrush(Qt::NoBrush);
759 759
760 paint.setPen(surroundColour); 760 paint.setPen(surroundColour);
761 761
772 772
773 paint.restore(); 773 paint.restore();
774 774
775 } else { 775 } else {
776 776
777 std::cerr << "ERROR: View::drawVisibleText: Boxed style not yet implemented!" << std::endl; 777 cerr << "ERROR: View::drawVisibleText: Boxed style not yet implemented!" << endl;
778 } 778 }
779 } 779 }
780 780
781 void 781 void
782 View::setPlaybackFollow(PlaybackFollowMode m) 782 View::setPlaybackFollow(PlaybackFollowMode m)
789 View::modelChanged() 789 View::modelChanged()
790 { 790 {
791 QObject *obj = sender(); 791 QObject *obj = sender();
792 792
793 #ifdef DEBUG_VIEW_WIDGET_PAINT 793 #ifdef DEBUG_VIEW_WIDGET_PAINT
794 std::cerr << "View(" << this << ")::modelChanged()" << std::endl; 794 cerr << "View(" << this << ")::modelChanged()" << endl;
795 #endif 795 #endif
796 796
797 // If the model that has changed is not used by any of the cached 797 // If the model that has changed is not used by any of the cached
798 // layers, we won't need to recreate the cache 798 // layers, we won't need to recreate the cache
799 799
828 828
829 long myStartFrame = getStartFrame(); 829 long myStartFrame = getStartFrame();
830 size_t myEndFrame = getEndFrame(); 830 size_t myEndFrame = getEndFrame();
831 831
832 #ifdef DEBUG_VIEW_WIDGET_PAINT 832 #ifdef DEBUG_VIEW_WIDGET_PAINT
833 std::cerr << "View(" << this << ")::modelChanged(" << startFrame << "," << endFrame << ") [me " << myStartFrame << "," << myEndFrame << "]" << std::endl; 833 cerr << "View(" << this << ")::modelChanged(" << startFrame << "," << endFrame << ") [me " << myStartFrame << "," << myEndFrame << "]" << endl;
834 #endif 834 #endif
835 835
836 if (myStartFrame > 0 && endFrame < size_t(myStartFrame)) { 836 if (myStartFrame > 0 && endFrame < size_t(myStartFrame)) {
837 checkProgress(obj); 837 checkProgress(obj);
838 return; 838 return;
871 } 871 }
872 872
873 void 873 void
874 View::modelCompletionChanged() 874 View::modelCompletionChanged()
875 { 875 {
876 // std::cerr << "View(" << this << ")::modelCompletionChanged()" << std::endl; 876 // cerr << "View(" << this << ")::modelCompletionChanged()" << endl;
877 877
878 QObject *obj = sender(); 878 QObject *obj = sender();
879 checkProgress(obj); 879 checkProgress(obj);
880 } 880 }
881 881
882 void 882 void
883 View::modelAlignmentCompletionChanged() 883 View::modelAlignmentCompletionChanged()
884 { 884 {
885 // std::cerr << "View(" << this << ")::modelAlignmentCompletionChanged()" << std::endl; 885 // cerr << "View(" << this << ")::modelAlignmentCompletionChanged()" << endl;
886 886
887 QObject *obj = sender(); 887 QObject *obj = sender();
888 checkProgress(obj); 888 checkProgress(obj);
889 } 889 }
890 890
891 void 891 void
892 View::modelReplaced() 892 View::modelReplaced()
893 { 893 {
894 #ifdef DEBUG_VIEW_WIDGET_PAINT 894 #ifdef DEBUG_VIEW_WIDGET_PAINT
895 std::cerr << "View(" << this << ")::modelReplaced()" << std::endl; 895 cerr << "View(" << this << ")::modelReplaced()" << endl;
896 #endif 896 #endif
897 delete m_cache; 897 delete m_cache;
898 m_cache = 0; 898 m_cache = 0;
899 899
900 update(); 900 update();
943 View::globalCentreFrameChanged(unsigned long rf) 943 View::globalCentreFrameChanged(unsigned long rf)
944 { 944 {
945 if (m_followPan) { 945 if (m_followPan) {
946 size_t f = alignFromReference(rf); 946 size_t f = alignFromReference(rf);
947 #ifdef DEBUG_VIEW_WIDGET_PAINT 947 #ifdef DEBUG_VIEW_WIDGET_PAINT
948 std::cerr << "View[" << this << "]::globalCentreFrameChanged(" << rf 948 cerr << "View[" << this << "]::globalCentreFrameChanged(" << rf
949 << "): setting centre frame to " << f << std::endl; 949 << "): setting centre frame to " << f << endl;
950 #endif 950 #endif
951 setCentreFrame(f, false); 951 setCentreFrame(f, false);
952 } 952 }
953 } 953 }
954 954
1012 } 1012 }
1013 } 1013 }
1014 } 1014 }
1015 1015
1016 #ifdef DEBUG_VIEW_WIDGET_PAINT 1016 #ifdef DEBUG_VIEW_WIDGET_PAINT
1017 std::cerr << "PlaybackScrollPage: f = " << m_playPointerFrame << ", sf = " << sf << ", start frame " 1017 cerr << "PlaybackScrollPage: f = " << m_playPointerFrame << ", sf = " << sf << ", start frame "
1018 << getStartFrame() << std::endl; 1018 << getStartFrame() << endl;
1019 #endif 1019 #endif
1020 1020
1021 // We don't consider scrolling unless the pointer is outside 1021 // We don't consider scrolling unless the pointer is outside
1022 // the clearly visible range already 1022 // the clearly visible range already
1023 1023
1024 int xnew = getXForFrame(m_playPointerFrame); 1024 int xnew = getXForFrame(m_playPointerFrame);
1025 1025
1026 #ifdef DEBUG_VIEW_WIDGET_PAINT 1026 #ifdef DEBUG_VIEW_WIDGET_PAINT
1027 std::cerr << "xnew = " << xnew << ", width = " << width() << std::endl; 1027 cerr << "xnew = " << xnew << ", width = " << width() << endl;
1028 #endif 1028 #endif
1029 1029
1030 if (xnew < width()/8 || xnew > (width()*7)/8) { 1030 if (xnew < width()/8 || xnew > (width()*7)/8) {
1031 if (!somethingGoingOn) { 1031 if (!somethingGoingOn) {
1032 long offset = getFrameForX(width()/2) - getStartFrame(); 1032 long offset = getFrameForX(width()/2) - getStartFrame();
1055 1055
1056 void 1056 void
1057 View::viewZoomLevelChanged(View *p, unsigned long z, bool locked) 1057 View::viewZoomLevelChanged(View *p, unsigned long z, bool locked)
1058 { 1058 {
1059 #ifdef DEBUG_VIEW_WIDGET_PAINT 1059 #ifdef DEBUG_VIEW_WIDGET_PAINT
1060 std::cerr << "View[" << this << "]: viewZoomLevelChanged(" << p << ", " << z << ", " << locked << ")" << std::endl; 1060 cerr << "View[" << this << "]: viewZoomLevelChanged(" << p << ", " << z << ", " << locked << ")" << endl;
1061 #endif 1061 #endif
1062 if (m_followZoom && p != this && locked) { 1062 if (m_followZoom && p != this && locked) {
1063 setZoomLevel(z); 1063 setZoomLevel(z);
1064 } 1064 }
1065 } 1065 }
1243 Model *aligningModel = getAligningModel(); 1243 Model *aligningModel = getAligningModel();
1244 if (!aligningModel) return pf; 1244 if (!aligningModel) return pf;
1245 /* 1245 /*
1246 Model *pm = m_manager->getPlaybackModel(); 1246 Model *pm = m_manager->getPlaybackModel();
1247 1247
1248 // std::cerr << "View[" << this << "]::getAlignedPlaybackFrame: pf = " << pf; 1248 // cerr << "View[" << this << "]::getAlignedPlaybackFrame: pf = " << pf;
1249 1249
1250 if (pm) { 1250 if (pm) {
1251 pf = pm->alignToReference(pf); 1251 pf = pm->alignToReference(pf);
1252 // std::cerr << " -> " << pf; 1252 // cerr << " -> " << pf;
1253 } 1253 }
1254 */ 1254 */
1255 int af = aligningModel->alignFromReference(pf); 1255 int af = aligningModel->alignFromReference(pf);
1256 1256
1257 // std::cerr << ", aligned = " << af << std::endl; 1257 // cerr << ", aligned = " << af << endl;
1258 return af; 1258 return af;
1259 } 1259 }
1260 1260
1261 bool 1261 bool
1262 View::areLayersScrollable() const 1262 View::areLayersScrollable() const
1279 LayerList scrollables; 1279 LayerList scrollables;
1280 bool metUnscrollable = false; 1280 bool metUnscrollable = false;
1281 1281
1282 for (LayerList::const_iterator i = m_layers.begin(); i != m_layers.end(); ++i) { 1282 for (LayerList::const_iterator i = m_layers.begin(); i != m_layers.end(); ++i) {
1283 // SVDEBUG << "View::getScrollableBackLayers: calling isLayerDormant on layer " << *i << endl; 1283 // SVDEBUG << "View::getScrollableBackLayers: calling isLayerDormant on layer " << *i << endl;
1284 // std::cerr << "(name is " << (*i)->objectName() << ")" 1284 // cerr << "(name is " << (*i)->objectName() << ")"
1285 // << std::endl; 1285 // << endl;
1286 // SVDEBUG << "View::getScrollableBackLayers: I am " << this << endl; 1286 // SVDEBUG << "View::getScrollableBackLayers: I am " << this << endl;
1287 if ((*i)->isLayerDormant(this)) continue; 1287 if ((*i)->isLayerDormant(this)) continue;
1288 if ((*i)->isLayerOpaque()) { 1288 if ((*i)->isLayerOpaque()) {
1289 // You can't see anything behind an opaque layer! 1289 // You can't see anything behind an opaque layer!
1290 scrollables.clear(); 1290 scrollables.clear();
1483 pb->hide(); 1483 pb->hide();
1484 timer->stop(); 1484 timer->stop();
1485 1485
1486 } else { 1486 } else {
1487 1487
1488 // std::cerr << "progress = " << completion << std::endl; 1488 // cerr << "progress = " << completion << endl;
1489 1489
1490 if (!pb->isVisible()) { 1490 if (!pb->isVisible()) {
1491 i->second.lastCheck = 0; 1491 i->second.lastCheck = 0;
1492 timer->setInterval(2000); 1492 timer->setInterval(2000);
1493 timer->start(); 1493 timer->start();
1576 QRect cacheRect(rect()); 1576 QRect cacheRect(rect());
1577 1577
1578 if (e) { 1578 if (e) {
1579 cacheRect &= e->rect(); 1579 cacheRect &= e->rect();
1580 #ifdef DEBUG_VIEW_WIDGET_PAINT 1580 #ifdef DEBUG_VIEW_WIDGET_PAINT
1581 std::cerr << "paint rect " << cacheRect.width() << "x" << cacheRect.height() 1581 cerr << "paint rect " << cacheRect.width() << "x" << cacheRect.height()
1582 << ", my rect " << width() << "x" << height() << std::endl; 1582 << ", my rect " << width() << "x" << height() << endl;
1583 #endif 1583 #endif
1584 } 1584 }
1585 1585
1586 QRect nonCacheRect(cacheRect); 1586 QRect nonCacheRect(cacheRect);
1587 1587
1617 selectionCacheable = false; 1617 selectionCacheable = false;
1618 } 1618 }
1619 } 1619 }
1620 1620
1621 #ifdef DEBUG_VIEW_WIDGET_PAINT 1621 #ifdef DEBUG_VIEW_WIDGET_PAINT
1622 std::cerr << "View(" << this << ")::paintEvent: have " << scrollables.size() 1622 cerr << "View(" << this << ")::paintEvent: have " << scrollables.size()
1623 << " scrollable back layers and " << nonScrollables.size() 1623 << " scrollable back layers and " << nonScrollables.size()
1624 << " non-scrollable front layers" << std::endl; 1624 << " non-scrollable front layers" << endl;
1625 std::cerr << "haveSelections " << haveSelections << ", selectionCacheable " 1625 cerr << "haveSelections " << haveSelections << ", selectionCacheable "
1626 << selectionCacheable << ", m_selectionCached " << m_selectionCached << std::endl; 1626 << selectionCacheable << ", m_selectionCached " << m_selectionCached << endl;
1627 #endif 1627 #endif
1628 1628
1629 if (layersChanged || scrollables.empty() || 1629 if (layersChanged || scrollables.empty() ||
1630 (haveSelections && (selectionCacheable != m_selectionCached))) { 1630 (haveSelections && (selectionCacheable != m_selectionCached))) {
1631 delete m_cache; 1631 delete m_cache;
1634 } 1634 }
1635 1635
1636 if (!scrollables.empty()) { 1636 if (!scrollables.empty()) {
1637 1637
1638 #ifdef DEBUG_VIEW_WIDGET_PAINT 1638 #ifdef DEBUG_VIEW_WIDGET_PAINT
1639 std::cerr << "View(" << this << "): cache " << m_cache << ", cache zoom " 1639 cerr << "View(" << this << "): cache " << m_cache << ", cache zoom "
1640 << m_cacheZoomLevel << ", zoom " << m_zoomLevel << std::endl; 1640 << m_cacheZoomLevel << ", zoom " << m_zoomLevel << endl;
1641 #endif 1641 #endif
1642 1642
1643 if (!m_cache || 1643 if (!m_cache ||
1644 m_cacheZoomLevel != m_zoomLevel || 1644 m_cacheZoomLevel != m_zoomLevel ||
1645 width() != m_cache->width() || 1645 width() != m_cache->width() ||
1649 1649
1650 if (cacheRect.width() < width()/10) { 1650 if (cacheRect.width() < width()/10) {
1651 delete m_cache; 1651 delete m_cache;
1652 m_cache = 0; 1652 m_cache = 0;
1653 #ifdef DEBUG_VIEW_WIDGET_PAINT 1653 #ifdef DEBUG_VIEW_WIDGET_PAINT
1654 std::cerr << "View(" << this << ")::paintEvent: small repaint, not bothering to recreate cache" << std::endl; 1654 cerr << "View(" << this << ")::paintEvent: small repaint, not bothering to recreate cache" << endl;
1655 #endif 1655 #endif
1656 } else { 1656 } else {
1657 delete m_cache; 1657 delete m_cache;
1658 m_cache = new QPixmap(width(), height()); 1658 m_cache = new QPixmap(width(), height());
1659 #ifdef DEBUG_VIEW_WIDGET_PAINT 1659 #ifdef DEBUG_VIEW_WIDGET_PAINT
1660 std::cerr << "View(" << this << ")::paintEvent: recreated cache" << std::endl; 1660 cerr << "View(" << this << ")::paintEvent: recreated cache" << endl;
1661 #endif 1661 #endif
1662 cacheRect = rect(); 1662 cacheRect = rect();
1663 repaintCache = true; 1663 repaintCache = true;
1664 } 1664 }
1665 1665
1700 cacheRect = QRect(width() + dx, 0, -dx, height()); 1700 cacheRect = QRect(width() + dx, 0, -dx, height());
1701 } else { 1701 } else {
1702 cacheRect = QRect(0, 0, dx, height()); 1702 cacheRect = QRect(0, 0, dx, height());
1703 } 1703 }
1704 #ifdef DEBUG_VIEW_WIDGET_PAINT 1704 #ifdef DEBUG_VIEW_WIDGET_PAINT
1705 std::cerr << "View(" << this << ")::paintEvent: scrolled cache by " << dx << std::endl; 1705 cerr << "View(" << this << ")::paintEvent: scrolled cache by " << dx << endl;
1706 #endif 1706 #endif
1707 } else { 1707 } else {
1708 cacheRect = rect(); 1708 cacheRect = rect();
1709 #ifdef DEBUG_VIEW_WIDGET_PAINT 1709 #ifdef DEBUG_VIEW_WIDGET_PAINT
1710 std::cerr << "View(" << this << ")::paintEvent: scrolling too far" << std::endl; 1710 cerr << "View(" << this << ")::paintEvent: scrolling too far" << endl;
1711 #endif 1711 #endif
1712 } 1712 }
1713 repaintCache = true; 1713 repaintCache = true;
1714 1714
1715 } else { 1715 } else {
1716 #ifdef DEBUG_VIEW_WIDGET_PAINT 1716 #ifdef DEBUG_VIEW_WIDGET_PAINT
1717 std::cerr << "View(" << this << ")::paintEvent: cache is good" << std::endl; 1717 cerr << "View(" << this << ")::paintEvent: cache is good" << endl;
1718 #endif 1718 #endif
1719 paint.begin(this); 1719 paint.begin(this);
1720 paint.drawPixmap(cacheRect, *m_cache, cacheRect); 1720 paint.drawPixmap(cacheRect, *m_cache, cacheRect);
1721 paint.end(); 1721 paint.end();
1722 QFrame::paintEvent(e); 1722 QFrame::paintEvent(e);
1726 m_cacheCentreFrame = m_centreFrame; 1726 m_cacheCentreFrame = m_centreFrame;
1727 m_cacheZoomLevel = m_zoomLevel; 1727 m_cacheZoomLevel = m_zoomLevel;
1728 } 1728 }
1729 1729
1730 #ifdef DEBUG_VIEW_WIDGET_PAINT 1730 #ifdef DEBUG_VIEW_WIDGET_PAINT
1731 // std::cerr << "View(" << this << ")::paintEvent: cacheRect " << cacheRect << ", nonCacheRect " << (nonCacheRect | cacheRect) << ", repaintCache " << repaintCache << ", paintedCacheRect " << paintedCacheRect << std::endl; 1731 // cerr << "View(" << this << ")::paintEvent: cacheRect " << cacheRect << ", nonCacheRect " << (nonCacheRect | cacheRect) << ", repaintCache " << repaintCache << ", paintedCacheRect " << paintedCacheRect << endl;
1732 #endif 1732 #endif
1733 1733
1734 // Scrollable (cacheable) items first 1734 // Scrollable (cacheable) items first
1735 1735
1736 if (!paintedCacheRect) { 1736 if (!paintedCacheRect) {
2307 paint.setRenderHint(QPainter::Antialiasing, false); 2307 paint.setRenderHint(QPainter::Antialiasing, false);
2308 2308
2309 paint.save(); 2309 paint.save();
2310 paint.translate(xorigin + x, 0); 2310 paint.translate(xorigin + x, 0);
2311 2311
2312 std::cerr << "Centre frame now: " << m_centreFrame << " drawing to " << chunk.x() + x + xorigin << ", " << chunk.width() << std::endl; 2312 cerr << "Centre frame now: " << m_centreFrame << " drawing to " << chunk.x() + x + xorigin << ", " << chunk.width() << endl;
2313 2313
2314 (*i)->setSynchronousPainting(true); 2314 (*i)->setSynchronousPainting(true);
2315 2315
2316 (*i)->paint(this, paint, chunk); 2316 (*i)->paint(this, paint, chunk);
2317 2317