0030700: Visualization, TKOpenGl - support PBR Metallic-Roughness shading model
[occt.git] / src / Shaders / DeclarationsImpl.glsl
CommitLineData
12381341 1
d95f5ce1 2//! @file DeclarationsImpl.glsl includes implementation of common functions and properties accessors
b17e5bae 3#if defined(FRAGMENT_SHADER)
c40eb6b9 4//! Output color (and coverage for accumulation by OIT algorithm).
b17e5bae 5void occSetFragColor (in vec4 theColor)
6{
c40eb6b9 7#if defined(OCC_ALPHA_TEST)
8 if (theColor.a < occAlphaCutoff) discard;
9#endif
10#if defined(OCC_WRITE_WEIGHT_OIT_COVERAGE)
b17e5bae 11 float aWeight = theColor.a * clamp (1e+2 * pow (1.0 - gl_FragCoord.z * occOitDepthFactor, 3.0), 1e-2, 1e+2);
12 occFragCoverage.r = theColor.a * aWeight;
13 occFragColor = vec4 (theColor.rgb * theColor.a * aWeight, theColor.a);
b17e5bae 14#else
c40eb6b9 15 occFragColor = theColor;
b17e5bae 16#endif
c40eb6b9 17}
b17e5bae 18#endif
19
daf73ab7 20#if defined(THE_MAX_LIGHTS) && (THE_MAX_LIGHTS > 0)
12381341 21// arrays of light sources
8a53d1c4 22uniform vec4 occLightSources[THE_MAX_LIGHTS * 4]; //!< packed light sources parameters
67312b79 23uniform THE_PREC_ENUM ivec2 occLightSourcesTypes[THE_MAX_LIGHTS]; //!< packed light sources types
24#endif
25
26#if defined(THE_IS_PBR)
27vec3 occDiffIBLMap (in vec3 theNormal)
28{
29 vec3 aSHCoeffs[9];
30 for (int i = 0; i < 9; ++i)
31 {
32 aSHCoeffs[i] = occTexture2D (occDiffIBLMapSHCoeffs, vec2 ((float(i) + 0.5) / 9.0, 0.0)).rgb;
33 }
34 return aSHCoeffs[0]
35
36 + aSHCoeffs[1] * theNormal.x
37 + aSHCoeffs[2] * theNormal.y
38 + aSHCoeffs[3] * theNormal.z
39
40 + aSHCoeffs[4] * theNormal.x * theNormal.z
41 + aSHCoeffs[5] * theNormal.y * theNormal.z
42 + aSHCoeffs[6] * theNormal.x * theNormal.y
43
44 + aSHCoeffs[7] * (3.0 * theNormal.z * theNormal.z - 1.0)
45 + aSHCoeffs[8] * (theNormal.x * theNormal.x - theNormal.y * theNormal.y);
46}
daf73ab7 47#endif
12381341 48
67312b79 49// front and back material properties accessors
50#if defined(THE_IS_PBR)
51uniform vec4 occPbrFrontMaterial[3];
52uniform vec4 occPbrBackMaterial[3];
53
54#define MIN_ROUGHNESS 0.01
55// Converts roughness value from range [0, 1] to real value for calculations
56float occRoughness (in float theNormalizedRoughness) { return theNormalizedRoughness * (1.0 - MIN_ROUGHNESS) + MIN_ROUGHNESS; }
57
58vec4 occPBRFrontMaterial_Color(void) { return occPbrFrontMaterial[0]; }
59vec3 occPBRFrontMaterial_Emission(void) { return occPbrFrontMaterial[1].rgb; }
60float occPBRFrontMaterial_IOR(void) { return occPbrFrontMaterial[1].w; }
61float occPBRFrontMaterial_Metallic(void) { return occPbrFrontMaterial[2].b; }
62float occPBRFrontMaterial_Roughness(void) { return occRoughness (occPbrFrontMaterial[2].g); }
63float occPBRFrontMaterial_NormalizedRoughness(void) { return occPbrFrontMaterial[2].g; }
64
65vec4 occPBRBackMaterial_Color(void) { return occPbrBackMaterial[0]; }
66vec3 occPBRBackMaterial_Emission(void) { return occPbrBackMaterial[1].rgb; }
67float occPBRBackMaterial_IOR(void) { return occPbrBackMaterial[1].w; }
68float occPBRBackMaterial_Metallic(void) { return occPbrBackMaterial[2].b; }
69float occPBRBackMaterial_Roughness(void) { return occRoughness (occPbrBackMaterial[2].g); }
70float occPBRBackMaterial_NormalizedRoughness(void) { return occPbrBackMaterial[2].g; }
71#else
12381341 72uniform vec4 occFrontMaterial[5];
73uniform vec4 occBackMaterial[5];
74
0adbd30f 75vec4 occFrontMaterial_Ambient(void) { return occFrontMaterial[0]; }
76vec4 occFrontMaterial_Diffuse(void) { return occFrontMaterial[1]; }
77vec4 occFrontMaterial_Specular(void) { return occFrontMaterial[2]; }
78vec4 occFrontMaterial_Emission(void) { return occFrontMaterial[3]; }
12381341 79float occFrontMaterial_Shininess(void) { return occFrontMaterial[4].x; }
80float occFrontMaterial_Transparency(void) { return occFrontMaterial[4].y; }
81
0adbd30f 82vec4 occBackMaterial_Ambient(void) { return occBackMaterial[0]; }
83vec4 occBackMaterial_Diffuse(void) { return occBackMaterial[1]; }
84vec4 occBackMaterial_Specular(void) { return occBackMaterial[2]; }
85vec4 occBackMaterial_Emission(void) { return occBackMaterial[3]; }
12381341 86float occBackMaterial_Shininess(void) { return occBackMaterial[4].x; }
87float occBackMaterial_Transparency(void) { return occBackMaterial[4].y; }
67312b79 88#endif
79f4f036 89
90// 2D texture coordinates transformation
91vec2 occTextureTrsf_Translation(void) { return occTexTrsf2d[0].xy; }
92vec2 occTextureTrsf_Scale(void) { return occTexTrsf2d[0].zw; }
93float occTextureTrsf_RotationSin(void) { return occTexTrsf2d[1].x; }
94float occTextureTrsf_RotationCos(void) { return occTexTrsf2d[1].y; }
d95f5ce1 95//! @endfile DeclarationsImpl.glsl