blob: a5a153f892805cbc6220c6a10d1a016e18212093 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
|
// Dca' = Sca.Da + Dca.Sa <= Sa.Da ?
// Sca.(1 - Da) + Dca.(1 - Sa)
// Sa.(Sca.Da + Dca.Sa - Sa.Da)/Sca + Sca.(1 - Da) + Dca.(1 - Sa)
// Da' = Sa + Da - Sa.Da
vec4 composite(vec4 src, vec4 dst)
{
vec4 result;
result.rgb = mix(src.rgb * (1 - dst.a) + dst.rgb * (1 - src.a),
src.a * (src.rgb * dst.a + dst.rgb * src.a - src.a * dst.a) / max(src.rgb, 0.00001) + src.rgb * (1 - dst.a) + dst.rgb * (1 - src.a),
step(src.a * dst.a, src.rgb * dst.a + dst.rgb * src.a));
result.a = src.a + dst.a - src.a * dst.a;
return result;
}
|