-
Notifications
You must be signed in to change notification settings - Fork 3
Z fighting issues #8
Comments
The reason for this is the use of a less-equal comparison for transparent fragments. The only reason I do this is for HUD elements (for example, the pause menu). You can mess with the comparison here and the normalization here. Might be worth somehow special-casing the HUD, or perhaps using a different method of storing depth. Currently transparent fragment depth is stored normalized (0 to 1). The reasons for this are:
*z is the depth from the far plane to the near plane, effectively world-space; dividing by w normalizes it, making it screen-space If I had full control over the entire pipeline, I could easily draw opaque first, transparent second, and then draw hud elements over the top after composition of the scene fragments. I could of course take control over the entire pipeline by force, but that will be very time consuming if not impractical (says the person who just shimmed D3D8 to D3D11 for OIT). So it turns out to be a bit of a complex issue. |
If you can test which texlist is being used, maybe it's possible to whitelist all HUD texlists and get rid of the less-equal check? |
Sky Chase works fine with the latest generic build (or maybe it's because I reworked it a while back, not sure), all other issues are still there. I fixed the Emerald Coast pool thing manually. |
These happen only when OIT is on, 32-bit Z Buffer doesn't help
Pool in the Ice Cap cave in the Mystic Ruins (DC level only)
Water ripple (happens only with the SADX version of the ripple)
Hard to see but this thing in MR Past appears to have some kind of shadow that flickers when the screen moves. It shows up only with OIT when a 24-bit Z Buffer is used, but it also shows up without OIT when a 32-bit Z Buffer is used.
Sky Chase sky looks weird in motion (DC level only)
Character shadow at the bottom of Emerald Coast 2 pond
The text was updated successfully, but these errors were encountered: