From 061968d0825b2f12dd99ec94ef03b87955af894a Mon Sep 17 00:00:00 2001 From: Friedemann Kleint Date: Fri, 18 May 2012 16:08:20 +0200 Subject: QWindowsBackingStore: Implement scroll. MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Similar to XCB. Task-number: QTBUG-24299 Task-number: QTBUG-24296 (partially fixed) Change-Id: I4c9d813d9645f957f2caad0c4e395ce0d3d222cc Reviewed-by: Samuel Rødal --- src/plugins/platforms/windows/qwindowsbackingstore.cpp | 14 ++++++++++++++ src/plugins/platforms/windows/qwindowsbackingstore.h | 1 + 2 files changed, 15 insertions(+) (limited to 'src/plugins') diff --git a/src/plugins/platforms/windows/qwindowsbackingstore.cpp b/src/plugins/platforms/windows/qwindowsbackingstore.cpp index e86b41a48a..aad115a30b 100644 --- a/src/plugins/platforms/windows/qwindowsbackingstore.cpp +++ b/src/plugins/platforms/windows/qwindowsbackingstore.cpp @@ -121,6 +121,20 @@ void QWindowsBackingStore::resize(const QSize &size, const QRegion ®ion) } } +Q_GUI_EXPORT void qt_scrollRectInImage(QImage &img, const QRect &rect, const QPoint &offset); + +bool QWindowsBackingStore::scroll(const QRegion &area, int dx, int dy) +{ + if (m_image.isNull() || m_image->image().isNull()) + return false; + + const QVector rects = area.rects(); + for (int i = 0; i < rects.size(); ++i) + qt_scrollRectInImage(m_image->image(), rects.at(i), QPoint(dx, dy)); + + return true; +} + void QWindowsBackingStore::beginPaint(const QRegion ®ion) { Q_UNUSED(region); diff --git a/src/plugins/platforms/windows/qwindowsbackingstore.h b/src/plugins/platforms/windows/qwindowsbackingstore.h index 75b6e5f736..f9a0603642 100644 --- a/src/plugins/platforms/windows/qwindowsbackingstore.h +++ b/src/plugins/platforms/windows/qwindowsbackingstore.h @@ -62,6 +62,7 @@ public: virtual QPaintDevice *paintDevice(); virtual void flush(QWindow *window, const QRegion ®ion, const QPoint &offset); virtual void resize(const QSize &size, const QRegion &r); + virtual bool scroll(const QRegion &area, int dx, int dy); virtual void beginPaint(const QRegion &); HDC getDC() const; -- cgit v1.2.3