|
Last change
on this file was 561, checked in by Dmitry A. Kuminov, 16 years ago |
|
trunk: Merged in qt 4.6.1 sources.
|
|
File size:
1.1 KB
|
| Line | |
|---|
| 1 | // if 2.Sca <= Sa
|
|---|
| 2 | // Dca' = Dca.(Sa + (2.Sca - Sa).(1 - Dca/Da)) + Sca.(1 - Da) + Dca.(1 - Sa)
|
|---|
| 3 | // otherwise if 2.Sca > Sa and 4.Dca <= Da
|
|---|
| 4 | // Dca' = Dca.Sa + Da.(2.Sca - Sa).(4.Dca/Da.(4.Dca/Da + 1).(Dca/Da - 1) + 7.Dca/Da) + Sca.(1 - Da) + Dca.(1 - Sa)
|
|---|
| 5 | // otherwise if 2.Sca > Sa and 4.Dca > Da
|
|---|
| 6 | // Dca' = Dca.Sa + Da.(2.Sca - Sa).((Dca/Da)^0.5 - Dca/Da) + Sca.(1 - Da) + Dca.(1 - Sa)
|
|---|
| 7 | // Da' = Sa + Da - Sa.Da
|
|---|
| 8 |
|
|---|
| 9 | vec4 composite(vec4 src, vec4 dst)
|
|---|
| 10 | {
|
|---|
| 11 | vec4 result;
|
|---|
| 12 | float da = max(dst.a, 0.00001);
|
|---|
| 13 | vec3 dst_np = dst.rgb / da;
|
|---|
| 14 | result.rgb = mix(dst.rgb * (src.a + (2.0 * src.rgb - src.a) * (1.0 - dst_np)),
|
|---|
| 15 | mix(dst.rgb * src.a + dst.a * (2.0 * src.rgb - src.a) * ((16.0 * dst_np - 12.0) * dst_np + 3.0) * dst_np,
|
|---|
| 16 | dst.rgb * src.a + dst.a * (2.0 * src.rgb - src.a) * (sqrt(dst_np) - dst_np),
|
|---|
| 17 | step(dst.a, 4.0 * dst.rgb)),
|
|---|
| 18 | step(src.a, 2.0 * src.rgb))
|
|---|
| 19 | + src.rgb * (1.0 - dst.a) + dst.rgb * (1.0 - src.a);
|
|---|
| 20 | result.a = src.a + dst.a - src.a * dst.a;
|
|---|
| 21 | return result;
|
|---|
| 22 | }
|
|---|
Note:
See
TracBrowser
for help on using the repository browser.