mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0027943: Visualization - fix broken shading by positional light for object with local transformation
OpenGl_ShaderManager, per-vertex shading and per-fragment shading - do not apply model-world matrix on the light sources which are expected to be defined in world-space.
This commit is contained in:
parent
bd6a845441
commit
5f4bd4d4d2
@ -83,7 +83,7 @@ const char THE_FUNC_pointLight[] =
|
|||||||
EOL" vec3 aLight = occLight_Position (theId).xyz;"
|
EOL" vec3 aLight = occLight_Position (theId).xyz;"
|
||||||
EOL" if (occLight_IsHeadlight (theId) == 0)"
|
EOL" if (occLight_IsHeadlight (theId) == 0)"
|
||||||
EOL" {"
|
EOL" {"
|
||||||
EOL" aLight = vec3 (occWorldViewMatrix * occModelWorldMatrix * vec4 (aLight, 1.0));"
|
EOL" aLight = vec3 (occWorldViewMatrix * vec4 (aLight, 1.0));"
|
||||||
EOL" }"
|
EOL" }"
|
||||||
EOL" aLight -= thePoint;"
|
EOL" aLight -= thePoint;"
|
||||||
EOL
|
EOL
|
||||||
@ -121,8 +121,8 @@ const char THE_FUNC_spotLight[] =
|
|||||||
EOL" vec3 aSpotDir = occLight_SpotDirection (theId).xyz;"
|
EOL" vec3 aSpotDir = occLight_SpotDirection (theId).xyz;"
|
||||||
EOL" if (occLight_IsHeadlight (theId) == 0)"
|
EOL" if (occLight_IsHeadlight (theId) == 0)"
|
||||||
EOL" {"
|
EOL" {"
|
||||||
EOL" aLight = vec3 (occWorldViewMatrix * occModelWorldMatrix * vec4 (aLight, 1.0));"
|
EOL" aLight = vec3 (occWorldViewMatrix * vec4 (aLight, 1.0));"
|
||||||
EOL" aSpotDir = vec3 (occWorldViewMatrix * occModelWorldMatrix * vec4 (aSpotDir, 0.0));"
|
EOL" aSpotDir = vec3 (occWorldViewMatrix * vec4 (aSpotDir, 0.0));"
|
||||||
EOL" }"
|
EOL" }"
|
||||||
EOL" aLight -= thePoint;"
|
EOL" aLight -= thePoint;"
|
||||||
EOL
|
EOL
|
||||||
@ -171,7 +171,7 @@ const char THE_FUNC_directionalLight[] =
|
|||||||
EOL" vec3 aLight = normalize (occLight_Position (theId).xyz);"
|
EOL" vec3 aLight = normalize (occLight_Position (theId).xyz);"
|
||||||
EOL" if (occLight_IsHeadlight (theId) == 0)"
|
EOL" if (occLight_IsHeadlight (theId) == 0)"
|
||||||
EOL" {"
|
EOL" {"
|
||||||
EOL" aLight = vec3 (occWorldViewMatrix * occModelWorldMatrix * vec4 (aLight, 0.0));"
|
EOL" aLight = vec3 (occWorldViewMatrix * vec4 (aLight, 0.0));"
|
||||||
EOL" }"
|
EOL" }"
|
||||||
EOL
|
EOL
|
||||||
EOL" vec3 aHalf = normalize (aLight + theView);"
|
EOL" vec3 aHalf = normalize (aLight + theView);"
|
||||||
@ -200,7 +200,7 @@ const char THE_FUNC_directionalLightFirst[] =
|
|||||||
EOL" vec3 aLight = normalize (occLightSources[1].xyz);"
|
EOL" vec3 aLight = normalize (occLightSources[1].xyz);"
|
||||||
EOL" if (occLight_IsHeadlight (0) == 0)"
|
EOL" if (occLight_IsHeadlight (0) == 0)"
|
||||||
EOL" {"
|
EOL" {"
|
||||||
EOL" aLight = vec3 (occWorldViewMatrix * occModelWorldMatrix * vec4 (aLight, 0.0));"
|
EOL" aLight = vec3 (occWorldViewMatrix * vec4 (aLight, 0.0));"
|
||||||
EOL" }"
|
EOL" }"
|
||||||
EOL
|
EOL
|
||||||
EOL" vec3 aHalf = normalize (aLight + theView);"
|
EOL" vec3 aHalf = normalize (aLight + theView);"
|
||||||
|
@ -31,7 +31,7 @@ void pointLight (in int theId,
|
|||||||
vec3 aLight = occLight_Position (theId).xyz;
|
vec3 aLight = occLight_Position (theId).xyz;
|
||||||
if (occLight_IsHeadlight (theId) == 0)
|
if (occLight_IsHeadlight (theId) == 0)
|
||||||
{
|
{
|
||||||
aLight = vec3 (occWorldViewMatrix * occModelWorldMatrix * vec4 (aLight, 1.0));
|
aLight = vec3 (occWorldViewMatrix * vec4 (aLight, 1.0));
|
||||||
}
|
}
|
||||||
aLight -= thePoint;
|
aLight -= thePoint;
|
||||||
|
|
||||||
@ -67,8 +67,8 @@ void spotLight (in int theId,
|
|||||||
vec3 aSpotDir = occLight_SpotDirection (theId).xyz;
|
vec3 aSpotDir = occLight_SpotDirection (theId).xyz;
|
||||||
if (occLight_IsHeadlight (theId) == 0)
|
if (occLight_IsHeadlight (theId) == 0)
|
||||||
{
|
{
|
||||||
aLight = vec3 (occWorldViewMatrix * occModelWorldMatrix * vec4 (aLight, 1.0));
|
aLight = vec3 (occWorldViewMatrix * vec4 (aLight, 1.0));
|
||||||
aSpotDir = vec3 (occWorldViewMatrix * occModelWorldMatrix * vec4 (aSpotDir, 0.0));
|
aSpotDir = vec3 (occWorldViewMatrix * vec4 (aSpotDir, 0.0));
|
||||||
}
|
}
|
||||||
aLight -= thePoint;
|
aLight -= thePoint;
|
||||||
|
|
||||||
@ -116,7 +116,7 @@ void directionalLight (in int theId,
|
|||||||
vec3 aLight = normalize (occLight_Position (theId).xyz);
|
vec3 aLight = normalize (occLight_Position (theId).xyz);
|
||||||
if (occLight_IsHeadlight (theId) == 0)
|
if (occLight_IsHeadlight (theId) == 0)
|
||||||
{
|
{
|
||||||
aLight = vec3 (occWorldViewMatrix * occModelWorldMatrix * vec4 (aLight, 0.0));
|
aLight = vec3 (occWorldViewMatrix * vec4 (aLight, 0.0));
|
||||||
}
|
}
|
||||||
|
|
||||||
vec3 aHalf = normalize (aLight + theView);
|
vec3 aHalf = normalize (aLight + theView);
|
||||||
|
45
tests/v3d/glsl/gouraud_pos1
Normal file
45
tests/v3d/glsl/gouraud_pos1
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
puts "========"
|
||||||
|
puts "Per-vertex lighting using built-in GLSL program, one positional light source."
|
||||||
|
puts "Visual comparison with the reference snapshot should be performed for this test case."
|
||||||
|
puts "========"
|
||||||
|
|
||||||
|
# create objects
|
||||||
|
set anX 0.001
|
||||||
|
circle c 0 0 0 0.001
|
||||||
|
mkedge e c
|
||||||
|
wire w e
|
||||||
|
plane s
|
||||||
|
mkface f1 s w
|
||||||
|
mkface f2 s w
|
||||||
|
ttranslate f1 $anX -0.001 0
|
||||||
|
|
||||||
|
# display objects
|
||||||
|
vtop
|
||||||
|
vdisplay -dispMode 1 f1 f2
|
||||||
|
vsetlocation f2 $anX 0.001 0
|
||||||
|
vpoint vl $anX 0 0.001
|
||||||
|
vfit
|
||||||
|
|
||||||
|
# setup light
|
||||||
|
vcaps -ffp 0
|
||||||
|
vrenderparams -shadingModel vert
|
||||||
|
vlight clear
|
||||||
|
vlight add positional pos $anX 0 0.001 color RED1 headLight 0
|
||||||
|
|
||||||
|
set aColor1 [vreadpixel 205 180 rgb name]
|
||||||
|
set aColor2 [vreadpixel 205 210 rgb name]
|
||||||
|
if { "$aColor1" != "RED" || "$aColor2" != "RED" } {
|
||||||
|
puts "Error: expected color near the light spot is RED"
|
||||||
|
}
|
||||||
|
|
||||||
|
set aColor3 [vreadpixel 205 132 rgb name]
|
||||||
|
set aColor4 [vreadpixel 205 280 rgb name]
|
||||||
|
if { "$aColor3" != "RED3" || "$aColor4" != "RED4" } {
|
||||||
|
puts "Error: expected color mid from the light spot is RED4"
|
||||||
|
}
|
||||||
|
|
||||||
|
set aColor5 [vreadpixel 205 100 rgb name]
|
||||||
|
set aColor6 [vreadpixel 205 306 rgb name]
|
||||||
|
if { "$aColor5" != "RED4" || "$aColor6" != "RED4" } {
|
||||||
|
puts "Error: expected color far from the light spot is RED4"
|
||||||
|
}
|
45
tests/v3d/glsl/gouraud_spot1
Normal file
45
tests/v3d/glsl/gouraud_spot1
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
puts "========"
|
||||||
|
puts "Per-vertex lighting using built-in GLSL program, one spot light source."
|
||||||
|
puts "Visual comparison with the reference snapshot should be performed for this test case."
|
||||||
|
puts "========"
|
||||||
|
|
||||||
|
# create objects
|
||||||
|
set anX 0.001
|
||||||
|
circle c 0 0 0 0.001
|
||||||
|
mkedge e c
|
||||||
|
wire w e
|
||||||
|
plane s
|
||||||
|
mkface f1 s w
|
||||||
|
mkface f2 s w
|
||||||
|
ttranslate f1 $anX -0.001 0
|
||||||
|
|
||||||
|
# display objects
|
||||||
|
vtop
|
||||||
|
vdisplay -dispMode 1 f1 f2
|
||||||
|
vsetlocation f2 $anX 0.001 0
|
||||||
|
vpoint vl $anX 0 0.001
|
||||||
|
vfit
|
||||||
|
|
||||||
|
# setup light
|
||||||
|
vcaps -ffp 0
|
||||||
|
vrenderparams -shadingModel vert
|
||||||
|
vlight clear
|
||||||
|
vlight add spotLight pos $anX 0 0.001 dir 0 0 -1 angle 60 constAtten 0.1 exponent 0.1 color RED1 headLight 0
|
||||||
|
|
||||||
|
set aColor1 [vreadpixel 205 180 rgb name]
|
||||||
|
set aColor2 [vreadpixel 205 220 rgb name]
|
||||||
|
if { "$aColor1" != "RED" || "$aColor2" != "RED" } {
|
||||||
|
puts "Error: expected color near the light spot is RED"
|
||||||
|
}
|
||||||
|
|
||||||
|
set aColor3 [vreadpixel 205 132 rgb name]
|
||||||
|
set aColor4 [vreadpixel 205 280 rgb name]
|
||||||
|
if { "$aColor3" != "RED" || "$aColor4" != "RED4" } {
|
||||||
|
puts "Error: expected color mid from the light spot is RED4"
|
||||||
|
}
|
||||||
|
|
||||||
|
set aColor5 [vreadpixel 205 100 rgb name]
|
||||||
|
set aColor6 [vreadpixel 205 306 rgb name]
|
||||||
|
if { "$aColor5" != "GRAY9" || "$aColor6" != "GRAY9" } {
|
||||||
|
puts "Error: expected color far from the light spot is GRAY9"
|
||||||
|
}
|
45
tests/v3d/glsl/phong_pos1
Normal file
45
tests/v3d/glsl/phong_pos1
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
puts "========"
|
||||||
|
puts "Per-fragment lighting using built-in GLSL program, one positional light source."
|
||||||
|
puts "Visual comparison with the reference snapshot should be performed for this test case."
|
||||||
|
puts "========"
|
||||||
|
|
||||||
|
# create objects
|
||||||
|
set anX 0.001
|
||||||
|
circle c 0 0 0 0.001
|
||||||
|
mkedge e c
|
||||||
|
wire w e
|
||||||
|
plane s
|
||||||
|
mkface f1 s w
|
||||||
|
mkface f2 s w
|
||||||
|
ttranslate f1 $anX -0.001 0
|
||||||
|
|
||||||
|
# display objects
|
||||||
|
vtop
|
||||||
|
vdisplay -dispMode 1 f1 f2
|
||||||
|
vsetlocation f2 $anX 0.001 0
|
||||||
|
vpoint vl $anX 0 0.001
|
||||||
|
vfit
|
||||||
|
|
||||||
|
# setup light
|
||||||
|
vcaps -ffp 0
|
||||||
|
vrenderparams -shadingModel phong
|
||||||
|
vlight clear
|
||||||
|
vlight add positional pos $anX 0 0.001 color RED1 headLight 0
|
||||||
|
|
||||||
|
set aColor1 [vreadpixel 205 180 rgb name]
|
||||||
|
set aColor2 [vreadpixel 205 220 rgb name]
|
||||||
|
if { "$aColor1" != "RED" || "$aColor2" != "RED" } {
|
||||||
|
puts "Error: expected color near the light spot is RED"
|
||||||
|
}
|
||||||
|
|
||||||
|
set aColor3 [vreadpixel 205 132 rgb name]
|
||||||
|
set aColor4 [vreadpixel 205 280 rgb name]
|
||||||
|
if { "$aColor3" != "RED4" || "$aColor4" != "RED4" } {
|
||||||
|
puts "Error: expected color mid from the light spot is RED4"
|
||||||
|
}
|
||||||
|
|
||||||
|
set aColor5 [vreadpixel 205 100 rgb name]
|
||||||
|
set aColor6 [vreadpixel 205 306 rgb name]
|
||||||
|
if { "$aColor5" != "RED4" || "$aColor6" != "RED4" } {
|
||||||
|
puts "Error: expected color far from the light spot is RED4"
|
||||||
|
}
|
45
tests/v3d/glsl/phong_spot1
Normal file
45
tests/v3d/glsl/phong_spot1
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
puts "========"
|
||||||
|
puts "Per-fragment lighting using built-in GLSL program, one spot light source."
|
||||||
|
puts "Visual comparison with the reference snapshot should be performed for this test case."
|
||||||
|
puts "========"
|
||||||
|
|
||||||
|
# create objects
|
||||||
|
set anX 0.001
|
||||||
|
circle c 0 0 0 0.001
|
||||||
|
mkedge e c
|
||||||
|
wire w e
|
||||||
|
plane s
|
||||||
|
mkface f1 s w
|
||||||
|
mkface f2 s w
|
||||||
|
ttranslate f1 $anX -0.001 0
|
||||||
|
|
||||||
|
# display objects
|
||||||
|
vtop
|
||||||
|
vdisplay -dispMode 1 f1 f2
|
||||||
|
vsetlocation f2 $anX 0.001 0
|
||||||
|
vpoint vl $anX 0 0.001
|
||||||
|
vfit
|
||||||
|
|
||||||
|
# setup light
|
||||||
|
vcaps -ffp 0
|
||||||
|
vrenderparams -shadingModel phong
|
||||||
|
vlight clear
|
||||||
|
vlight add spotLight pos $anX 0 0.001 dir 0 0 -1 angle 60 constAtten 0.1 exponent 0.1 color RED1 headLight 0
|
||||||
|
|
||||||
|
set aColor1 [vreadpixel 205 180 rgb name]
|
||||||
|
set aColor2 [vreadpixel 205 220 rgb name]
|
||||||
|
if { "$aColor1" != "RED" || "$aColor2" != "RED" } {
|
||||||
|
puts "Error: expected color near the light spot is RED"
|
||||||
|
}
|
||||||
|
|
||||||
|
set aColor3 [vreadpixel 205 132 rgb name]
|
||||||
|
set aColor4 [vreadpixel 205 280 rgb name]
|
||||||
|
if { "$aColor3" != "RED4" || "$aColor4" != "RED4" } {
|
||||||
|
puts "Error: expected color mid from the light spot is RED4"
|
||||||
|
}
|
||||||
|
|
||||||
|
set aColor5 [vreadpixel 205 100 rgb name]
|
||||||
|
set aColor6 [vreadpixel 205 306 rgb name]
|
||||||
|
if { "$aColor5" != "GRAY2" || "$aColor6" != "GRAY2" } {
|
||||||
|
puts "Error: expected color far from the light spot is GRAY2"
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user