-
Notifications
You must be signed in to change notification settings - Fork 225
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
Ray-traced VC Textures #379
base: main
Are you sure you want to change the base?
Conversation
Hi @jarmonik, regarding your "do not merge" comment, what we often do for NASSP dev, is leave PRs as "draft", until we're ready to merge them. Then we mark them as ready for review. That way they can't accidentally get merged early, but we can still use them as a placeholder for an ongoing project. |
- Passed the data to a client level - Addressed issue #379 (implemented but not tested) - Cleared up filename and pathname confusion in D3D9Surface.cpp - Cleared up visualization of shadow map (Debug)
-Activated pre-bake process
…hader and are operational. - Fixed bugs from IProcess.cpp - Baked light sources can be adjusted from debug controls.
This project is ready enough for shader development to start. Waiting feedback.. |
…edVC # Conflicts: # OVP/D3D9Client/D3D9Util.h
@jarmonik, what is needed for a test of this feature? |
There is currently nothing to test. The shader would need to be finished first. Felix24 knows how to build ray-traced textures and how to write shaders so he knows both sides of the equation. I don't know who else could do that. I suppose I could try to write some kind of shader but I have close to zero experience with 3D modeling and ray-tracing, so, I am not going to make any textures. It's a holiday season so it might take some time until things move forward. Meanwhile I try to improve the sun shadow quality. |
…BakedVC # Conflicts: # OVP/D3D9Client/D3D9Util.h
Fed shadow cascades to shaders Added a debug visualization of cascade coverage
…ine tuning required.
…e level selection.
I am so bad at remembering to reply to things. I will reach out on the forum. I like the idea of the ambient light probe. It's amazing just how bright the sun is, from a lighting standpoint: https://www.flickr.com/photos/projectapolloarchive/21315590814/in/album-72157659042210300/ Who else has written shaders in the past? |
I think the photo from Flickr has a longer exposure time, you can see that because the camera was moved while taking the photo. |
This is a good idea, and is basically what I'm trying to do. I currently grab the blue channel of gSun.Color as a proxy for the amount of sunlight present in the VC and use it to change the brightness of the ambient light illumination. gSun.Color is white in day and black at night, with some sunrise/sunset color mixing in between. I grab the blue channel because it is the last channel to increase in brightness at sunrise, and the first to decay at sunset, and allows for a more gradual transition between dynamic range regimes. This does not take into account flying upside-down with the sun not visible through the windows. In this case, currently there is no change in the ambient light. I want be able eventually to have multiple ambient light maps for sunlight coming from different directions. One with the light coming in from the forward direction, one for each side, and one for above. |
This is a great idea. I'm not sure how to implement and test this though. |
That sounds like a good idea, no need for the ambient probe. If there is an ambient map for each of the main directions (X,Y,Z) and -(X,Y,Z) then the ambient map could be interpolated from the main axes for a given sun light direction. If that's the way to go then I can add the texture load and interpolation procedures. |
Implemented pre-bake shader.
- Env camera configuration cleanup and improvements. - Irradiance map quality and performance updates. - Planet glow included in BakedAmbient lighting.
…edVC # Conflicts: # Orbitersdk/include/GraphicsAPI.h
Moved oapiMeshProperty function to VESSEL interface as SetVisualProperty()
…edVC # Conflicts: # OVP/D3D9Client/DebugControls.cpp # OVP/D3D9Client/Scene.cpp
The C++ side should be now in a working condition. The shaders still need some work. Feedback required regarding fully baked configuration. Ambient light probe experiment was successful, although, without HDR the small difference between dim local light and sun light causes some issues. With HDR upgrade, performance optimizations and quality improvements, this can work. With this upgrade it would be possible to block Earth glow coming in a closed payload bay. It might be good idea to wait for the release of Orbiter 2024 before merge and then start updating the stock vessels since no more DX7 compatibility is required. |
@jarmonik I have been testing with internal dynamic shadows using code from this commit: a193053 The result in NASSP is quite good in my opinion: https://www.dropbox.com/s/emczp6g854riys4/Screenshot%202025-01-07%2020.36.06.png?raw=1 The ambient lighting may be a little too low now but before it was much too high in my opinion as the sun seemed to illuminate the entire interior face directly opposite to it, even if there is no window in between to shine through, whereas now it is just through an actual window. Maybe eventually some other way can be found to restore some of the lost ambient light in a more realistic way if that makes sense. Anyway I have built my own version of the Orbiter 2024 D3D9 client that has it enabled but would it be feasible to have this feature pushed to OpenOrbiter, maybe with an tick box to enable/disable in the options? |
Implementation of ray-traced VC textures. Issue #378
https://www.orbiter-forum.com/threads/raytraced-vc-textures-with-panel-lights.40347/