Sample WebGL program for OSU CSE 5542 by Prof. Han-Wei Shen (shen.94@osu.edu)
Learn WebGL by studying the sample code in the following order:
- open-canvas.html/js: A simple program that opens a webgl canvas and initialize webgl graphics context
- simple-triangles.html/js: draw two triangles using Array Buffer VBO in a default color (red)
- triangle-strip.html/js: draw two triangles using Triangle S trip and Array buffer VBO
- viewport-demo.html/js: display the same 2 triangles over 9 different viewports; allow change background color
- color-triangles.html/js: add an additional color VBO to the shader. Notice how fragment colors are interpolated from the triangle vertices
- color-interleaved.html/js: set an interleaved position/color into a single VBO; and then assign the positions/colors to two different attribute arrays
- element-array/html/js: show you how to draw triangles using an element array VBO to index triangle vertices
- simple-transform.html/hs: simple transformation of 2D triangles using glm (left mouse click and drag to rotate)
- Mtransforms.html/js: demonstrate how to apply different transformations to different objects.
- hierarhicalXform.html/js: demonstrate how hierarchical transformation can be constructed for three square.
- 3Dcube.html/js: the first 3D cube drawing program where you will learn how to set up a camera and needed transformation matrices
- shading.html/js: implementation of Gouraud shading for a cylinder.
- texture.html/js: this shows you how to perform 2D texture mapping. make sure you have downloaded the file earth.png. Also, you need to disable the browser restriction of reading local files (browser specific).
- teapot.html/js: A 3D rendering of Utah teapot in Json format
- textureTeapot.html/hs: A texture mapped Utah teapot in Json format
- cubeMappedTeapot.httml/js: Environment cube map example
- teapotFBO.html/js: A frame buffer object example (wiah a slight visibility bug)
Additional files for OSU CSE 5542 AU 2020
A. uniform-color-xform.html/js: this program shows you how to use uniform variable to set per object color (not per vertex color) and also how to use 'r' and 'R' to rotate two squares, one counter clockwise and the other clockwise.
B. 8-transform-ortho2D.html/js: this sample code show you how to use ortho2D call to change the range of visibe points from [-1,1]x[-1,1] to an arbitrary range using orthographic projection. you use gl.ortho() to define a projection matrix and pass it to the vertex shader.
C. xform.html/js; xform2.html/js for illustrating transformations. D. xform{3,4,5}.html/js to illustrate hierarchical transformations.
That's it folks, for now.