-
-
Notifications
You must be signed in to change notification settings - Fork 53
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
Instance lighting has a tendency to break #226
Comments
I've also experienced this issue, and spent the last week trying to figure out why this happens and fixing it. I will not be posting a jar of the fixed version as i'm not sure if that is allowed and you probably shouldn't download and run jars from stranger's on the internet anyways. Fortunately, it is very easy to fix if you know how to clone the code and build your own jar.
In
In all 3 of these places, change This is what fixed it for me, so if you're only interested in that the below information will not be relevant. Here are some things i've found while trying to figure out why it breaks. In the vertex shaders, the normal is multiplied with a matrix 'normalMat' (done in the I mentioned a pattern in how instances are broken earlier. I noticed that at any point, the oldest half of created instanced (rounded up) of one type works normally, while the newest half (rounded down) is rendered incorrectly. With 'of one type', i mean things such as chest lids and minecarts being distinct types. Also, left- and right-half chest lids for double chests and single lids are considered different types. Shulker boxes top-and bottom halves are also distinct types, as well as shulker boxes of different colors. Lastly, i noticed that broken instances either rendered too bright or completely black (i assume this is because diffusefactor in the shader is either 0 or 1, but never something in between as a result of the broken 'normalMat'). But once an instance of particular type is destroyed, instances of that type are always completely black until the world is closed and restarted. This has been a very long comment. To finish i would like to mention that looked through several different branches and commits, and this commit is the one that introduced the problem. This commit happened quite a while ago, so it must be a quite rare occurrence for this problem to happen. Also, i noticed a new version is being worked on on the branch 1.20/next. This problem doesn't occur (at least for me) on that branch. That was all. I hope this helps! |
I'm able to reproduce this on an intel iGPU on 1.20/next. Seems to be related to using integer vertex attributes. |
I would like to fix it, so I'm wondering if anyone has an exact list of things I need to do? Because from that post I don't even know where to look for the files... |
@HiMikoHyuga The issue is now mostly resolved on 1.20/next and I don't know if there's a true solution that isn't just another workaround. The problem is that some drivers simply don't handle integer vertex attributes correctly. Flywheel used integer attributes for light (and still uses them for overlay), so sometimes the shader ends up with garbage data. The workaround you might want to try is to avoid using integer attributes at all. The 2 places I'll point you to are vertex_input.glsl for the GPU side code, and InternalVertex for the CPU side representation. |
is it solved? i don't think so, I'm on 1.20.1 create and I still get this with instancing, I did try backend. after I found out you can type that command but with that other thing is broken valk skies doesn't work and crashes, and with it off another mod doesn't work png file items are black... :\ not to mention fps is way worse with other that instancing |
It is fixed entirely in dev but the fix has not been released yet |
I'm also getting this issue like the this post, the top of my chest is just black. |
After harf a year by "fixed in dev", it still not fix in release? what can i say. i try an old version about amd driver, it`s ok, but i need to play other games with new driver too. |
Also still experiencing this issue on Adrenalin 24.9.1. Would very much appreciate a fix for this. |
Genuinely, why have you not released it then? This is a pretty severe issue, shouldn't it be a priority? |
@Jozufozu It's genuinely pathetic that it's taking this long to release a patch when the patch is already finished. |
"the fix" in question is a complete rewrite of the mod. I tried duct taping on some things I thought could work to 0.6, but nothing simple made a difference. Flywheel 1.0 cannot release on 1.20.1 without breaking create, so it will remain in dev until such time as create is ready to release with it. I appreciate your patience, and I remind you that contributions are always welcome if you feel you can improve the stability of the mod. |
Oh, didn't realize it was a part of the rewrite. Sorry. |
Describe the Bug
Lighting of instances will sometimes go completely or partially dark. This can be seen on large, moving Create contraptions.
This issue was recently opened, showing it happening to chests.
When looking for an issue to direct that to, I was very surprised to find this has never been formally reported?? It's a pretty common problem. I checked Flywheel and both Creates and found nothing. So now there is one.
Reproduction Steps
unknown, very random
Expected Result
correct lighting
Screenshots and Videos
see this issue
Crash Report or Log
No response
Operating System
Windows 10
What is your GPU?
I've had this occur on my 3060, unknown for original reporter.
Mod Version
0.6.8.a
Minecraft Version
1.19.2
Loader Version
unimportant, happens on all loaders and game versions
Other Mods
No response
Additional Context
No response
The text was updated successfully, but these errors were encountered: