Flesh out and clean up QBackingStore documentation

Some of the functions had wording that suggested people subclass
QBackingStore, probably because the docs came from QWindowSurface
in QWS times.

Clarify the role of the region, window, and offset arguments
to flush(), in the case of flushing child windows.

Document that paintDevice() is only valid after calling beginPaint(),
and should not be cached.

Although our own QRasterWindow, and the rasterwindow example, both
allow backingstores for child windows, and it works in practice on
a few platforms, we keep the documentation stating that they should
only be used for top level windows, until we've verified and
formalized support for this across platforms.

Change-Id: I7b4d6128a0cd2faeb2af9405ac1bcca46440ead1
Reviewed-by: Gatis Paeglis <gatis.paeglis@qt.io>
Reviewed-by: Eskil Abrahamsen Blomfeldt <eskil.abrahamsen-blomfeldt@qt.io>
Reviewed-by: Tor Arne Vestbø <tor.arne.vestbo@qt.io>
This commit is contained in:
Tor Arne Vestbø 2017-07-12 12:06:54 +02:00
parent 29af390e3f
commit caa4ead1b9
4 changed files with 74 additions and 72 deletions

View File

@ -89,50 +89,6 @@ public:
QBackingStore see the \l{Raster Window Example}. QBackingStore see the \l{Raster Window Example}.
*/ */
/*!
Flushes the given \a region from the specified window \a win onto the
screen.
Note that the \a offset parameter is currently unused.
*/
void QBackingStore::flush(const QRegion &region, QWindow *win, const QPoint &offset)
{
if (!win)
win = window();
if (!win->handle()) {
qWarning() << "QBackingStore::flush() called for "
<< win << " which does not have a handle.";
return;
}
#ifdef QBACKINGSTORE_DEBUG
if (win && win->isTopLevel() && !qt_window_private(win)->receivedExpose) {
qWarning().nospace() << "QBackingStore::flush() called with non-exposed window "
<< win << ", behavior is undefined";
}
#endif
Q_ASSERT(win == this->window() || this->window()->isAncestorOf(win, QWindow::ExcludeTransients));
d_ptr->platformBackingStore->flush(win, QHighDpi::toNativeLocalRegion(region, win),
QHighDpi::toNativeLocalPosition(offset, win));
}
/*!
\fn QPaintDevice* QBackingStore::paintDevice()
Implement this function to return the appropriate paint device.
*/
QPaintDevice *QBackingStore::paintDevice()
{
QPaintDevice *device = d_ptr->platformBackingStore->paintDevice();
if (QHighDpiScaling::isActive() && device->devType() == QInternal::Image)
return d_ptr->highDpiBackingstore.data();
return device;
}
/*! /*!
Constructs an empty surface for the given top-level \a window. Constructs an empty surface for the given top-level \a window.
*/ */
@ -161,8 +117,10 @@ QWindow* QBackingStore::window() const
} }
/*! /*!
This function is called before painting onto the surface begins, Begins painting on the backing store surface in the given \a region.
with the \a region in which the painting will occur.
You should call this function before using the paintDevice() to
paint.
\sa endPaint(), paintDevice() \sa endPaint(), paintDevice()
*/ */
@ -203,7 +161,26 @@ void QBackingStore::beginPaint(const QRegion &region)
} }
/*! /*!
This function is called after painting onto the surface has ended. Returns the paint device for this surface.
\warning The device is only valid between calls to beginPaint() and
endPaint(). You should not cache the returned value.
*/
QPaintDevice *QBackingStore::paintDevice()
{
QPaintDevice *device = d_ptr->platformBackingStore->paintDevice();
if (QHighDpiScaling::isActive() && device->devType() == QInternal::Image)
return d_ptr->highDpiBackingstore.data();
return device;
}
/*!
Ends painting.
You should call this function after painting with the paintDevice()
has ended.
\sa beginPaint(), paintDevice() \sa beginPaint(), paintDevice()
*/ */
@ -213,7 +190,48 @@ void QBackingStore::endPaint()
} }
/*! /*!
Sets the size of the windowsurface to be \a size. Flushes the given \a region from the specified \a window onto the
screen.
The \a window must either be the top level window represented by
this backingstore, or a non-transient child of that window. Passing
\c nullptr falls back to using the backingstore's top level window.
If the \a window is a child window, the \a region should be in child window
coordinates, and the \a offset should be the child window's offset in relation
to the backingstore's top level window.
You should call this function after ending painting with endPaint().
\sa QWindow::transientParent()
*/
void QBackingStore::flush(const QRegion &region, QWindow *window, const QPoint &offset)
{
QWindow *topLevelWindow = this->window();
if (!window)
window = topLevelWindow;
if (!window->handle()) {
qWarning() << "QBackingStore::flush() called for "
<< window << " which does not have a handle.";
return;
}
#ifdef QBACKINGSTORE_DEBUG
if (window && window->isTopLevel() && !qt_window_private(window)->receivedExpose) {
qWarning().nospace() << "QBackingStore::flush() called with non-exposed window "
<< window << ", behavior is undefined";
}
#endif
Q_ASSERT(window == topLevelWindow || topLevelWindow->isAncestorOf(window, QWindow::ExcludeTransients));
d_ptr->platformBackingStore->flush(window, QHighDpi::toNativeLocalRegion(region, window),
QHighDpi::toNativeLocalPosition(offset, window));
}
/*!
Sets the size of the window surface to \a size.
\sa size() \sa size()
*/ */
@ -260,8 +278,8 @@ void QBackingStore::setStaticContents(const QRegion &region)
} }
/*! /*!
Returns a pointer to the QRegion that has the static contents Returns a QRegion representing the area of the window that
of this window. has static contents.
*/ */
QRegion QBackingStore::staticContents() const QRegion QBackingStore::staticContents() const
{ {
@ -269,8 +287,7 @@ QRegion QBackingStore::staticContents() const
} }
/*! /*!
Returns a boolean indicating if this window Returns a boolean indicating if this window has static contents or not.
has static contents or not.
*/ */
bool QBackingStore::hasStaticContents() const bool QBackingStore::hasStaticContents() const
{ {

View File

@ -66,9 +66,7 @@ public:
QPaintDevice *paintDevice(); QPaintDevice *paintDevice();
// 'window' can be a child window, in which case 'region' is in child window coordinates and void flush(const QRegion &region, QWindow *window = nullptr, const QPoint &offset = QPoint());
// offset is the (child) window's offset in relation to the window surface.
void flush(const QRegion &region, QWindow *window = Q_NULLPTR, const QPoint &offset = QPoint());
void resize(const QSize &size); void resize(const QSize &size);
QSize size() const; QSize size() const;

View File

@ -234,17 +234,6 @@ void QPlatformTextureList::clear()
windows. windows.
*/ */
/*!
\fn void QPlatformBackingStore::flush(QWindow *window, const QRegion &region,
const QPoint &offset)
Flushes the given \a region from the specified \a window onto the
screen.
The \a offset parameter is relative to the origin of the backing
store image.
*/
#ifndef QT_NO_OPENGL #ifndef QT_NO_OPENGL
static inline QRect deviceRect(const QRect &rect, QWindow *window) static inline QRect deviceRect(const QRect &rect, QWindow *window)

View File

@ -117,8 +117,6 @@ public:
virtual QPaintDevice *paintDevice() = 0; virtual QPaintDevice *paintDevice() = 0;
// 'window' can be a child window, in which case 'region' is in child window coordinates and
// offset is the (child) window's offset in relation to the window surface.
virtual void flush(QWindow *window, const QRegion &region, const QPoint &offset) = 0; virtual void flush(QWindow *window, const QRegion &region, const QPoint &offset) = 0;
#ifndef QT_NO_OPENGL #ifndef QT_NO_OPENGL
virtual void composeAndFlush(QWindow *window, const QRegion &region, const QPoint &offset, virtual void composeAndFlush(QWindow *window, const QRegion &region, const QPoint &offset,