Possible Bug with Water Shaders with Emscripten
data:image/s3,"s3://crabby-images/cf23e/cf23ee93de9595a2335f9506f90c92731e44c20f" alt=""
data:image/s3,"s3://crabby-images/cfa6e/cfa6edf196155245acfc9df43dc6f733027b2dc8" alt=""
This is the same as on mobile GLES2. It doesn’t implement clipping planes, so the objects under water will render also incorrectly in the reflection.
I’m not sure there’s a good solution for this. One could clip manually in the pixel shader, by discarding the fragments, but this would be performance hell on mobiles at least.
data:image/s3,"s3://crabby-images/cf23e/cf23ee93de9595a2335f9506f90c92731e44c20f" alt=""
[quote=“cadaver”]This is the same as on mobile GLES2. It doesn’t implement clipping planes, so the objects under water will render also incorrectly in the reflection.
I’m not sure there’s a good solution for this. One could clip manually in the pixel shader, by discarding the fragments, but this would be performance hell on mobiles at least.[/quote]
There has to be a way to do it though that isn’t bad for performance… I wonder how Unity and other engines do it. But this is a known issue and it is just a minor one (note to self: avoid using water
).
EDIT: Maybe this will help show a better way to do it… https://github.com/powervr-graphics/Native_SDK/tree/3.4/Examples/Advanced/Water http://stackoverflow.com/questions/7408855/clipping-planes-in-opengl-es-2-0
data:image/s3,"s3://crabby-images/80531/805315f8e8606e1aaacf3350b62348d68fe6f6ad" alt=""
If i had any performance issues on mobile, fancy water w/ reflections would be the first to die
data:image/s3,"s3://crabby-images/cf23e/cf23ee93de9595a2335f9506f90c92731e44c20f" alt=""
Lol
Good point! Agree that would probably be best.
Do you think the reflections could be disabled when using opengl es?
data:image/s3,"s3://crabby-images/80531/805315f8e8606e1aaacf3350b62348d68fe6f6ad" alt=""
In the case of the water example the code is generating the material settings and not loading from a scene file. Since the code has control I would check at runtime which material to use on the water plane and not generate the realtime reflection image.
data:image/s3,"s3://crabby-images/cfa6e/cfa6edf196155245acfc9df43dc6f733027b2dc8" alt=""
I tested the Terathon oblique projection technique when initially implementing the water reflection; it’s cool but I never managed to get an arbitrary clipping plane to work (let’s say you wanted to clip either above a certain Y plane, or below it)