mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0026070: Ray tracing with reflections is poor on rotated presentation
Test case for issue CR26070
This commit is contained in:
parent
1d19db8dad
commit
cf537aacf7
@ -927,7 +927,13 @@ vec4 Radiance (in SRay theRay, in vec3 theInverse)
|
|||||||
return vec4 (aResult.xyz + aWeight.xyz * aColor.xyz, aWeight.w * aColor.w);
|
return vec4 (aResult.xyz + aWeight.xyz * aColor.xyz, aWeight.w * aColor.w);
|
||||||
}
|
}
|
||||||
|
|
||||||
aHit.Normal = normalize (aHit.Normal);
|
vec3 aInvTransf0 = texelFetch (uSceneTransformTexture, anObjectId * 4 + 0).xyz;
|
||||||
|
vec3 aInvTransf1 = texelFetch (uSceneTransformTexture, anObjectId * 4 + 1).xyz;
|
||||||
|
vec3 aInvTransf2 = texelFetch (uSceneTransformTexture, anObjectId * 4 + 2).xyz;
|
||||||
|
|
||||||
|
aHit.Normal = normalize (vec3 (dot (aInvTransf0, aHit.Normal),
|
||||||
|
dot (aInvTransf1, aHit.Normal),
|
||||||
|
dot (aInvTransf2, aHit.Normal)));
|
||||||
|
|
||||||
// For polygons that are parallel to the screen plane, the depth slope
|
// For polygons that are parallel to the screen plane, the depth slope
|
||||||
// is equal to 1, resulting in small polygon offset. For polygons that
|
// is equal to 1, resulting in small polygon offset. For polygons that
|
||||||
@ -946,10 +952,6 @@ vec4 Radiance (in SRay theRay, in vec3 theInverse)
|
|||||||
|
|
||||||
theRay.Origin += theRay.Direct * aHit.Time; // intersection point
|
theRay.Origin += theRay.Direct * aHit.Time; // intersection point
|
||||||
|
|
||||||
vec3 aInvTransf0 = texelFetch (uSceneTransformTexture, anObjectId * 4 + 0).xyz;
|
|
||||||
vec3 aInvTransf1 = texelFetch (uSceneTransformTexture, anObjectId * 4 + 1).xyz;
|
|
||||||
vec3 aInvTransf2 = texelFetch (uSceneTransformTexture, anObjectId * 4 + 2).xyz;
|
|
||||||
|
|
||||||
vec3 aNormal = SmoothNormal (aHit.UV, aTriIndex);
|
vec3 aNormal = SmoothNormal (aHit.UV, aTriIndex);
|
||||||
|
|
||||||
aNormal = normalize (vec3 (dot (aInvTransf0, aNormal),
|
aNormal = normalize (vec3 (dot (aInvTransf0, aNormal),
|
||||||
|
70
tests/v3d/raytrace/bug26070
Executable file
70
tests/v3d/raytrace/bug26070
Executable file
@ -0,0 +1,70 @@
|
|||||||
|
puts "============"
|
||||||
|
puts "OCC26070"
|
||||||
|
puts "============"
|
||||||
|
puts ""
|
||||||
|
#########################################################################
|
||||||
|
# Ray tracing with reflections is poor on rotated presentation
|
||||||
|
#########################################################################
|
||||||
|
|
||||||
|
#source samples/tcl/cad.tc
|
||||||
|
# make base
|
||||||
|
box b0 0 0 0 12 7 6
|
||||||
|
explode b0 e
|
||||||
|
blend b01 b0 1 b0_8
|
||||||
|
blend b02 b01 1 b0_6
|
||||||
|
|
||||||
|
# make cut at bottom
|
||||||
|
box b1 3 -1 0 2 9 1.5
|
||||||
|
bcut b2 b02 b1
|
||||||
|
explode b2 e
|
||||||
|
blend b3 b2 1 b2_27
|
||||||
|
blend b4 b3 1 b2_30
|
||||||
|
|
||||||
|
# make central cut
|
||||||
|
box h1 3 -1 2.5 2 9 0.5
|
||||||
|
box h2 3 -1 3 2 9 2
|
||||||
|
plane p 4 -1 3 0 1 0
|
||||||
|
pcylinder c p 1 9
|
||||||
|
bcommon h3 h2 c
|
||||||
|
bcut b5 b4 h1
|
||||||
|
bcut b6 b5 h3
|
||||||
|
|
||||||
|
# make side cut
|
||||||
|
box b7 9 -1 1 2 9 4
|
||||||
|
explode b7 e
|
||||||
|
blend b71 b7 1 b7_6
|
||||||
|
blend b72 b71 1 b7_8
|
||||||
|
bcut b8 b6 b72
|
||||||
|
|
||||||
|
# make box for inner cylindrical cut
|
||||||
|
box bc1 -1 0 2 9 1 4
|
||||||
|
box bc2 2 -1 2 4 3 3
|
||||||
|
bcut bc3 bc1 bc2
|
||||||
|
explode bc3 e
|
||||||
|
blend bc4 bc3 1 bc3_20
|
||||||
|
blend bc5 bc4 1 bc3_23
|
||||||
|
blend bc6 bc5 1.99 bc3_21
|
||||||
|
blend bc7 bc6 1.99 bc3_22
|
||||||
|
|
||||||
|
# make inner cylindrical cut
|
||||||
|
explode bc7 f
|
||||||
|
revol r bc7_1 -1 0 6 1 0 0 100
|
||||||
|
bcut b9 b8 r
|
||||||
|
|
||||||
|
# make outer cylindrical cut
|
||||||
|
plane p2 -1 0 6 1 0 0
|
||||||
|
pcylinder c2 p2 6 15
|
||||||
|
bcommon res b9 c2
|
||||||
|
|
||||||
|
# show result
|
||||||
|
#donly res
|
||||||
|
trotate res 0 0 0 0 0 1 90
|
||||||
|
#vinit
|
||||||
|
vdisplay res
|
||||||
|
vsetdispmode 1
|
||||||
|
#vshowfaceboundary res 1 255 255 255
|
||||||
|
vfit
|
||||||
|
|
||||||
|
vrenderparams -rayTrace -reflections
|
||||||
|
vlocrotate res 0 0 0 0 0 1 180
|
||||||
|
vfit
|
Loading…
x
Reference in New Issue
Block a user