summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMichael Brasser <mbrasser@ford.com>2020-10-21 16:38:42 -0500
committerMichael Brasser <mbrasser@ford.com>2020-10-22 08:29:56 -0500
commit3d2d67b571b0f6ed3df1c0d3eeed1e89097bef57 (patch)
treeca4e3732258222980ebf08b8a168ff4072e2cbe7 /src
parent41e457cbee41af546f964885e289dab8c9ac99de (diff)
Expand QPaintedTextureImage documentation
Also make use of the newly documented pattern in the manual test. Pick-to: 5.15 Change-Id: Idefe271eea345848af3817e08ac5b45946843dad Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
Diffstat (limited to 'src')
-rw-r--r--src/render/texture/qpaintedtextureimage.cpp17
1 files changed, 15 insertions, 2 deletions
diff --git a/src/render/texture/qpaintedtextureimage.cpp b/src/render/texture/qpaintedtextureimage.cpp
index 80bdc184f..a741205af 100644
--- a/src/render/texture/qpaintedtextureimage.cpp
+++ b/src/render/texture/qpaintedtextureimage.cpp
@@ -199,8 +199,12 @@ void QPaintedTextureImage::setSize(QSize size)
}
/*!
- Schedules the painted texture's paint() function to be called,
- which in turn uploads the new image to the GPU.
+ Immediately triggers the painted texture's paint() function,
+ which in turn uploads the new image to the GPU. If you are
+ making multiple changes to a painted texture, consider waiting
+ until all changes are complete before calling update, in order
+ to minimize the number of repaints required.
+
Parameter \a rect is currently unused.
*/
void QPaintedTextureImage::update(const QRect &rect)
@@ -215,6 +219,15 @@ void QPaintedTextureImage::update(const QRect &rect)
\fn Qt3DRender::QPaintedTextureImage::paint(QPainter *painter)
Paints the texture image with the specified QPainter object \a painter.
+
+ QPainter considers the top-left corner of an image as its origin, while OpenGL considers
+ the bottom-left corner of a texture as its origin. An easy way to account for this difference
+ is to set a custom viewport on the painter before doing any other painting:
+
+ \code
+ painter->setViewport(0, height(), width(), -height());
+ ...
+ \endcode
*/
QTextureImageDataGeneratorPtr QPaintedTextureImage::dataGenerator() const
{