From Cradle to Framebuffer

How to 3D

Chapter 5: Graphics Pipeline

From Cradle to Framebuffer

Before any pixels appear on the screen, your models must pass through an obstacle course of manipulations and challenges called the graphics pipeline. The pipeline roughly follows these stages:

  1. A geometric model is loaded or generated by your application and uploaded to the GPU in VBOs.
  2. The application issues a draw call.
  3. The vertex shader transforms the vertices, passing each through a series of coordinate systems that are convenient for performing various operations.
  4. Primitives that extend outside of the viewport are clipped so only their visible portions continue on through the pipeline.
  5. The positions of the clipped vertices are transformed into pixel coordinates.
  6. The fragment shader computes the colors of the fragments that fall between the surviving vertices.
  7. Fragments are tested to see if their colors should be written to the framebuffer. One typical test rejects any fragments that are farther from the viewer than a fragment drawn earlier.
  8. The colors of the surviving fragments either overwrite or blend with colors already written to the framebuffer.

You explored some of these stages in earlier chapters. For example, you've seen how to issue draw calls and write shaders for simple models defined in a small region of a 2D coordinate system. In this chapter, we open up all of space so that we can render complex 3D scenes containing many models. By the chapter's end, you'll be able to answer the following questions:

Once you've got a handle on this graphics pipeline, you'll be able to put the human viewer into a scene full of moving 3D models.

Spaces →