Rendering System

From Second Life Wiki
Revision as of 02:08, 15 November 2010 by HaZarD Gearhead (talk | contribs) (Initial summary of the events that happen in the viewer's rendering pipeline.)
Jump to navigation Jump to search

Rendering System of SecondLife Viewer 1.22

The SecondLife Viewer uses OpenGL to interface with the graphics hardware.

Rendering in the viewer starts in llviewerdisplay.cpp in the display() method.

Rendering follows this flow of events:

  • check window state and client state

Don't render if window is minimized.

Don't render if client is in startup state.

If client is in teleport mode only draw a static screen and progress bar.

If client requested a logout don't draw anything else.

prepare for next frame:

  • update camera
  • clear buffer, for drawing of dynamic textures
  • setup rendering
  • reset lights to SL defaults

update window and dynamic textures:

  • update (draw) dynamic(/render-to-texture) textures

for each dynamic texture:

-> save camera and viewport and clear the depthbuffer if required

-> render to framebuffer

-> use glCopyTexSubImage2D to copy results to texture

-> restore camera and viewport

  • if any dynamic textures were updated clear color and depth buffer
  • set viewport up (with offsets and window dimensions)

update scene:

  • set camera up

display_camera_update() creates projection matrix and clip distance

  • update HUD
  • update geometry
  • cull geometry
  • clear/flush last frame
  • update images (?)
  • state sorting
  • rebuild draw pools
  • update sky

redraw skytexture and cubic environment map

draw geometry

  • if render scene to texture (if vertex shaders supported) bind frame buffer to FBO
  • render pipeline

unbind vertex buffers (?)

set safe default state values (matrices and stuff)

set fog and lights

for each drawpool:

- render faces to vertex buffer

- render vertex buffer to frame buffer (?)