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:
parent
29af390e3f
commit
caa4ead1b9
@ -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 ®ion, 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 ®ion)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
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 ®ion, 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()
|
||||||
*/
|
*/
|
||||||
@ -224,7 +242,7 @@ void QBackingStore::resize(const QSize &size)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Returns the current size of the windowsurface.
|
Returns the current size of the window surface.
|
||||||
*/
|
*/
|
||||||
QSize QBackingStore::size() const
|
QSize QBackingStore::size() const
|
||||||
{
|
{
|
||||||
@ -260,8 +278,8 @@ void QBackingStore::setStaticContents(const QRegion ®ion)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
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
|
||||||
{
|
{
|
||||||
|
@ -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 ®ion, QWindow *window = nullptr, const QPoint &offset = QPoint());
|
||||||
// offset is the (child) window's offset in relation to the window surface.
|
|
||||||
void flush(const QRegion ®ion, QWindow *window = Q_NULLPTR, const QPoint &offset = QPoint());
|
|
||||||
|
|
||||||
void resize(const QSize &size);
|
void resize(const QSize &size);
|
||||||
QSize size() const;
|
QSize size() const;
|
||||||
|
@ -234,17 +234,6 @@ void QPlatformTextureList::clear()
|
|||||||
windows.
|
windows.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*!
|
|
||||||
\fn void QPlatformBackingStore::flush(QWindow *window, const QRegion ®ion,
|
|
||||||
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)
|
||||||
|
@ -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 ®ion, const QPoint &offset) = 0;
|
virtual void flush(QWindow *window, const QRegion ®ion, const QPoint &offset) = 0;
|
||||||
#ifndef QT_NO_OPENGL
|
#ifndef QT_NO_OPENGL
|
||||||
virtual void composeAndFlush(QWindow *window, const QRegion ®ion, const QPoint &offset,
|
virtual void composeAndFlush(QWindow *window, const QRegion ®ion, const QPoint &offset,
|
||||||
|
Loading…
Reference in New Issue
Block a user