Deferred Rendering Test

From Second Life Wiki
Jump to navigation Jump to search


Overview

The goal is to ship a new, additional rendering mode for not-old graphics cards that greatly improves the quality of the in-world visual experience and immersion. The two main features of this (optional) mode are support for real-time shadows and much-improved lighting.

Expectations:

  • There should be no negative impact on viewer speed, quality or compatibility if this mode is disabled.
  • It is expected that this mode be disabled by default on any hardware where this would cause the default frame-rate to become lower than (say) a typical 10FPS.
  • It is expected that enabling this mode lowers the frame-rate compared with turning it off.
  • Mild-to-moderate changes in the presentation of content - generally for the subjective better - are acceptable.

System requirements:

  • Supported on all viewer platforms; Linux, Mac, Windows.
  • A not-old graphics card:
    • For the initial release, GeForce 8600 and 8800, GTX 2xx, and Radeon HD 4xxxx in Windows XP and Vista are good test targets. ATI support on linux is optional, nVidia (8600+) cards on Linux with the official nVidia drivers are expected to work equivalently to Windows but it is not essential to test this configuration.
    • A relatively old graphics card which does not support this rendering mode will still entirely function as before - it will simply have the corresponding preference option(s) grayed-out.

Deferred rendering prefs UI

Prefs.png

  • New toggle option: "Lighting and Shadows" (should be greyed-out if "Atmospheric Shaders" is unchecked; may also be greyed-out on unsupported hardware)
  • New toggle option: "Ambient Occlusion" (should be greyed-out if "Lighting and Shadows" is unchecked)
  • New drop-down option: "Shadows:" (should be greyed-out if "Lighting and Shadows" is unchecked); available options should be "None", "Sun/Moon", "Sun/Moon + Projectors".
  • Drop-down option "Water Reflections:" replaces viewer 2.0 radio buttons with the same effect (should be greyed-out if "Basic shaders" is unchecked); available options should be "Minimal", "Terrain and Trees", "All static objects", "All avatars and objects", "Everything".

Deferred rendering - general

  • Turn on 'Lighting and Shadows', in 'Shadows:' select 'None'
    • Broadly-speaking, viewing random existing in-world content in this 'Lighting and Shadows' mode should look very similar to toggling 'Lighting and Shadows' off, except it should look... better. Better means:
      • A bit smoother lighting from sun, moon, and local lights
      • Shiny on non-fullbright surfaces should look different (more testing in a later section)
      • Any number of lights will now light the scene simultaneously (with some exceptions - more testing in a later section)
      • Increased accuracy in lighting means that a bright light near a surface may now light nearby points on that surface more intensely than previously
      • Avatar imposters are now lit very similarly to non-imposters
      • Otherwise, there is no expected outright content breakage in this mode.
    • In this mode, all of the following should behave as historically expected, i.e. very similarly to when 'Lighting and Shadows' is off, per general render testing:
      • Avatar clothing, non-prim hair and skirts
      • Fullbright faces
      • Faces with transparency and/or alpha-textures
      • Animation textures
      • Faces with glow
      • Underwater scenes
      • Faces with bumpiness
      • Media textures / shared media
      • Underwater camera view
      • Combinations of any of the above

Deferred rendering - shiny

  • Fullbright shiny objects should render exactly as with 'Lighting and Shadows' turned off
  • Non-fullbright shiny objects should have the following visual properties of shininess:
    • A reflected specular 'spot' from the sun or moon (when above horizon); the higher the shiny level, the tighter-and-brighter the spot.

Shinylevels100.png

    • Reflected specular spot(s) from nearby local lights; the higher the shiny level, the tighter-and-brighter the spot.

Localshinies.png

  • Reflections on water should generally behave like reflections on shiny faces (specular spots from nearby local lights and sun/moon). These reflections are in addition to - and thus affect - all 'Water reflections' preferences which should otherwise all behave very similarly to their historic counterparts (reflecting terrain, avatars etc. in the water).

Waterref.png

Deferred rendering - bumpiness

  • Fullbright bumpy objects should render exactly as with 'Lighting and Shadows' turned off (hmm, they don't seem to - they don't seem to show any bumpyness - this is probably a bug)
  • Non-fullbright bumpy objects should have the following visual properties of bumpiness:
    • Realistic lighting for the depth-like roughness detail of the bump texture, according to sun/moon direction and the direction and influence of any local lights:

Bumpgeneral.png

    • Non-fullbright bumpy shiny objects should have these bumpy properties *plus* have the properties of shiny objects according to the 'Deferred rendering - shiny' section above; in addition, their shiny properties should be realistically perturbed by the bumpiness. See below screenshot for example.

Shinybump.png

Deferred rendering - shadows / ambient occlusion

Shadow preference settings

  • The 'Ambient Occlusion' toggle and the 'Shadows' dropdown may be used independently.
    • Enabling 'Ambient Occlusion' should cause a rather subtle darkening of nooks and crannies in shapes.
    • Setting 'Shadows' to 'Sun/Moon' should cause all qualifying objects (details further down!) to cast shadows and have shadows cast upon them.

Shadall400.png

    • Enabling 'Ambient Occlusion' and setting 'Shadows' to 'Sun/Moon' should simultaneously exhibit both effects, with the added effect that shadows are now smoother/softer/blurrier.

Aooffon.png

Casting and receiving shadow

Shadows should be cast in a direction opposite to the location of the sun (or moon) in the sky, i.e. realistically. If there is no sun or moon above the horizon, then effectively the whole world is in shadow and you won't see a clear shadow at all.

Note, it is expected and desired that an object (or twisted prim face, etc) which both casts and receives shadows may cast a shadow on itself. For example, an avatar's arm should cast a shadow on that avatar's leg, where appropriate.

Key to illustrations in this section: A = avatar B = opaque object C = 30% transparency D = 60% transparency E = 80% transparency F = opaque fullbright object G = alpha texture (per-pixel transparency)

Things that can cast shadows

  • alpha pixels > 50% opaque
  • fullbrights, glowies, sculpties, avatars, foliage, ground

Things that cannot cast shadows

  • alpha pixels <50% opaque
  • impostered avatars
  • particles

Casters.png

Things that can receive shadows

  • avatars, glowies, sculpties, water, ground, foliage, impostered avatars

Things that cannot receive shadows

  • fullbright surfaces (opaque or transparent)

Receivers.PNG

Accepted weaknesses

  • Sun/moon shadows cast onto partially-transparent/alpha faces may exhibit more blockiness than shadows cast onto normal opaque faces.
  • The 'ambient occlusion' preference may have no effect on partially-transparent/alpha faces.
  • Sun/moon shadow fidelity is not evenly distributed across the scene; shadows being cast onto faces far from the viewer may start to look increasingly blocky, also depending on camera angle and sun angle.
  • Faces which are far from the camera (approx 256 meters+) will not receive shadows. As they approach this distance, the received shadows should quickly fade away to zero effect. This can be tested by setting your draw distance to 300m and slowly pulling your camera back from the world by hundreds of meters.

Deferred rendering - legacy point-lights

  • With 'lighting and shadows' turned on, existing in-world lights should look quite similar to how they've historically looked (and continue to look, when 'lighting and shadows' is turned off), except:
    • The generated light should generally look smoother (less triangular, less delineated, and more 'round' in its influence - see below screenshot for example)
    • The generated light may appear brighter on surfaces close to the light source (see below screenshot for example)
    • Lights whose areas of influence overlap may make that area seem lit much brighter than previously.
    • Every light in the scene will have a cumulative influence on lighting (not just the closest 6 lights)
  • The above exceptions may not apply to lighting falling upon transparent or alpha-textured faces - faces with a lot of partial transparency should appear essentially identical (apart from shadows falling upon them) regardless of whether 'lighting and shadows' is turned on or off.
  • The light attributes 'color', 'intensity', 'radius', and 'falloff' should affect lights in visually similar ways with 'lighting and shadows' on or off.

Pointlights.png

Deferred rendering - projector UI

  • Editing/creating a light-source should be the same process and UI as Viewer 2.0, but extra lighting options are exposed in the build->Features tab if you have 'Lighting and shadows' turned on:

Lightopts.png

The extra options are:

  • A new texture-chooser next to the light's color-chooser. This defaults to 'no texture' (a grey box with an X through it).
  • A 'FOV' entry (defaulting to 0.0)
  • A 'Focus' entry (defaulting to 0.0)
  • An 'Ambiance' entry (defaulting to 0.0)

The effects of these options are explained in the next section. 'FOV', 'Focus', and 'Ambiance' settings have no visible effect unless a texture is selected in the texture-chooser.

Deferred rendering - projectors

Proj.png

A light becomes a 'projector' as long as it has a texture assigned to it (from the texture-picker next to the color-picker in the light editor). The features of projectors are only fully visibly supported when 'Lighting and shadows' is enabled (more details below).

Projectors: 'Lighting and shadows' enabled

A projector differs from a regular ('point') light in these significant ways:

  • It respects the FOV, Ambiance and Focus attributes (more on these below).
  • It does not cast light evenly in all directions; it only casts light along its negative Z-axis (i.e. the light is directional, and may be pointed at things).
    • The upshot of this is that the effect of a projector's light depends on the rotation of the object with the Light feature.
  • Light emitted along the negative Z-axis of a projector will actually cause lit objects to cast shadows appropriately, according to the same caster/receiver rules as sun/moon shadows, but only if:
    • the 'Shadows' preference is set to 'Sun/Moon + Projectors', and
    • the projector in question is one of the top two most influential projectors in the scene ('influential' is a fuzzy metric, but basically 'closest to the avatar')
  • The light emitted along a projector's negative Z axis is itself textured (with the texture selected in the light section of the build->Feature tab, tinted with the color selected alongside it), effectively like a slide-projector.
  • The scale of a prim with the Light feature proportionally affects the scale of the textured light projection from that object.

Accepted Weaknesses

Projectors may not project textures onto alpha/transparent faces which have partial transparency. Such faces may be lit by the projector as if 'Lighting and Shadows' was disabled, as detailed in the below section "Projectors: 'Lighting and shadows' disabled (a.k.a. Spotlights)"

Projectors & Shiny

Projref.png

A projecting prim reflecting in a shiny surface should exhibit a reflection of the projecting prim's projected texture. This should be increasingly sharper and brighter, the more shiny the reflecting surface is.

FOV

This defines the 'field of view' of the projector, in radians. This is the angular width of the cone of light projected. The possible range of values from 0.0 to 3.0 correspond to widths from 0 degrees (you can't see it - we should probably set this lower range to 0.001) to approx 172 degrees (almost a hemisphere of influence). It is accepted that the fidelity of any shadows caused by a projector may degrade as the FOV becomes larger.

Fov.jpg

Focus

A projected texture appears blurrier the further the projection point is from the projector. The Focus value controls how attenuated this effect is. Positive values keep the projection sharper for further, negative values make the projection start to blur at a closer range.

Focus.jpg

Ambiance

This adds a very blurred version of the projected image to all faces within the cone of influence, regardless of even whether they are in shadow or facing away from the projector. The goal is to very roughly simulate light influence which is being diffused in all directions by surfaces receiving a projected image. Thus it is acceptable that this be even brighter on faces facing away from the projector. The brightness of this effect should be proportional to the Ambiance value. It is probably a bug that values from 0.5-1.0 seem to have no additional effect above the 0.5 value.

Amb.jpg

Projectors: 'Lighting and shadows' disabled

  • When 'Lighting and shadows' is disabled, a projector behaves like a point light, it continues to obey the Color, Intensity, Radius, Falloff attributes of the light.

Deferred rendering and Environment

Atmospheric settings

Atmospheric/Sky (aka WindLight) settings should function pretty much identically regardless of whether 'Lighting and Shadows' is enabled (they may be slightly better or otherwise more accurate when 'Lighting and Shadows' is enabled, but the difference is hardly noticeable if things are working right). This can be tested by comparing the Environment Editor's sky presets in both modes (especially the more 'extreme' presets like Gelatto).

Envboth475.jpg

Water settings

Although the overall appearance of water is a bit different with 'Lighting and Shadows' enabled, it should still respond similarly to all tweaks in the Advanced Water Settings section of the Environment Editor. This can be tested by comparing the Environment Editor's water presets in both modes.