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.
© 2019 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.