Week of | Meetings | Topics | Items of Note |
---|---|---|---|
Mon-02-Sep-2024 | 01 | Topics |
Noteworthy Items |
Mon-09-Sep-2024 | 02 03 | Topics |
|
Mon-16-Sep-2024 | 04 05 | Topics |
Noteworthy Items |
Mon-23-Sep-2024 | 06 07 | Topics |
|
Mon-30-Sep-2024 | 08 | Topics |
Noteworthy Items |
Mon-07-Oct-2024 | 09 10 | Topics |
|
Mon-14-Oct-2024 | |||
Mon-21-Oct-2024 | 11 12 | Topics |
|
Mon-28-Oct-2024 | 13 14 | Topics |
Noteworthy Items |
Mon-04-Nov-2024 | 15 16 | Topics |
|
Mon-11-Nov-2024 | 17 | Topics |
Noteworthy Items |
Mon-18-Nov-2024 | 18 19 | Topics |
|
Mon-25-Nov-2024 | 20 21 | Topics |
Noteworthy Items |
Mon-02-Dec-2024 | 22 23 | Topics |
Noteworthy Items |
Write 2 WebGL2 programs (HTML and JavaScript) to generate a Sierpiński Gasket (as named by Benoit B Mandelbrot) in 2D. One of your programs will use the random algorithm (Chaos Game, introduced by Barnsley) – see https://interactivecomputergraphics.com/8E/Code/02/gasket1.html – and the other will use the recursive algorithm – see https://interactivecomputergraphics.com/8E/Code/02/gasket2.html. You may use the sample code discussed in class as starting points for your work but remember to acknowledge your sources!
This assignment is worth 4 marks, according to the following rubric:
DePaul Univerity’s Center for Teaching and Learning has a useful resource describing the process of creating rubrics. Your comments about the following rubric are welcome via email
Criterion and Weight | Exemplary | Sufficient | Developing | Needs Improvement |
---|---|---|---|---|
Random (2) | Code functions as required and code is easily readable. Comments well written and explain rationale. | Code functions as required but code is not so easily readable. Comments well written but do not fully explain rationale. | Completed but code does not function as required. Comments not consistently done. | Not completed. Little to no comments in code. |
Recursive (2) | Code functions as required and code is easily readable. Comments well written and explain rationale. | Code functions as required but code is not so easily readable. Comments well written but do not fully explain rationale. | Completed but code does not function as required. Comments not consistently done. | Not completed. Little to no comments in code. |
Write a WebGL2 program (HTML and JavaScript) that generates a 3D Sierpiński’s Tetrahedron and builds an opaque (not wireframe) container around it that encloses the tetrahedron. This container should have a lid that opens (while being connected to the rest of the container along a common edge). Create a means to open the lid with an animation and to show that the tetrahedron is inside. Here is a sample tetrahedron from the textbook code. You may use the sample code discussed in class and the 315 lab as a starting point for your work but remember to acknowledge your sources!
Devise and describe tests to ensure:
This is not intended to be a programming question.
In two dimensions, we can specify a line by the equation y = mx + b, where m is the slope of the line and b is the point where it intercepts the y axis. Find an affine transformation that reflects two dimensional points about this line. Given a point P = (x, y), derive a transformation matrix M such that P’ = M x P is the reflected image of P. Note that if P is on this line, P’ == P
This is not intended to be a programming question.
Submit all your files in a single zip archive. The contents of your archive should include all the files needed to run your code (including copies of the Common files). Include a README file at the top level of your archive that explains where to find things. You should use the textbook’s convention of putting the shaders in your HTML file.
This assignment is worth 7 marks, according to the following rubric:
DePaul Univerity’s Center for Teaching and Learning has a useful resource describing the process of creating rubrics. Your comments about the following rubric are welcome via email
Criterion and Weight | Exemplary | Sufficient | Developing | Needs Improvement |
---|---|---|---|---|
WebGL2 Programming (5) | Code functions as required and code is easily readable. Comments well written and explain rationale. | Code functions as required but code is not so easily readable. Comments well written but do not fully explain rationale. | Completed but code does not function as required. Comments not consistently done. | Not completed. Little to no comments in code. |
Testing (1) | ||||
Transformation (1) |
Write a WebGL2 program (HTML and JavaScript) that builds on your code from Assignment 2 (code is provided if you did not complete Assignment 2), add some other boxes (or other objects) to the scene then add the ability for the camera to fly around the scene in 2 ways:
following a straight line, have the camera look down at the scene and update the point at which you are looking as you move along the line. Keep the same relationship between camera (eye point) and the point you are looking at as you move along the line: say your camera starts at location at (0,5,0) and ends at (0,5,-10) then your camera might start looking at (0,0,-1) and end looking at (0,0,-11). The height should be constant and allow you to fly over your scene at a comfortable distance (without hitting it).
following a circular spiral path, have the camera always looking at the centre of your scene (say (cx,0,cz)). Start your camera’s descent from a comfortable height (x,h,z) and a distance (r) from the centre (cx,h,cz). Make one or more complete passes to reach a height of (h/2) so that the camera stops at (x,h/2,z).
Provide an interface that allows the fly-by option to be selected and the parameters to be adjusted. See this example for interface ideas, which you can use as a starting point for your work but remember to acknowledge your sources!
Submit all your files in a single zip archive. The contents of your archive should include all the files needed to run your code (including copies of the Common files). Include a README file at the top level of your archive that explains where to find things. You should use the textbook’s convention of putting the shaders in your HTML file.
This assignment is worth 7 marks, according to the following rubric:
DePaul Univerity’s Center for Teaching and Learning has a useful resource describing the process of creating rubrics. Your comments about the following rubric are welcome via email
Criterion and Weight | Exemplary | Sufficient | Developing | Needs Improvement |
---|---|---|---|---|
WebGL2 Programming (7) | Code functions as required and code is easily readable. Comments well written and explain rationale. | Code functions as required but code is not so easily readable. Comments well written but do not fully explain rationale. | Completed but code does not function as required. Comments not consistently done. | Not completed. Little to no comments in code. |
Write a WebGL2 program (HTML and JavaScript) that builds on your code from Assignment 3. For fly-by option 1 (straight line), move the light with the camera and for fly-by option 2 (circular spiral), the light should be stationary. Add interface controls for the parameters of the lighting and shading. You can use the same material for your whole scene. See this example for interface ideas, which you can use as a starting point for your work but remember to acknowledge your sources!
Submit all your files in a single zip archive. The contents of your archive should include all the files needed to run your code (including copies of the Common files). Include a README file at the top level of your archive that explains where to find things. You should use the textbook’s convention of putting the shaders in your HTML file.
This assignment is worth 7 marks, according to the following rubric:
DePaul Univerity’s Center for Teaching and Learning has a useful resource describing the process of creating rubrics. Your comments about the following rubric are welcome via email
Criterion and Weight | Exemplary | Sufficient | Developing | Needs Improvement |
---|---|---|---|---|
WebGL2 Programming (7) | Code functions as required and code is easily readable. Comments well written and explain rationale. | Code functions as required but code is not so easily readable. Comments well written but do not fully explain rationale. | Completed but code does not function as required. Comments not consistently done. | Not completed. Little to no comments in code. |