diff --git a/jme3-core/src/main/resources/Common/ShaderLib/GLSLCompat.glsllib b/jme3-core/src/main/resources/Common/ShaderLib/GLSLCompat.glsllib index 697db195d..180559562 100644 --- a/jme3-core/src/main/resources/Common/ShaderLib/GLSLCompat.glsllib +++ b/jme3-core/src/main/resources/Common/ShaderLib/GLSLCompat.glsllib @@ -42,4 +42,42 @@ out vec4 outFragColor; # define isnan(val) !(val<0.0||val>0.0||val==0.0) #endif +#if __VERSION__ == 110 +mat3 mat3_sub(mat4 m) { + return mat3(m[0].xyz, m[1].xyz, m[2].xyz); +} +#else + #define mat3_sub mat3 +#endif + +#if __VERSION__ <= 140 +float determinant(mat2 m) { + return m[0][0] * m[1][1] - m[1][0] * m[0][1]; +} + +float determinant(mat3 m) { + return + m[0][0] * (m[1][1] * m[2][2] - m[1][2] * m[2][1]) + - m[0][1] * (m[1][0] * m[2][2] - m[1][2] * m[2][0]) + + m[0][2] * (m[1][0] * m[2][1] - m[1][1] * m[2][0]); +} +#endif + +#if __VERSION__ <= 130 +mat2 inverse(mat2 m) { + return mat2(m[1][1], -m[0][1], -m[1][0], m[0][0]) / determinant(m); +} + +mat3 inverse(mat3 m) { + return mat3( + + (m[1][1] * m[2][2] - m[2][1] * m[1][2]), + - (m[1][0] * m[2][2] - m[2][0] * m[1][2]), + + (m[1][0] * m[2][1] - m[2][0] * m[1][1]), + - (m[0][1] * m[2][2] - m[2][1] * m[0][2]), + + (m[0][0] * m[2][2] - m[2][0] * m[0][2]), + - (m[0][0] * m[2][1] - m[2][0] * m[0][1]), + + (m[0][1] * m[1][2] - m[1][1] * m[0][2]), + - (m[0][0] * m[1][2] - m[1][0] * m[0][2]), + + (m[0][0] * m[1][1] - m[1][0] * m[0][1])) / determinant(m); +} +#endif diff --git a/jme3-core/src/main/resources/Common/ShaderLib/PBR.glsllib b/jme3-core/src/main/resources/Common/ShaderLib/PBR.glsllib index 692dd8619..d27c0222f 100644 --- a/jme3-core/src/main/resources/Common/ShaderLib/PBR.glsllib +++ b/jme3-core/src/main/resources/Common/ShaderLib/PBR.glsllib @@ -143,12 +143,9 @@ float renderProbe(vec3 viewDir, vec3 worldPos, vec3 normal, vec3 norm, float Rou if(lightProbeData[0][3] != 0.0){ // oriented box probe - mat3 wToLocalRot; - wToLocalRot[0].xyz = lightProbeData[0].xyz; - wToLocalRot[1].xyz = lightProbeData[1].xyz; - wToLocalRot[2].xyz = lightProbeData[2].xyz; + // mat3_sub our compat wrapper for mat3(mat4) + mat3 wToLocalRot = inverse(mat3_sub(lightProbeData)); - wToLocalRot = inverse(wToLocalRot); vec3 scale = vec3(lightProbeData[0][3], lightProbeData[1][3], lightProbeData[2][3]); #if NB_PROBES >= 2 // probe blending