QDiffuseSpecularMaterial Class
(Qt3DExtras::QDiffuseSpecularMaterial)The QDiffuseSpecularMaterial class provides a default implementation of the phong lighting effect. More...
Header: | #include <QDiffuseSpecularMaterial> |
qmake: | QT += 3dextras |
Since: | Qt 5.10 |
Instantiated By: | DiffuseSpecularMaterial |
Inherits: | Qt3DRender::QMaterial |
Properties
|
|
- 1 property inherited from Qt3DRender::QMaterial
- 1 property inherited from Qt3DCore::QComponent
- 3 properties inherited from Qt3DCore::QNode
- 1 property inherited from QObject
Public Functions
QDiffuseSpecularMaterial(Qt3DCore::QNode *parent = nullptr) | |
virtual | ~QDiffuseSpecularMaterial() |
QColor | ambient() const |
QVariant | diffuse() const |
bool | isAlphaBlendingEnabled() const |
QVariant | normal() const |
float | shininess() const |
QVariant | specular() const |
float | textureScale() const |
- 4 public functions inherited from Qt3DRender::QMaterial
- 2 public functions inherited from Qt3DCore::QComponent
- 13 public functions inherited from Qt3DCore::QNode
- 31 public functions inherited from QObject
Public Slots
void | setAlphaBlendingEnabled(bool enabled) |
void | setAmbient(const QColor &ambient) |
void | setDiffuse(const QVariant &diffuse) |
void | setNormal(const QVariant &normal) |
void | setShininess(float shininess) |
void | setSpecular(const QVariant &specular) |
void | setTextureScale(float textureScale) |
- 1 public slot inherited from Qt3DRender::QMaterial
- 1 public slot inherited from Qt3DCore::QComponent
- 3 public slots inherited from Qt3DCore::QNode
- 1 public slot inherited from QObject
Signals
void | alphaBlendingEnabledChanged(bool enabled) |
void | ambientChanged(const QColor &ambient) |
void | diffuseChanged(const QVariant &diffuse) |
void | normalChanged(const QVariant &normal) |
void | shininessChanged(float shininess) |
void | specularChanged(const QVariant &specular) |
void | textureScaleChanged(float textureScale) |
- 1 signal inherited from Qt3DRender::QMaterial
- 3 signals inherited from Qt3DCore::QComponent
- 4 signals inherited from Qt3DCore::QNode
- 2 signals inherited from QObject
Static Public Members
const QMetaObject | staticMetaObject |
- 9 static public members inherited from QObject
Additional Inherited Members
- 2 protected functions inherited from Qt3DCore::QNode
- 9 protected functions inherited from QObject
Detailed Description
The QDiffuseSpecularMaterial class provides a default implementation of the phong lighting effect.
The phong lighting effect is based on the combination of 3 lighting components ambient, diffuse and specular. The relative strengths of these components are controlled by means of their reflectivity coefficients which are modelled as RGB triplets:
- Ambient is the color that is emitted by an object without any other light source.
- Diffuse is the color that is emitted for rought surface reflections with the lights.
- Specular is the color emitted for shiny surface reflections with the lights.
- The shininess of a surface is controlled by a float property.
This material uses an effect with a single render pass approach and performs per fragment lighting. Techniques are provided for OpenGL 2, OpenGL 3 or above as well as OpenGL ES 2.
Property Documentation
alphaBlending : bool
Indicates if the alpha information coming from the diffuse property will be taken into account during rendering. Defaults to false.
Access functions:
bool | isAlphaBlendingEnabled() const |
void | setAlphaBlendingEnabled(bool enabled) |
Notifier signal:
void | alphaBlendingEnabledChanged(bool enabled) |
ambient : QColor
Holds the ambient color that is emitted by an object without any other light source.
Access functions:
QColor | ambient() const |
void | setAmbient(const QColor &ambient) |
Notifier signal:
void | ambientChanged(const QColor &ambient) |
diffuse : QVariant
Holds the diffuse color of the material that is emitted for rough surface reflections with the lights. This can be either a plain color value or a texture.
Access functions:
QVariant | diffuse() const |
void | setDiffuse(const QVariant &diffuse) |
Notifier signal:
void | diffuseChanged(const QVariant &diffuse) |
normal : QVariant
Holds the current normal map texture of the material. This can only be a texture, otherwise it is ignored. By default this map is not set.
Access functions:
QVariant | normal() const |
void | setNormal(const QVariant &normal) |
Notifier signal:
void | normalChanged(const QVariant &normal) |
shininess : float
Holds the shininess exponent. Higher values of shininess result in a smaller and brighter highlight.
Defaults to 150.0.
Access functions:
float | shininess() const |
void | setShininess(float shininess) |
Notifier signal:
void | shininessChanged(float shininess) |
specular : QVariant
Holds the specular color of the material that is emitted for shiny surface reflections with the lights. This can be either a plain color value or a texture.
Access functions:
QVariant | specular() const |
void | setSpecular(const QVariant &specular) |
Notifier signal:
void | specularChanged(const QVariant &specular) |
textureScale : float
Holds the current texture scale. It is applied as a multiplier to texture coordinates at render time. Defaults to 1.0.
Access functions:
float | textureScale() const |
void | setTextureScale(float textureScale) |
Notifier signal:
void | textureScaleChanged(float textureScale) |
Member Function Documentation
QDiffuseSpecularMaterial::QDiffuseSpecularMaterial(Qt3DCore::QNode *parent = nullptr)
Constructs a new QDiffuseSpecularMaterial instance with parent object parent.
[virtual]
QDiffuseSpecularMaterial::~QDiffuseSpecularMaterial()
Destroys the QDiffuseSpecularMaterial.
© The Qt Company Ltd
Licensed under the GNU Free Documentation License, Version 1.3.
https://doc.qt.io/qt-5.12/qt3dextras-qdiffusespecularmaterial.html