three-d 0.19.0

2D/3D renderer - makes it simple to draw stuff across platforms (including web)
Documentation


uniform samplerCube environmentMap;
uniform vec3 direction;
uniform vec3 up;
uniform uint sampleCount;

in vec2 uvs;

layout (location = 0) out vec4 outColor;

void main()
{		
	// The world vector acts as the normal of a tangent surface
    // from the origin, aligned to WorldPos. Given this normal, calculate all
    // incoming radiance of the environment. The result of this radiance
    // is the radiance of light coming from -Normal direction, which is what
    // we use in the PBR shader to sample irradiance.
    vec3 right = cross(direction, up);
    vec3 N = normalize(up * (uvs.y - 0.5) * 2.0 + right * (uvs.x - 0.5) * 2.0 + direction);

    vec3 irradiance = vec3(0.0);   
    
    // tangent space calculation from origin point
    vec3 up    = vec3(0.0, 1.0, 0.0);
    right = normalize(cross(up, N));
    up         = normalize(cross(N, right));
       
    float sampleDelta = 2.0 * PI / float(sampleCount);
    float nrSamples = 0.0;
    for(float phi = 0.0; phi < 2.0 * PI; phi += sampleDelta)
    {
        float sin_phi = sin(phi);
        float cos_phi = cos(phi);
        for(float theta = 0.0; theta < 0.5 * PI; theta += sampleDelta)
        {
            float sin_theta = sin(theta);
            float cos_theta = cos(theta);
            // spherical to cartesian (in tangent space)
            vec3 tangentSample = vec3(sin_theta * cos_phi,  sin_theta * sin_phi, cos_theta);
            // tangent space to world
            vec3 sampleVec = tangentSample.x * right + tangentSample.y * up + tangentSample.z * N; 

            irradiance += texture(environmentMap, sampleVec).rgb * cos_theta * sin_theta;
            nrSamples++;
        }
    }
    irradiance = PI * irradiance * (1.0 / float(nrSamples));
    
    outColor = vec4(irradiance, 1.0);
}