diff layer/ScrollableImageCache.cpp @ 1324:13d9b422f7fe zoom

Merge from default branch
author Chris Cannam
date Mon, 17 Sep 2018 13:51:31 +0100
parents a34a2a25907c
children
line wrap: on
line diff
--- a/layer/ScrollableImageCache.cpp	Mon Dec 12 15:18:52 2016 +0000
+++ b/layer/ScrollableImageCache.cpp	Mon Sep 17 13:51:31 2018 +0100
@@ -28,43 +28,43 @@
     static HitCount count("ScrollableImageCache: scrolling");
     
     int dx = (v->getXForFrame(m_startFrame) -
-	      v->getXForFrame(newStartFrame));
+              v->getXForFrame(newStartFrame));
     
 #ifdef DEBUG_SCROLLABLE_IMAGE_CACHE
     cerr << "ScrollableImageCache::scrollTo: start frame " << m_startFrame
-	 << " -> " << newStartFrame << ", dx = " << dx << endl;
+         << " -> " << newStartFrame << ", dx = " << dx << endl;
 #endif
 
     if (m_startFrame == newStartFrame) {
-	// haven't moved
+        // haven't moved
         count.hit();
         return;
     }
-	
+        
     m_startFrame = newStartFrame;
-	
+        
     if (!isValid()) {
         count.miss();
-	return;
+        return;
     }
 
     int w = m_image.width();
 
     if (dx == 0) {
-	// haven't moved visibly (even though start frame may have changed)
+        // haven't moved visibly (even though start frame may have changed)
         count.hit();
-	return;
+        return;
     }
 
     if (dx <= -w || dx >= w) {
-	// scrolled entirely off
-	invalidate();
+        // scrolled entirely off
+        invalidate();
         count.miss();
-	return;
+        return;
     }
 
     count.partial();
-	
+        
     // dx is in range, cache is scrollable
 
     int dxp = dx;
@@ -72,38 +72,38 @@
 
     int copylen = (w - dxp) * int(sizeof(QRgb));
     for (int y = 0; y < m_image.height(); ++y) {
-	QRgb *line = (QRgb *)m_image.scanLine(y);
-	if (dx < 0) {
-	    memmove(line, line + dxp, copylen);
-	} else {
-	    memmove(line + dxp, line, copylen);
-	}
+        QRgb *line = (QRgb *)m_image.scanLine(y);
+        if (dx < 0) {
+            memmove(line, line + dxp, copylen);
+        } else {
+            memmove(line + dxp, line, copylen);
+        }
     }
-	
+        
     // update valid area
         
     int px = m_validLeft;
     int pw = m_validWidth;
-	
+        
     px += dx;
-	
+        
     if (dx < 0) {
-	// we scrolled left
-	if (px < 0) {
-	    pw += px;
-	    px = 0;
-	    if (pw < 0) {
-		pw = 0;
-	    }
-	}
+        // we scrolled left
+        if (px < 0) {
+            pw += px;
+            px = 0;
+            if (pw < 0) {
+                pw = 0;
+            }
+        }
     } else {
-	// we scrolled right
-	if (px + pw > w) {
-	    pw = w - px;
-	    if (pw < 0) {
-		pw = 0;
-	    }
-	}
+        // we scrolled right
+        if (px + pw > w) {
+            pw = w - px;
+            if (pw < 0) {
+                pw = 0;
+            }
+        }
     }
 
     m_validLeft = px;
@@ -112,7 +112,7 @@
 
 void
 ScrollableImageCache::adjustToTouchValidArea(int &left, int &width,
-					     bool &isLeftOfValidArea) const
+                                             bool &isLeftOfValidArea) const
 {
 #ifdef DEBUG_SCROLLABLE_IMAGE_CACHE
     cerr << "ScrollableImageCache::adjustToTouchValidArea: left " << left
@@ -121,18 +121,18 @@
          << ", width " << m_validWidth << " so right " << (m_validLeft + m_validWidth) << endl;
 #endif
     if (left < m_validLeft) {
-	isLeftOfValidArea = true;
-	if (left + width <= m_validLeft + m_validWidth) {
-	    width = m_validLeft - left;
-	}
+        isLeftOfValidArea = true;
+        if (left + width <= m_validLeft + m_validWidth) {
+            width = m_validLeft - left;
+        }
 #ifdef DEBUG_SCROLLABLE_IMAGE_CACHE
         cerr << "ScrollableImageCache: we're left of valid area, adjusted width to " << width << endl;
 #endif
     } else {
-	isLeftOfValidArea = false;
-	width = left + width - (m_validLeft + m_validWidth);
-	left = m_validLeft + m_validWidth;
-	if (width < 0) width = 0;
+        isLeftOfValidArea = false;
+        width = left + width - (m_validLeft + m_validWidth);
+        left = m_validLeft + m_validWidth;
+        if (width < 0) width = 0;
 #ifdef DEBUG_SCROLLABLE_IMAGE_CACHE
         cerr << "ScrollableImageCache: we're right of valid area, adjusted left to " << left << ", width to " << width << endl;
 #endif
@@ -141,80 +141,80 @@
     
 void
 ScrollableImageCache::drawImage(int left,
-				int width,
-				QImage image,
-				int imageLeft,
-				int imageWidth)
+                                int width,
+                                QImage image,
+                                int imageLeft,
+                                int imageWidth)
 {
     if (image.height() != m_image.height()) {
-	cerr << "ScrollableImageCache::drawImage: ERROR: Supplied image height "
-	     << image.height() << " does not match cache height "
-	     << m_image.height() << endl;
-	throw std::logic_error("Image height must match cache height in ScrollableImageCache::drawImage");
+        cerr << "ScrollableImageCache::drawImage: ERROR: Supplied image height "
+             << image.height() << " does not match cache height "
+             << m_image.height() << endl;
+        throw std::logic_error("Image height must match cache height in ScrollableImageCache::drawImage");
     }
     if (left < 0 || width < 0 || left + width > m_image.width()) {
-	cerr << "ScrollableImageCache::drawImage: ERROR: Target area (left = "
-	     << left << ", width = " << width << ", so right = " << left + width
+        cerr << "ScrollableImageCache::drawImage: ERROR: Target area (left = "
+             << left << ", width = " << width << ", so right = " << left + width
              << ") out of bounds for cache of width " << m_image.width() << endl;
-	throw std::logic_error("Target area out of bounds in ScrollableImageCache::drawImage");
+        throw std::logic_error("Target area out of bounds in ScrollableImageCache::drawImage");
     }
     if (imageLeft < 0 || imageWidth < 0 ||
-	imageLeft + imageWidth > image.width()) {
-	cerr << "ScrollableImageCache::drawImage: ERROR: Source area (left = "
-	     << imageLeft << ", width = " << imageWidth << ", so right = "
+        imageLeft + imageWidth > image.width()) {
+        cerr << "ScrollableImageCache::drawImage: ERROR: Source area (left = "
+             << imageLeft << ", width = " << imageWidth << ", so right = "
              << imageLeft + imageWidth << ") out of bounds for image of "
-	     << "width " << image.width() << endl;
-	throw std::logic_error("Source area out of bounds in ScrollableImageCache::drawImage");
+             << "width " << image.width() << endl;
+        throw std::logic_error("Source area out of bounds in ScrollableImageCache::drawImage");
     }
-	
+        
     QPainter painter(&m_image);
     painter.drawImage(QRect(left, 0, width, m_image.height()),
-		      image,
-		      QRect(imageLeft, 0, imageWidth, image.height()));
+                      image,
+                      QRect(imageLeft, 0, imageWidth, image.height()));
     painter.end();
 
     if (!isValid()) {
-	m_validLeft = left;
-	m_validWidth = width;
-	return;
+        m_validLeft = left;
+        m_validWidth = width;
+        return;
     }
-	
+        
     if (left < m_validLeft) {
-	if (left + width > m_validLeft + m_validWidth) {
-	    // new image completely contains the old valid area --
-	    // use the new area as is
-	    m_validLeft = left;
-	    m_validWidth = width;
-	} else if (left + width < m_validLeft) {
-	    // new image completely off left of old valid area --
-	    // we can't extend the valid area because the bit in
-	    // between is not valid, so must use the new area only
-	    m_validLeft = left;
-	    m_validWidth = width;
-	} else {
-	    // new image overlaps old valid area on left side --
-	    // use new left edge, and extend width to existing
-	    // right edge
-	    m_validWidth = (m_validLeft + m_validWidth) - left;
-	    m_validLeft = left;
-	}
+        if (left + width > m_validLeft + m_validWidth) {
+            // new image completely contains the old valid area --
+            // use the new area as is
+            m_validLeft = left;
+            m_validWidth = width;
+        } else if (left + width < m_validLeft) {
+            // new image completely off left of old valid area --
+            // we can't extend the valid area because the bit in
+            // between is not valid, so must use the new area only
+            m_validLeft = left;
+            m_validWidth = width;
+        } else {
+            // new image overlaps old valid area on left side --
+            // use new left edge, and extend width to existing
+            // right edge
+            m_validWidth = (m_validLeft + m_validWidth) - left;
+            m_validLeft = left;
+        }
     } else {
-	if (left > m_validLeft + m_validWidth) {
-	    // new image completely off right of old valid area --
-	    // we can't extend the valid area because the bit in
-	    // between is not valid, so must use the new area only
-	    m_validLeft = left;
-	    m_validWidth = width;
-	} else if (left + width > m_validLeft + m_validWidth) {
-	    // new image overlaps old valid area on right side --
-	    // use existing left edge, and extend width to new
-	    // right edge
-	    m_validWidth = (left + width) - m_validLeft;
-	    // (m_validLeft unchanged)
-	} else {
-	    // new image completely contained within old valid
-	    // area -- leave the old area unchanged
-	}
+        if (left > m_validLeft + m_validWidth) {
+            // new image completely off right of old valid area --
+            // we can't extend the valid area because the bit in
+            // between is not valid, so must use the new area only
+            m_validLeft = left;
+            m_validWidth = width;
+        } else if (left + width > m_validLeft + m_validWidth) {
+            // new image overlaps old valid area on right side --
+            // use existing left edge, and extend width to new
+            // right edge
+            m_validWidth = (left + width) - m_validLeft;
+            // (m_validLeft unchanged)
+        } else {
+            // new image completely contained within old valid
+            // area -- leave the old area unchanged
+        }
     }
 }