-
-
Notifications
You must be signed in to change notification settings - Fork 111
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
[bug?] SpotLight::generate_shadow_map()
doesn't cast shadows?
#503
Comments
#461 could be related to this? |
You defined a spotlight with a cutoff at almost 180 degrees, that means the shadow map needs to cover an enormous area and therefore no pixel in the shadow map will actually hit the relatively small sphere. If you change the angle to something more realistic (a spotlight is usually something like a flashlight), then it's working as expected.
What is the exact reason why it should be part of a trait? 🤔
It's already an issue: #74. However, it's quite expensive for point lights since it requires a shadow map in all directions (a cube map instead of a 2D texture). So it's not used a lot in practice in my experience. In general, shadow maps are really nice but definitely have their limitations due to performance. Therefore, it's not just plug-and-play, you need to understand the technique before being able to use it effectively. |
Well yes, playing around found the cutoff to be somewhere around 179.72-179.73, high enough for any normal use, I was using such angles to try to get a pointlight kind of light but with shadows, guess I wont.
Its just some shared behavior, I simply ran into an issue in my project where I had to take a generic light that implements shadows, so I ended up making my custom trait for it and implementing it for each light element. I just think it makes sense to make it a trait in the library directly.
Tbh idk much about shadow maps, I just get the basic idea of how they work and using them to make my project look a little nicer, nothing performance critical. But I think they are a little too complex for me, might look into it to optimize things at some point, but it's definitely not important for what I'm doing. Thanks for the assistance though! |
Well you might be able to if you use 6 spot lights with an angle of 90 degrees. That's basically the point light shadow map setup.
I'll consider it 👍
No problem 🙂 |
To be fair I'm not really familiar with the library, but to my understanding, the
Light
objects that implement the functiongenerate_shadow_map
should cast shadows on things when provided with the appropriateMesh
s of the scene. And this is what happens at least withDirectionalLight
, but doesn't work at all withSpotLight
.I was able to make this relatively simple demo for the issue:
demo code
I would expect the spotlight to cast a shadow on the right element as it's covered by the left sphere, just like what happens with the directional light from the other side.
Also unrelated, but a few quick thoughts on the shadows thing. They should have a common trait, or implement it in the
Light
trait, but I don't expect lights like ambient light to have the shadow method. AndPointLight
should implement shadows too, imo it's just like a spotlight but with a full coverage angle, so there's less variables to mind in the calculation.The text was updated successfully, but these errors were encountered: