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

Shadowmaps #1209

Open
8 tasks
VReaperV opened this issue Jun 25, 2024 · 11 comments
Open
8 tasks

Shadowmaps #1209

VReaperV opened this issue Jun 25, 2024 · 11 comments
Labels

Comments

@VReaperV
Copy link
Contributor

VReaperV commented Jun 25, 2024

This issue is to keep track of necessary steps and progress for implementing shadowmaps in the tiled renderer.

Required:

  • Support for generalized texture atlases. These atlases should be able to pack multiple different textures into them, as well as support non-trilinear sampling.
  • Additional data in tiles to tell which shadowmaps affect any particular tile.
  • Rendering of shadowmaps into arbitrary parts of the viewport.
  • Sampling of shadowmaps based on the tile information.
  • Evalute R_inPVVS() usefulness for shadow-casting lights culling.

Optional:

  • Shadowmap priority calculation. Based on eg: distance from viewpos, area on screen, light priority, light volume/area etc. This can then be used to determine the size of each individual shadowmap.
  • Caching shadowmaps: only render shadowmaps if something in their frustum changed or the frustum itself changed.
  • Caching static geometry in shadowmaps: render static geometry once (and if the light sources moves or changes its direction; for constantly moving lights, eg projectiles, it might be better to skip this part entirely) and then copy it when something moves in the view of the light source, and draw only the objects that moved.
@VReaperV VReaperV added A-Renderer T-Feature-Request Proposed new feature labels Jun 25, 2024
@slipher
Copy link
Member

slipher commented Jun 25, 2024

I suppose shadows are expected to be cast by dynamic lights only? Since the information isn't really there for lights baked into the map. It's possible to instruct q3map2 not to remove point light entities, but then everyone says you should be using light emitting shaders anyway.
I don't remember anything about the old shadow implementation, so I'm just asking as if it's starting from scratch.

@illwieckz
Copy link
Member

I suppose shadows are expected to be cast by dynamic lights only?

IT would be a good start, yes.

Since the information isn't really there for lights baked into the map. It's possible to instruct q3map2 not to remove point light entities, but then everyone says you should be using light emitting shaders anyway.

Indeed light entities could be used when not removed, and surfaces using light emitting shaders too (would require to also parse those keywords), when the shader is properly shipped with the map (it was possible to not ship some shaders if the image had the same name as the shader and some special effects like image scrolling were not used).

I wonder if we can also average some lightgrid direction.

@VReaperV
Copy link
Contributor Author

Yeah, some information would be required for any shadows. I'm assuming light emitting shaders essentially work as spotlights where everything between where the light source would be and the surface itself is ignored? (and light falloff not applying until getting to the surface of course)

@illwieckz
Copy link
Member

illwieckz commented Jun 25, 2024

I'm assuming light emitting shaders essentially work as spotlights

Basically, yes. In fact the map compiler spawns a kind of spotlight every given subdivision, and this subdivision can be configured, but considering it as a spotlight at first would be good enough (and we may not want to render so many shadows anyway).

spotlights where everything between where the light source would be and the surface itself is ignored?

I don't get this part of the sentence.

@VReaperV
Copy link
Contributor Author

VReaperV commented Jun 25, 2024

I don't get this part of the sentence.

I'm imagining something like this:
image

@DolceTriade
Copy link
Contributor

Averaging the lightgrid is possible and that's what we did in the past. It's just not super accurate, but if the shadows look nice, it still looks nice :)

I don't think we have any information about light emitting shaders except the light grid, which is super lossy.

@illwieckz
Copy link
Member

illwieckz commented Jun 25, 2024

The light emitting shader works like this:

                           light cone
      \       /   \       /
       \     /     \     /
        \   /       \   /
         \ /         \ /
          *           * light
         / \         / \ back splash
     ________________________ light emitting shader
/////|//////////|///////////|/////// wall
     |          |           | subdivision

A light is spawn a bit in front of the surface having a light emitting shader, with a back splash.

The distance of the light to the surface, and the intensity of the backsplash is configurable independently to the main light intensity.

  • q3map_lightImage <path>: sample the light color from this image,
  • q3map_lightRGB <R> <G> <B>: explicit light color,
  • q3map_surfacelight <N>: light intensity,
  • q3map_lightSubdivide <N>: spawn one light per N game units,
  • q3map_backSplash <percentage> <distance>: configure the backsplash (percentage of intensity and distance to surface).

More details here: http://q3map2.robotrenegade.com/docs/shader_manual/q3map-global-directives.html

@VReaperV
Copy link
Contributor Author

Hmm, interesting. How is the light cone size calculated though? I'm not seeing any mention of that. At least some light source for such surfaces can probably be combined to avoid building more shadowmaps.

@illwieckz
Copy link
Member

illwieckz commented Jun 26, 2024

DolceTriade dixit:
I don't think we have any information about light emitting shaders except the light grid, which is super lossy.

I guess we can iterate every surface of the geometry, compute the position in space, pick the material name, lookup for the shader, parse it and see if there is some light emitting keywords in its body.

VReaperV dixit:
How is the light cone size calculated though?

I even don't know if it's a cone, but I guess it's somewhat biased into some direction if it needs a backlight.

@illwieckz
Copy link
Member

illwieckz commented Jun 26, 2024

I even don't know if it's a cone, but I guess it's somewhat biased into some direction if it needs a backlight.

It may also be an half-sphere.

@VReaperV
Copy link
Contributor Author

I've changed my mind on making texture atlases generalised: I wanted to use those for material system as a workaround where bindless textures aren't supported/broken, but earlier testing showed that approach to be too convoluted for regular textures, with a bunch of issues related to mipmaps as well. Using texture arrays (GL_TEXTURE_2D_ARRAY) is a much better alternative there.

Shadow atlases will probably still need some additional shader code to correctly sample the shadowmaps at their borders.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

4 participants