aboutsummaryrefslogtreecommitdiffstats
path: root/src/runtimerender/res/effectlib/funcsampleNormalTexture.glsllib
blob: 76e14f806405da022cd2a98c48fe8ec5cf2cd0c9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
// Copyright (C) 2023 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only

// This function assumes tangent, binormal and normal are orthonormal.
// It means the return value will be a normalized normal vector.
vec3 qt_sampleNormalTexture(in sampler2D inSampler, in float factor, in vec2 texCoord, in vec3 tangent,
                            in vec3 binormal, in vec3 normal)
{
    vec3 tsNormal = 2.0 * texture(inSampler, texCoord).xyz - 1.0;
    tsNormal *= vec3(factor, factor, 1.0);
    tsNormal = normalize(tsNormal);
    return tsNormal.x * tangent + tsNormal.y * binormal + tsNormal.z * normal;
}

vec3 qt_sampleNormalTexture2(in sampler2D inSampler, in float factor, in vec2 texCoord, in vec3 tangent,
                            in vec3 binormal, in vec3 normal)
{
    vec3 tsNormal = 2.0 * texture(inSampler, texCoord).xyz - 1.0;
    //tsNormal.xy = tsNormal.xy * 2.0 - 1.0;
    //tsNormal.z = sqrt(max(0.0, 1.0 - dot(tsNormal.xy, tsNormal.xy)));
    return normalize(mix(normal, tangent * tsNormal.x + binormal * tsNormal.y + normal * tsNormal.z, factor));
}

vec3 qt_sampleNormalTexture3(in sampler2D inSampler, in float factor, in vec2 texCoord, in vec3 tangent,
                            in vec3 binormal, in vec3 normal)
{
    mat3 tanFrame = mat3(tangent, binormal, normal);
    vec3 tsNormal = texture(inSampler, texCoord).xyz * 2.0 - vec3(1.0);
    tsNormal *= vec3(factor, factor, 1.0);
    return tanFrame * normalize(tsNormal);
}