QDiffuseMapMaterial Class
class Qt3DExtras::QDiffuseMapMaterialDas QDiffuseMapMaterial bietet eine Standardimplementierung des Phong-Lichteffekts, bei dem die diffuse Lichtkomponente aus einer Texturkarte gelesen wird. Mehr...
Kopfzeile: | #include <QDiffuseMapMaterial> |
CMake: | find_package(Qt6 REQUIRED COMPONENTS 3dextras) target_link_libraries(mytarget PRIVATE Qt6::3dextras) |
qmake: | QT += 3dextras |
Vererbt: | Qt3DRender::QMaterial |
Status: | Veraltet |
Diese Klasse ist veraltet. Wir raten dringend davon ab, sie in neuem Code zu verwenden.
Eigenschaften
|
Öffentliche Funktionen
QDiffuseMapMaterial(Qt3DCore::QNode *parent = nullptr) | |
virtual | ~QDiffuseMapMaterial() |
QColor | ambient() const |
Qt3DRender::QAbstractTexture * | diffuse() const |
float | shininess() const |
QColor | specular() const |
float | textureScale() const |
Öffentliche Slots
void | setAmbient(const QColor &color) |
void | setDiffuse(Qt3DRender::QAbstractTexture *diffuse) |
void | setShininess(float shininess) |
void | setSpecular(const QColor &specular) |
void | setTextureScale(float textureScale) |
Signale
void | ambientChanged(const QColor &ambient) |
void | diffuseChanged(Qt3DRender::QAbstractTexture *diffuse) |
void | shininessChanged(float shininess) |
void | specularChanged(const QColor &specular) |
void | textureScaleChanged(float textureScale) |
Detaillierte Beschreibung
Diese Klasse ist veraltet; verwenden Sie stattdessen Qt3DExtras::QDiffuseSpecularMaterial.
Der spiegelnde Lichteffekt basiert auf der Kombination der 3 Beleuchtungskomponenten ambient, diffus und spiegelnd. Die relativen Stärken dieser Komponenten werden durch ihre Reflexionskoeffizienten gesteuert, die als RGB-Tripletts modelliert werden:
- Umgebungslicht ist die Farbe, die von einem Objekt ohne andere Lichtquelle abgestrahlt wird.
- Diffus ist die Farbe, die bei groben Oberflächenreflexionen mit den Lichtern emittiert wird.
- Specular ist die Farbe, die für glänzende Oberflächenreflexionen mit den Lichtern emittiert wird.
- Der Glanz einer Oberfläche wird durch eine Float-Eigenschaft gesteuert.
Dieses Material verwendet einen Effekt mit einem einzigen Rendering-Pass-Ansatz und führt eine Beleuchtung pro Fragment durch. Die Techniken werden für OpenGL 2, OpenGL 3 oder höher sowie OpenGL ES 2 bereitgestellt.
Dokumentation der Eigenschaft
ambient : QColor
Enthält die aktuelle Umgebungsfarbe.
Zugriffsfunktionen:
QColor | ambient() const |
void | setAmbient(const QColor &color) |
Melder-Signal:
void | ambientChanged(const QColor &ambient) |
diffuse : Qt3DRender::QAbstractTexture*
Enthält die aktuelle Textur, die als Diffus-Map verwendet wird.
Standardmäßig hat die diffuse Textur die folgenden Eigenschaften:
- Lineare Verkleinerungs- und Vergrößerungsfilter
- Lineare Mipmap mit aktiviertem Mipmapping
- Wiederholter Wrap-Modus
- Maximale Anisotropie von 16,0
Zugriffsfunktionen:
Qt3DRender::QAbstractTexture * | diffuse() const |
void | setDiffuse(Qt3DRender::QAbstractTexture *diffuse) |
Benachrichtigungssignal:
void | diffuseChanged(Qt3DRender::QAbstractTexture *diffuse) |
shininess : float
Enthält den aktuellen Glanzgrad als Fließkommawert.
Zugriffsfunktionen:
float | shininess() const |
void | setShininess(float shininess) |
Benachrichtigungssignal:
void | shininessChanged(float shininess) |
specular : QColor
Enthält die aktuelle Spiegelfarbe.
Zugriffsfunktionen:
QColor | specular() const |
void | setSpecular(const QColor &specular) |
Benachrichtigungssignal:
void | specularChanged(const QColor &specular) |
textureScale : float
Enthält den aktuellen Texturmaßstab. Sie wird als Multiplikator auf die Texturkoordinaten zur Renderzeit angewendet. Der Standardwert ist 1.0.
In Verbindung mit QTextureWrapMode::Repeat bietet textureScale eine einfache Möglichkeit, eine Textur über eine Fläche zu kacheln. Zum Beispiel würde eine Texturskala von 4.0
zu 16 (4x4) Kacheln führen.
Zugriffsfunktionen:
float | textureScale() const |
void | setTextureScale(float textureScale) |
Benachrichtigungssignal:
void | textureScaleChanged(float textureScale) |
Member Function Dokumentation
[explicit]
QDiffuseMapMaterial::QDiffuseMapMaterial(Qt3DCore::QNode *parent = nullptr)
Konstruiert eine neue QDiffuseMapMaterial-Instanz mit dem übergeordneten Objekt parent.
[virtual noexcept]
QDiffuseMapMaterial::~QDiffuseMapMaterial()
Zerstört die Instanz QDiffuseMapMaterial.
© 2025 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.