adjust light functionality,
bugs: - background cannot be changed during runtime
This commit is contained in:
parent
a521dfc292
commit
4c177f2ddc
|
@ -38,7 +38,7 @@ private:
|
||||||
} m_rotDirections;
|
} m_rotDirections;
|
||||||
|
|
||||||
struct {
|
struct {
|
||||||
QVector3D position = { 10,10,10 };
|
QVector3D position = { 1,1,1 };
|
||||||
QVector3D intensities = { 1,0.25,0.25 };
|
QVector3D intensities = { 1,0.25,0.25 };
|
||||||
} m_light;
|
} m_light;
|
||||||
|
|
||||||
|
@ -50,7 +50,7 @@ private:
|
||||||
QQuaternion m_rotation;
|
QQuaternion m_rotation;
|
||||||
|
|
||||||
bool m_wireframe = false;
|
bool m_wireframe = false;
|
||||||
bool m_lightOn = true;
|
bool m_lightOn = false;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void mousePressEvent(QMouseEvent *e) Q_DECL_OVERRIDE;
|
void mousePressEvent(QMouseEvent *e) Q_DECL_OVERRIDE;
|
||||||
|
@ -68,6 +68,7 @@ protected:
|
||||||
private:
|
private:
|
||||||
void initShaders();
|
void initShaders();
|
||||||
void setConnections();
|
void setConnections();
|
||||||
|
void updateLightPosition();
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void resetView();
|
void resetView();
|
||||||
|
@ -75,5 +76,6 @@ private slots:
|
||||||
public slots:
|
public slots:
|
||||||
void changeDirection(int direction);
|
void changeDirection(int direction);
|
||||||
void toggleWireframe();
|
void toggleWireframe();
|
||||||
|
void toggleLight();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -19,5 +19,6 @@
|
||||||
<file>Z.png</file>
|
<file>Z.png</file>
|
||||||
<file>screenshot.png</file>
|
<file>screenshot.png</file>
|
||||||
<file>wireframe.png</file>
|
<file>wireframe.png</file>
|
||||||
|
<file>light.png</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
||||||
|
|
|
@ -8,6 +8,7 @@ left mouse - rotate
|
||||||
right mouse - move
|
right mouse - move
|
||||||
scroll - zoom
|
scroll - zoom
|
||||||
space - reset view
|
space - reset view
|
||||||
|
L - set light to current position
|
||||||
esc - close
|
esc - close
|
||||||
|
|
||||||
using the X, Y, Z Button you can activate/deactivate the rotating directions
|
using the X, Y, Z Button you can activate/deactivate the rotating directions
|
||||||
|
|
|
@ -15,40 +15,41 @@ uniform struct Light {
|
||||||
uniform bool b_transparent;
|
uniform bool b_transparent;
|
||||||
uniform bool b_light;
|
uniform bool b_light;
|
||||||
|
|
||||||
varying vec2 v_texcoord;
|
varying vec2 v_surfaceUV;
|
||||||
varying vec3 v_position;
|
varying vec3 v_surfacePosition;
|
||||||
varying vec3 v_normal;
|
varying vec3 v_surfaceNormal;
|
||||||
|
|
||||||
void main()
|
void main()
|
||||||
{
|
{
|
||||||
// variables
|
// variables
|
||||||
float brightness;
|
vec3 diffuse;
|
||||||
|
|
||||||
if(b_light == true)
|
|
||||||
{
|
|
||||||
// calculate normals in worldspace
|
|
||||||
vec3 normal = normalize(n_matrix * v_normal);
|
|
||||||
|
|
||||||
//get the surface - light vector (cause this is a candel)
|
|
||||||
vec3 surfaceToLight = light.position - v_position;
|
|
||||||
|
|
||||||
// calculate the brightness depending on the angle
|
|
||||||
brightness = dot(normal, surfaceToLight) / (length(surfaceToLight) * length(normal));
|
|
||||||
brightness = clamp(brightness, 0, 1);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
brightness = 1;
|
|
||||||
light.intensities = vec3(1,1,1);
|
|
||||||
}
|
|
||||||
|
|
||||||
// get fragment color from texture
|
// get fragment color from texture
|
||||||
vec4 surfaceColor = vec4(texture2D(texture, v_texcoord));
|
vec4 surfaceColor = vec4(texture2D(texture, v_surfaceUV));
|
||||||
|
|
||||||
// if not transparent, ignore alpha value and set it to 1
|
// if not transparent, ignore alpha value and set it to 1
|
||||||
if(!b_transparent)
|
if(!b_transparent)
|
||||||
surfaceColor.a = 1.0f;
|
surfaceColor.a = 1.0f;
|
||||||
|
|
||||||
// pass the data to ogl
|
if(b_light)
|
||||||
gl_FragColor = vec4(brightness * light.intensities * surfaceColor.rgb, surfaceColor.a);
|
{
|
||||||
|
// calculate normals in worldspace
|
||||||
|
vec3 normalWorld = normalize(n_matrix * v_surfaceNormal);
|
||||||
|
|
||||||
|
//get the surface - light vector (cause this is a point light)
|
||||||
|
vec3 surfaceToLight = normalize(light.position - v_surfacePosition);
|
||||||
|
|
||||||
|
// calculate the brightness depending on the angle
|
||||||
|
float diffuseCoefficient = max(0.0, dot(normalWorld, surfaceToLight));
|
||||||
|
|
||||||
|
// result diffuse color
|
||||||
|
diffuse = diffuseCoefficient * surfaceColor.rgb * light.intensities;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
diffuse = surfaceColor.rgb;
|
||||||
|
}
|
||||||
|
|
||||||
|
// put all together
|
||||||
|
gl_FragColor = vec4(diffuse, surfaceColor.a);
|
||||||
}
|
}
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 3.5 KiB |
|
@ -12,9 +12,9 @@ attribute vec4 a_position;
|
||||||
attribute vec2 a_texcoord;
|
attribute vec2 a_texcoord;
|
||||||
attribute vec3 a_normal;
|
attribute vec3 a_normal;
|
||||||
|
|
||||||
varying vec2 v_texcoord;
|
varying vec2 v_surfaceUV;
|
||||||
varying vec3 v_position;
|
varying vec3 v_surfacePosition;
|
||||||
varying vec3 v_normal;
|
varying vec3 v_surfaceNormal;
|
||||||
|
|
||||||
void main()
|
void main()
|
||||||
{
|
{
|
||||||
|
@ -23,7 +23,7 @@ void main()
|
||||||
|
|
||||||
// Pass data to fragment shader
|
// Pass data to fragment shader
|
||||||
// Value will be automatically interpolated to fragments inside polygon faces
|
// Value will be automatically interpolated to fragments inside polygon faces
|
||||||
v_texcoord = a_texcoord;
|
v_surfaceUV = a_texcoord;
|
||||||
v_position = vec3(norm_matrix * m_matrix * a_position);
|
v_surfacePosition = vec3(norm_matrix * m_matrix * a_position);
|
||||||
v_normal = a_normal;
|
v_surfaceNormal = a_normal;
|
||||||
}
|
}
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 3.5 KiB |
|
@ -101,6 +101,12 @@ void MainWindow::setupWidgets()
|
||||||
connect(wireframe, &QAction::triggered, viewer, &OglViewerWidget::toggleWireframe);
|
connect(wireframe, &QAction::triggered, viewer, &OglViewerWidget::toggleWireframe);
|
||||||
ui->mainToolBar->addAction(wireframe);
|
ui->mainToolBar->addAction(wireframe);
|
||||||
|
|
||||||
|
QAction *light = new QAction(QIcon(":/images/toolbar/light.png"), "Light", this);
|
||||||
|
light->setCheckable(true);
|
||||||
|
light->setChecked(false);
|
||||||
|
connect(light, &QAction::triggered, viewer, &OglViewerWidget::toggleLight);
|
||||||
|
ui->mainToolBar->addAction(light);
|
||||||
|
|
||||||
ui->mainToolBar->addSeparator();
|
ui->mainToolBar->addSeparator();
|
||||||
|
|
||||||
QAction *fileInfo = new QAction(QIcon(":/images/toolbar/info.png"), "File info", this);
|
QAction *fileInfo = new QAction(QIcon(":/images/toolbar/info.png"), "File info", this);
|
||||||
|
|
|
@ -173,14 +173,18 @@ void OglViewerWidget::keyPressEvent(QKeyEvent *e)
|
||||||
{
|
{
|
||||||
parentWidget()->close();
|
parentWidget()->close();
|
||||||
}
|
}
|
||||||
|
else if (e->key() == Qt::Key_L)
|
||||||
|
{
|
||||||
|
updateLightPosition();
|
||||||
|
update();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void OglViewerWidget::initializeGL()
|
void OglViewerWidget::initializeGL()
|
||||||
{
|
{
|
||||||
initializeOpenGLFunctions();
|
initializeOpenGLFunctions();
|
||||||
|
|
||||||
//glClearColor(0.5000f, 0.8000f, 1.0000f, 0.0000f);
|
glClearColor(0.5000f, 0.8000f, 1.0000f, 0.0000f);
|
||||||
glClearColor(0.02f, 0.01f, 0.01f, 0.0000f);
|
|
||||||
|
|
||||||
initShaders();
|
initShaders();
|
||||||
|
|
||||||
|
@ -269,6 +273,13 @@ void OglViewerWidget::setConnections()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void OglViewerWidget::updateLightPosition()
|
||||||
|
{
|
||||||
|
QMatrix4x4 rotateBack;
|
||||||
|
rotateBack.rotate(m_rotation.inverted());
|
||||||
|
m_light.position = rotateBack * (-m_translation);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// private slots
|
// private slots
|
||||||
|
@ -305,3 +316,21 @@ void OglViewerWidget::toggleWireframe()
|
||||||
m_wireframe = 1 - m_wireframe;
|
m_wireframe = 1 - m_wireframe;
|
||||||
update();
|
update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void OglViewerWidget::toggleLight()
|
||||||
|
{
|
||||||
|
m_lightOn = 1 - m_lightOn;
|
||||||
|
|
||||||
|
if (m_lightOn)
|
||||||
|
{
|
||||||
|
glClearColor(m_light.intensities.x() / 100, m_light.intensities.y() / 100, m_light.intensities.z() / 100, 0.0000f);
|
||||||
|
|
||||||
|
updateLightPosition();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
glClearColor(0.5000f, 0.8000f, 1.0000f, 0.0000f);
|
||||||
|
}
|
||||||
|
|
||||||
|
update();
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue