1 / 26

Simplified 3D Viewing Process: Triangles Rasterization & Interpolation

Explore the rasterization of triangles, hardware-friendly algorithms for rendering, edge equations for determining pixel positions, color and Z value rendering, Gouraud shading, attribute derivation, perspectively correct interpolation, and more.

leroyp
Download Presentation

Simplified 3D Viewing Process: Triangles Rasterization & Interpolation

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Model Space World Space View Space MC Model Transformation WC Viewing Transformation VC Projection Transformation Viewport Transformation DC PC Normalization & Clipping NC Projection Space Normalize Space Display Space 3D Viewing Process • 3D viewing process

  2. Simplified View • The Data Flow: 3D Polygons (+Colors, Lights, Normals, Texture Coordinates…etc.) • 2D Polygons • 2D Pixels (I.e., Output Images) Transform (& Lighting) Rasterization

  3. Attributes  Varying Transform (& Lighting) Rasterization fragment shader vertex shader vertex attributes: Color, Normal, Tex_coord, …etc. varying variables: interpolated from vertices to internal pixels

  4. Key Questions • Q1: What screen pixels are covered by the triangles? • Q2: How to interpolate the attributes?

  5. Rasterization

  6. Triangles Only • We will discuss the rasterization of triangles only. • Why? • Polygon can be decomposed into triangles. • A triangle is always convex. • Results in algorithms that are more hardware friendly.

  7. Being Hardware Friendly • [Angel 5e] Section 7.11.3 : • Intersect scan lines with polygon edges. • Sort the intersections, first by scan lines, then by order of x on each scan line. • It works for polygons in general, not just in triangles. • O(n log n) complexity  feasible in software implementation only (i.e., not hardware friendly)

  8. Using Edge Equations • Find the edge equations for P1-P2, P2-P3, P1-P3 • For each pixel, test which sides of the edges it is at. • Q: Do we need to test every pixel on the screen? P1 ege defined by Ax+By+c=0 P3 P2

  9. Example P1 ege defined by Ax+By+C=0 P3 P2

  10. Example • Now we have P1-P3 defined by 2x+y-4=0 • To test if a point (u,v) is inside the triangle, we calculate 2(u)+(v)-4. For example, (0,0) leads to 2(0)+(0)-4=-4 • So the negative side is inside. • Use P2 to decide which side is inside. • Negate A,B,C if you prefer the positive side P1 Ax+By+C=0 P3 P2

  11. Color and Z • Now we know which pixels must be drawn. The next step is to find their colors and Z’s. • Gouraud shading: linear interpolation of the vertex colors. • Isn’t it straightforward? • Interpolate along the edges. (Y direction) • Then interpolate along the span. (X direction)

  12. (255, 0, 0) (0, 0, 0) (0, 0, 0) Red (0, 0, 0) (255, 0, 0) Green (0, 0, 0) (0, 255, 0) (0, 0, 0) (0, 0, 255) (0, 255, 0) Blue (0, 0, 255) (0, 0, 0) Attribute Derivation • Color Interpolation

  13. Interpolation OpenGL uses interpolation to find proper texels from specified texture coordinates

  14. Perspectively Correct Interpolation • The previous slide is not “perspectively correct” • Consider the interpolation along the vertical (Y) direction. Should the checkers spaced equally? • Use the s to t conversion shown earlier, then you get the perspectively correct interpolation.

  15. Interpolation in World Space vs Screen Space • P1=(x1, y1, z1, c1); P2=(x2, y2, z2, c2); P3=(x3, y3, z3, c3) in world space • If (x3, y3) = (1-t)(x1, y1) + t(x2, y2) then z3=(1-t)z1+t z2; c3=(1-t)c1+t c2 P1=(x1,y1,z1) P3=(x3,y3,z3) P2=(x2,y2,z2)

  16. P1 P3 P2 Interpolation in World Space vs Screen Space • But, remember that we are interpolating on screen coordinates (x’, y’): y’ P’1 P’2 x’

  17. Let P’1=(x’1, y’1); P’2=(x’2, y’2) and P’3=(x’3, y’3)= (1-s)(x’1, y’1) + s(x’2, y’2) • Does s=t? If not, should we compute z3 and c3 by s or t? • Express s in t (or vice versa), we get something like: • So, if we interpolate z on screen space, we get the z of some other point on the line • This is OK for Z’s, but may be a problem for texture coordinates (topic of another lecture)

  18. Appendix

  19. Derivation of s and t • Two end points P1=(x1, y1, z1) and P2=(x2, y2, z2). Let P3=(1-t)P1+(t)P2 • After projection, P1, P2, P3 are projected to (x’1, y’1), (x’2, y’2), (x’3, y’3) in screen coordinates. Let (x’3, y’3)=(1-s)(x’1, y’1) + s(x’2, y’2).

  20. (x’1, y’1), (x’2, y’2), (x’3, y’3) are obtained from P1, P2, P3 by:

  21. Since We have:

  22. When P3 is projected to the screen, we get (x’3, y’3) by dividing by w3, so: But remember that (x’3, y’3)=(1-s)(x’1, y’1) + s(x’2, y’2) Looking at x coordinate, we have

  23. We may rewrite s in terms of t, w1, w2, x’1, and x’2. In fact, or conversely Surprisingly, x’1 and x’2 disappear.

  24. What are Missing in This Course?

  25. Shadow • Loading 3D models directly from files • Three.js • Physically Based Rendering (PBR) See the gallery at: https://corona-renderer.com/gallery/

More Related