IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)

QPaintedTextureImage Class

A QAbstractTextureImage that can be written through a QPainter.

This class was introduced in Qt 5.8.

Article lu   fois.

L'auteur

Liens sociaux

Viadeo Twitter Facebook Share on Google+   

QPaintedTextureImage Class

  • Header: QPaintedTextureImage

  • Since: Qt 5.8

  • CMake:

    find_package(Qt6 REQUIRED COMPONENTS 3drender)

    target_link_libraries(mytarget PRIVATE Qt6::3drender)

  • qmake: QT += 3drender

  • Inherits: Qt3DRender::QAbstractTextureImage

Detailed Description

A QPaintedTextureImage provides a way to specify a texture image (and thus an OpenGL texture) through a QPainter. The width and height of the texture image can be specified through the width and height or size properties.

A QPaintedTextureImage must be subclassed and the virtual paint() function implemented. Each time update() is called on the QPaintedTextureImage, the paint() function is invoked and the resulting image is uploaded.

The QPaintedTextureImage must be attached to some QAbstractTexture.

Property Documentation

 

height : int

This property holds the height of the texture image. The height must be greater than or equal to 1.

Access functions:

Notifier signal:

  • void heightChanged(int w)

size : QSize

This property holds the size of the texture image.

Access functions:

Notifier signal:

  • void sizeChanged( size)

See Also

See also height, width

width : int

This property holds the width of the texture image. The width must be greater than or equal to 1.

Access functions:

  • int width() const

  • void setWidth(int w)

Notifier signal:

  • void widthChanged(int w)

Member Function Documentation

 

[pure virtual protected] void QPaintedTextureImage::paint(QPainter *painter)

Paints the texture image with the specified QPainter object 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:

 
Sélectionnez
painter->setViewport(0, height(), width(), -height());
...

void QPaintedTextureImage::setHeight(int h)

Sets the height (h) of the texture image. Triggers an update, if the size changes.

Setter function for property height.

See Also

See also height()

void QPaintedTextureImage::setSize(QSize size)

Sets the width and height of the texture image. Triggers an update, if the size changes.

Setter function for property size.

See Also

See also size()

void QPaintedTextureImage::setWidth(int w)

Sets the width (w) of the texture image. Triggers an update, if the size changes.

Setter function for property width.

See Also

See also width()

void QPaintedTextureImage::update(const QRect &rect = QRect())

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 rect is currently unused.

Vous avez aimé ce tutoriel ? Alors partagez-le en cliquant sur les boutons suivants : Viadeo Twitter Facebook Share on Google+