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