Difference between revisions of "CISC440 F2019 HW4"
From class_wiki
								
												
				|  (→Graduate students only) |  (→Required elements) | ||
| Line 11: | Line 11: | ||
| ** Apply at least one texture to the object either through [https://www.youtube.com/watch?v=6F5M0ZuL-eg wrapping] or [https://www.youtube.com/watch?v=JX-UwgKaPsA painting] and save the resulting .obj | ** Apply at least one texture to the object either through [https://www.youtube.com/watch?v=6F5M0ZuL-eg wrapping] or [https://www.youtube.com/watch?v=JX-UwgKaPsA painting] and save the resulting .obj | ||
| * In your C++ OpenGL program, load the .obj and animate a camera path that shows it from different angles and distances, calling glm::lookat() to recompute the view matrix at every step.    | * In your C++ OpenGL program, load the .obj and animate a camera path that shows it from different angles and distances, calling glm::lookat() to recompute the view matrix at every step.    | ||
| − | ** Your camera path should be created from a Catmull-Rom cubic spline.  All control points should be chosen by you and hard-coded your program as an array of 3-D positions. | + | ** Your camera path should be created from a Catmull-Rom cubic spline.  All control points should be chosen by you and hard-coded your program as an array of at least 25 3-D positions. | 
| ** The camera path should be displayed initially as a continuous curve (i.e., connected line segments).  So it should be computed outside of your animation loop | ** The camera path should be displayed initially as a continuous curve (i.e., connected line segments).  So it should be computed outside of your animation loop | ||
| ** The camera position (i.e., the view matrix) should be updated with each pass through the animation loop and the scene redrawn from the new location.  Your up vector may remain constant, and your center point (where the camera is looking) may either be fixed to the centroid of the object that you loaded, or it can be updated to "look ahead" of the camera for an architectural walk-through or roller coaster scenario. | ** The camera position (i.e., the view matrix) should be updated with each pass through the animation loop and the scene redrawn from the new location.  Your up vector may remain constant, and your center point (where the camera is looking) may either be fixed to the centroid of the object that you loaded, or it can be updated to "look ahead" of the camera for an architectural walk-through or roller coaster scenario. | ||
| + | ** The camera path does not need to be a loop.  Regardless, when the last position is reached, the animation should automatically start over at the first position | ||
| + | ** The 'p' key should toggle pause/play in the animation.  In pause mode the camera should not move | ||
| Submit your C++ code, the textured .obj you created, and a short text description of how you created it. | Submit your C++ code, the textured .obj you created, and a short text description of how you created it. | ||
Revision as of 22:47, 31 October 2019
Due Monday, November 11
Description
In this assignment you will create and texture an object (loosely defined) in Blender, then display it in an OpenGL program which animates camera motion along a Catmull-Rom spline.
Required elements
-  In Blender, create and texture an object and export it as an .obj that is loadable by your OpenGL program
- The object may not be a default mesh in Blender such as a plane, monkey, cylinder, or sphere. Rather, it should be an edited version such as the apple created in this tutorial or the cube manipulations here
- Apply at least one texture to the object either through wrapping or painting and save the resulting .obj
 
-  In your C++ OpenGL program, load the .obj and animate a camera path that shows it from different angles and distances, calling glm::lookat() to recompute the view matrix at every step.  
- Your camera path should be created from a Catmull-Rom cubic spline. All control points should be chosen by you and hard-coded your program as an array of at least 25 3-D positions.
- The camera path should be displayed initially as a continuous curve (i.e., connected line segments). So it should be computed outside of your animation loop
- The camera position (i.e., the view matrix) should be updated with each pass through the animation loop and the scene redrawn from the new location. Your up vector may remain constant, and your center point (where the camera is looking) may either be fixed to the centroid of the object that you loaded, or it can be updated to "look ahead" of the camera for an architectural walk-through or roller coaster scenario.
- The camera path does not need to be a loop. Regardless, when the last position is reached, the animation should automatically start over at the first position
- The 'p' key should toggle pause/play in the animation. In pause mode the camera should not move
 
Submit your C++ code, the textured .obj you created, and a short text description of how you created it.
Graduate students only
- Add a square textured "floor" to your scene which animates a morph between two face images. You should use the mesh-warping algorithm introduced in class and described in further detail in Section 2.1 of Wolberg, "Recent Advances in Image Morphing", 2003.
- The 'f' key should toggle between whatever center point you are using for glm::lookat() during the normal camera animation, and looking at the center of the morph square (even as the camera continues to move)
- The morph should take about 5 seconds to complete and then repeat
