Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rendering issues with "Show Me Your Skin!" mod #1576

Open
SplendidAlakey opened this issue Aug 1, 2022 · 8 comments
Open

Rendering issues with "Show Me Your Skin!" mod #1576

SplendidAlakey opened this issue Aug 1, 2022 · 8 comments
Labels
bug Something is implemented incorrectly mod compatibility A compatibility issue with another mod

Comments

@SplendidAlakey
Copy link

SplendidAlakey commented Aug 1, 2022

What happened?

Using Iris with ShowMeYourSkin causes slight rendering issues in game (you can see a shiny outline where the invisible/transparent armor is supposed to be) and major rendering issues in it's GUI screen (body parts are fully culled unless the armor visibility is set to 0%).

Initially reported to the developer of SMYS, however, they replied that they would likely not be able to fix it on their own: enjarai/show-me-your-skin#19

Screenshots

2022-07-28_14 02 32

2022-07-28_14 02 36

Log output

https://gist.github.com/SplendidAlakey/0f539d5c287fd33cd351f039493426b0

Minecraft Version

1.19.1

Iris Version

1.2.6

Operating System

Windows 10

What is your GPU?

GTX 980

Additional context

Initial report was made using version 1.2.1 of SMYS, but it's reproducible in 1.3.1 as well.

@SplendidAlakey SplendidAlakey added the bug Something is implemented incorrectly label Aug 1, 2022
@coderbot16 coderbot16 added the mod compatibility A compatibility issue with another mod label Feb 4, 2023
@enjarai
Copy link

enjarai commented Apr 8, 2023

Author of Show Me Your Skin here. This is still an issue, and while I've been looking into a fix for this on my side, I haven't made progress as of yet. I'd definitely like to get this fixed though, any ideas?

@RivenofthreeVoices
Copy link

RivenofthreeVoices commented Apr 14, 2023

Author of Show Me Your Skin here. This is still an issue, and while I've been looking into a fix for this on my side, I haven't made progress as of yet. I'd definitely like to get this fixed though, any ideas?

Instead of having a slider for opacity, could you instead make a toggle that instead of using opacities, altogether makes the piece invisible? Another mod called Skin Shine has a similar function to the mod, but I have no issues using it with Iris. I'd love to use your mod instead, because of the in-game GUI and customization per player.

@enjarai
Copy link

enjarai commented Apr 14, 2023

Author of Show Me Your Skin here. This is still an issue, and while I've been looking into a fix for this on my side, I haven't made progress as of yet. I'd definitely like to get this fixed though, any ideas?

Instead of having a slider for opacity, could you instead make a toggle that instead of using opacities, altogether makes the piece invisible? Another mod called Skin Shine has a similar function to the mod, but I have no issues using it with Iris. I'd love to use your mod instead, because of the in-game GUI and customization per player.

Setting the sliders to 0 will achieve that exact result, as it explicitely cancels the armor rendering instead of trying to render it with 0 opacity. Which I guess could be considered a workaround for this issue.

It doesn't take away from the fact hat the fully customizable opacity is one of the main features of my mod though, and having it be incompatible with one of the biggest mods out there is definitely not ideal.

@coderbot16
Copy link
Member

It looks like the outline is in reality the 1% transparent legs layer being drawn to the screen before the player shadow, which causes those pixels of the player shadow that are behind the legs layer to not be drawn because the depth buffer reports that there is something that is already closer on the screen. In other words, it's a classic translucency sorting problem. It's likely Iris Batched Entity Rendering that is causing the issue, since that relies on reordering and then batching together rendering calls to improve rendering performance, which can lead to transparency ordering issues.

@RivenofthreeVoices
Copy link

Setting the sliders to 0 will achieve that exact result, as it explicitely cancels the armor rendering instead of trying to render it with 0 opacity. Which I guess could be considered a workaround for this issue.

It doesn't take away from the fact hat the fully customizable opacity is one of the main features of my mod though, and having it be incompatible with one of the biggest mods out there is definitely not ideal.

Apologies, I'm not sure how your mod, and the Shine mod work in-depth. All I know is that somehow, Shine doesn't have issues with Iris. I don't mean to just drop the opacities, because that's an extremely awesome feature. I simply mean to say that perhaps fixing it is possible, due to the fact that a similar mod exists with little issue.

@enjarai
Copy link

enjarai commented Apr 15, 2023

It looks like the outline is in reality the 1% transparent legs layer being drawn to the screen before the player shadow, which causes those pixels of the player shadow that are behind the legs layer to not be drawn because the depth buffer reports that there is something that is already closer on the screen. In other words, it's a classic translucency sorting problem. It's likely Iris Batched Entity Rendering that is causing the issue, since that relies on reordering and then batching together rendering calls to improve rendering performance, which can lead to transparency ordering issues.

That does explain why its an issue even when no shaders are enabled. Is there any way I can work around this on my side, aside from disabling entity batching entirely?

@coderbot16
Copy link
Member

Entity batching tries to observe the order of draw calls to figure out how to order translucency rendering. Reordering your render calls may or may not change things.

@enjarai
Copy link

enjarai commented Apr 15, 2023

I'm using the exact same ordering and pipeline as vanilla, just with some mixins to change the renderlayer and transparency somewhere along the way. I'll have to add that I'm not particularly well-versed in rendering or how Minecraft handles it. Though it seems like it'd be quite difficult to change the order in which the armor and playermodels render in relation to eachother.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something is implemented incorrectly mod compatibility A compatibility issue with another mod
Projects
None yet
Development

No branches or pull requests

4 participants