Possible Bug with Water Shaders with Emscripten
data:image/s3,"s3://crabby-images/b40a4/b40a4186367bf268d014d7ce0d610ea36a32d077" alt=""
data:image/s3,"s3://crabby-images/e63bd/e63bd37b42171216c0e3e6555bdca8d728525bba" 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/b40a4/b40a4186367bf268d014d7ce0d610ea36a32d077" 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/4506e/4506e93de36838b4d022105615f9e5580ce5b0ae" 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/b40a4/b40a4186367bf268d014d7ce0d610ea36a32d077" 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/4506e/4506e93de36838b4d022105615f9e5580ce5b0ae" 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/e63bd/e63bd37b42171216c0e3e6555bdca8d728525bba" 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)