QNormalDiffuseSpecularMapMaterial Class

(Qt3DRender::QNormalDiffuseSpecularMapMaterial)

The QNormalDiffuseSpecularMapMaterial provides a default implementation of the phong lighting and bump effect where the diffuse and specular light components are read from texture maps and the normals of the mesh being rendered from a normal texture map. More...

Header: #include <QNormalDiffuseSpecularMapMaterial>
qmake: QT += 3drender
Since: Qt 5.5
Inherits: Qt3DRender::QMaterial

Properties

  • ambient : QColor
  • diffuse : Qt3DRender::QAbstractTextureProvider *
  • normal : Qt3DRender::QAbstractTextureProvider *

Public Functions

QNormalDiffuseSpecularMapMaterial(Qt3DCore::QNode *parent = Q_NULLPTR)
~QNormalDiffuseSpecularMapMaterial()
QColor ambient() const
QAbstractTextureProvider * diffuse() const
QAbstractTextureProvider * normal() const
float shininess() const
QAbstractTextureProvider * specular() const
float textureScale() const

Public Slots

void setAmbient(const QColor &ambient)
void setDiffuse(QAbstractTextureProvider *diffuse)
void setNormal(QAbstractTextureProvider *normal)
void setShininess(float shininess)
void setSpecular(QAbstractTextureProvider *specular)
void setTextureScale(float textureScale)

Signals

void ambientChanged(const QColor &ambient)
void diffuseChanged(QAbstractTextureProvider *diffuse)
void normalChanged(QAbstractTextureProvider *normal)
void shininessChanged(float shininess)
void specularChanged(QAbstractTextureProvider *specular)
void textureScaleChanged(float textureScale)

Protected Functions

QNormalDiffuseSpecularMapMaterial(QNormalDiffuseSpecularMapMaterialPrivate &dd, Qt3DCore::QNode *parent = Q_NULLPTR)

Additional Inherited Members

Detailed Description

The QNormalDiffuseSpecularMapMaterial provides a default implementation of the phong lighting and bump effect where the diffuse and specular light components are read from texture maps and the normals of the mesh being rendered from a normal texture map.

The specular lighting effect is based on the combination of 3 lighting components ambient, diffuse and specular. The relative strengths of these components is 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

ambient : QColor

Holds the current ambient color.

Access functions:

QColor ambient() const
void setAmbient(const QColor &ambient)

Notifier signal:

void ambientChanged(const QColor &ambient)

diffuse : Qt3DRender::QAbstractTextureProvider *

Holds the current diffuse map texture.

By default, the diffuse texture has the following properties:

  • Linear minification and magnification filters
  • Linear mipmap with mipmapping enabled
  • Repeat wrap mode
  • Maximum anisotropy of 16.0

Access functions:

QAbstractTextureProvider * diffuse() const
void setDiffuse(QAbstractTextureProvider *diffuse)

Notifier signal:

void diffuseChanged(QAbstractTextureProvider *diffuse)

normal : Qt3DRender::QAbstractTextureProvider *

Holds the current normal map texture.

By default, the normal texture has the following properties:

  • Linear minification and magnification filters
  • Repeat wrap mode
  • Maximum anisotropy of 16.0

Access functions:

QAbstractTextureProvider * normal() const
void setNormal(QAbstractTextureProvider *normal)

Notifier signal:

void normalChanged(QAbstractTextureProvider *normal)

shininess : float

Holds the current shininess as a float value.

Access functions:

float shininess() const
void setShininess(float shininess)

Notifier signal:

void shininessChanged(float shininess)

specular : Qt3DRender::QAbstractTextureProvider *

Holds the current specular map texture.

By default, the specular texture has the following properties:

  • Linear minification and magnification filters
  • Linear mipmap with mipmapping enabled
  • Repeat wrap mode
  • Maximum anisotropy of 16.0

Access functions:

QAbstractTextureProvider * specular() const
void setSpecular(QAbstractTextureProvider *specular)

Notifier signal:

void specularChanged(QAbstractTextureProvider *specular)

textureScale : float

Holds the current texture scale as a float value.

Access functions:

float textureScale() const
void setTextureScale(float textureScale)

Notifier signal:

void textureScaleChanged(float textureScale)

Member Function Documentation

QNormalDiffuseSpecularMapMaterial::QNormalDiffuseSpecularMapMaterial(Qt3DCore::QNode *parent = Q_NULLPTR)

Default constructs an instance of QNormalDiffuseSpecularMapMaterial.

[protected] QNormalDiffuseSpecularMapMaterial::QNormalDiffuseSpecularMapMaterial(QNormalDiffuseSpecularMapMaterialPrivate &dd, Qt3DCore::QNode *parent = Q_NULLPTR)

Copy constructor.

QNormalDiffuseSpecularMapMaterial::~QNormalDiffuseSpecularMapMaterial()

Destroys the Qt3DRender::QNormalDiffuseSpecularMapMaterial instance.

© The Qt Company Ltd
Licensed under the GNU Free Documentation License, Version 1.3.
https://doc.qt.io/archives/qt-5.6/qt3drender-qnormaldiffusespecularmapmaterial.html