Difference between revisions of "Homework4W14"

From Immersive Visualization Lab Wiki
Jump to: navigation, search
(Optional Work (Max. 10 Points))
(Grading)
 
(15 intermediate revisions by one user not shown)
Line 3: Line 3:
 
For this assignment you can obtain 100 points, plus up to 10 points for extra credit.  
 
For this assignment you can obtain 100 points, plus up to 10 points for extra credit.  
  
This homework assignment is due on '''March 20th, 2014''' at 3pm in lab 260. Matteo and Thinh are going to have a Q&A session on '''Wednesday, February 26th''' at '''4pm''' in lab 260.
+
This homework assignment is due on '''March 20th, 2014''' at 3pm in lab 260. Matteo and Thinh are going to have a Q&A session on <del>'''Wednesday, February 26th'''</del> now '''Friday, February 28th''' at '''4pm''' in lab 260.
  
The goal of this project is to create a 3D user interface for any one or a combination of the three input devices used in this course (Kinect, Hydra, Leap). The user interface needs to implement at least one instance of each of the following universal 3D interaction tasks discussed in class: selection, manipulation, navigation, way finding, travel, system control. Your application is not allowed to use input devices other than those above mentioned. Specifically, you are not allowed to use keyboard or mouse.
+
'''UPDATE:''' Because the Q&A didn't happen as planned, we rescheduled it to Friday. We are also moving the deadline for the first blog to that Friday, Feb 28th at 23:59pm.
  
If you decide to use the Razer Hydra, your application needs to use no more than one button on each controller. This is to encourage you to make the application easier to use, and to think about system control issues.
+
The goal of this project is to create a 3D user interface for any one or a combination of the three input devices used in this course (Kinect, Hydra, Leap). The user interface needs to implement at least one instance of each of the following universal 3D interaction tasks discussed in class:
 +
 
 +
* selection
 +
* manipulation
 +
* wayfinding
 +
* travel
 +
* system control
 +
 
 +
Your application is not allowed to use input devices other than those above mentioned. Specifically, you are not allowed to use keyboard or mouse.
 +
 
 +
If you decide to use the Razer Hydra, your application needs to use no more than one button on each controller. This is to encourage you to make the application easier to use, and to think about system control issues. You can use the little joysticks on the controllers as long as you do not use them to replicate functionality that would otherwise be done with buttons. For example, using the joysticks to input direction is permitted.
  
 
You are welcome to come up with any 3D interaction task that you get approved by the course staff.  
 
You are welcome to come up with any 3D interaction task that you get approved by the course staff.  
 +
 +
Your application needs to use a physics engine (we recommend Bullet), unless it absolutely doesn't make sense.
 +
 +
Again, unless it absolutely doesn't make sense, your application needs to support shadows. OSG has its own turnkey [http://trac.openscenegraph.org/projects/osg//wiki/Support/ProgrammingGuide/osgShadow shadow rendering feature], called a nodekit. Shadows help tremendously with the placement of 3D shapes in a 3D world, if no actual 3D display is used.
  
 
If you do not come up with your own task, the following default task applies.
 
If you do not come up with your own task, the following default task applies.
Line 24: Line 38:
  
 
Have a movable point (or spot) light source in the scene that the user can move around; this light source needs to be visually represented somehow, for instance by drawing a sphere in its location.
 
Have a movable point (or spot) light source in the scene that the user can move around; this light source needs to be visually represented somehow, for instance by drawing a sphere in its location.
 
You need to use a physics engine.
 
 
You need to support shadows. OSG has its own [http://trac.openscenegraph.org/projects/osg//wiki/Support/ProgrammingGuide/osgShadow shadow rendering feature]. Shadows help tremendously with the placement of 3D shapes in a 3D world, if no actual 3D display is used.
 
  
 
You need to have camera (or other navigation) controls, so that the user can place and orient the objects to match their appearance in the picture.
 
You need to have camera (or other navigation) controls, so that the user can place and orient the objects to match their appearance in the picture.
Line 43: Line 53:
 
==Grading==
 
==Grading==
  
Besides the implementation of the demo program, this project requires weekly blog updates with at least one paragraph with a progress report, and at least one picture of the state of the program. The deadlines for the blog updates are on Wednesday evenings at 11:59pm. Updates are expected on the following dates: 2/26, 3/5, 3/12, 3/19. The first blog update on 2/26 needs to contain a link to the picture you are going to model in 3D. The last blog update on 3/19 needs to contain a picture showing the 3D-modeled scene representing the image picked in the first week.
+
Besides the implementation of the demo program, this project requires weekly blog updates with at least one paragraph with a progress report, and at least '''one picture''' (e.g., a screenshot) of the state of the program. The deadlines for the blog updates are on Wednesday evenings at 11:59pm. Updates are expected on the following dates: <del>2/26</del> '''now 2/28''', 3/5, 3/12, 3/19.  
  
 
The maximum number of points for the various components of this project are as follows:
 
The maximum number of points for the various components of this project are as follows:
Line 53: Line 63:
 
* Extra credit: 10 Points
 
* Extra credit: 10 Points
  
The blog gets graded by how complete it is. Technical and creativity score will be determined by the course staff's objective and subjective opinion of the interface. Ease of learning represents how easy it is to learn the controls. This will be decided by an independent jury member who is familiar with 3D user interfaces in general, but not with your interface specifically.
+
The blog gets graded by how complete it is. Technical and creativity score will be determined by the course staff's objective and subjective opinion of the interface. The UI evaluation aims at usability, which includes how easy it is to learn the controls. This will be decided by an independent jury member who is familiar with 3D user interfaces in general, but not with your interface specifically.
  
 
You can use any cloud-based Blog tool you'd like (such as Blogger or WordPress), as long as you can share the blog's URL with instructor, TA and tutor by email. The UCSD Ted tool supports blogs as well, feel free to use it.
 
You can use any cloud-based Blog tool you'd like (such as Blogger or WordPress), as long as you can share the blog's URL with instructor, TA and tutor by email. The UCSD Ted tool supports blogs as well, feel free to use it.
Line 63: Line 73:
 
* Camera path editor: define of a series of camera positions/orientations, and allow playback of a smooth camera motion along the path by interpolating between the camera positions. ('''5 points''')
 
* Camera path editor: define of a series of camera positions/orientations, and allow playback of a smooth camera motion along the path by interpolating between the camera positions. ('''5 points''')
  
* Save function: allow saving your 3D model to a file on disk, and demonstrate that it can be loaded back in later, with the same ability to edit as before. ('''5 points''')
+
* Save function (particularly for the default task): allow saving your 3D model to a file on disk, and demonstrate that it can be loaded back in later, with the same ability to edit as before. ('''5 points''')
  
 
* Video: shoot a ~2 minute video of your application, demonstrating all of its features. It must have a title slide and either subtitles or a voice-over. Upload it to the internet (eg, Youtube), and send the URL to instructor, TA and tutor. ('''5 points''')
 
* Video: shoot a ~2 minute video of your application, demonstrating all of its features. It must have a title slide and either subtitles or a voice-over. Upload it to the internet (eg, Youtube), and send the URL to instructor, TA and tutor. ('''5 points''')

Latest revision as of 10:33, 10 March 2014

Contents

Homework Assignment 4: Final Project

For this assignment you can obtain 100 points, plus up to 10 points for extra credit.

This homework assignment is due on March 20th, 2014 at 3pm in lab 260. Matteo and Thinh are going to have a Q&A session on Wednesday, February 26th now Friday, February 28th at 4pm in lab 260.

UPDATE: Because the Q&A didn't happen as planned, we rescheduled it to Friday. We are also moving the deadline for the first blog to that Friday, Feb 28th at 23:59pm.

The goal of this project is to create a 3D user interface for any one or a combination of the three input devices used in this course (Kinect, Hydra, Leap). The user interface needs to implement at least one instance of each of the following universal 3D interaction tasks discussed in class:

  • selection
  • manipulation
  • wayfinding
  • travel
  • system control

Your application is not allowed to use input devices other than those above mentioned. Specifically, you are not allowed to use keyboard or mouse.

If you decide to use the Razer Hydra, your application needs to use no more than one button on each controller. This is to encourage you to make the application easier to use, and to think about system control issues. You can use the little joysticks on the controllers as long as you do not use them to replicate functionality that would otherwise be done with buttons. For example, using the joysticks to input direction is permitted.

You are welcome to come up with any 3D interaction task that you get approved by the course staff.

Your application needs to use a physics engine (we recommend Bullet), unless it absolutely doesn't make sense.

Again, unless it absolutely doesn't make sense, your application needs to support shadows. OSG has its own turnkey shadow rendering feature, called a nodekit. Shadows help tremendously with the placement of 3D shapes in a 3D world, if no actual 3D display is used.

If you do not come up with your own task, the following default task applies.

Default User Interaction Task: 3D Modeling Tool

Implement a simple software tool for 3D modeling. The task is to model in 3D the scene of an image of your choice. A good approach to find suitable images is to do a Google image search. If you search for "still life" you will find thousands of images. Pick one of a 3D scene with multiple 3D objects.

Write a 3D modeling tool to allow the user to model the objects in the picture with. It is sufficient to offer a few of the standard OSG shapes, as long as their sizes can be changed.

You will need to implement a grouping function, which will group multiple objects together, so that they can be moved around as a unit.

You are encouraged to use textures as images on the 3D geometry you create, but only if the texture was either selected from a list of stored textures, or if the user draws it within the application.

Have a movable point (or spot) light source in the scene that the user can move around; this light source needs to be visually represented somehow, for instance by drawing a sphere in its location.

You need to have camera (or other navigation) controls, so that the user can place and orient the objects to match their appearance in the picture.

Besides geometry creation and material property functions, another useful function is a replication function to duplicate an object or group of objects. Implement it.

A good example for what this could look like is in this MakeVR video at time point 3:32, where a fire hydrant is created from multiple objects using the Hydra-successor Stem.

Alternative Ideas

  • 3D Angry Birds game: with your physics engine, you can easily have the user launch birds or simpler shapes within a 3D world, with the goal of destroying structures consisting of basic geometric elements. Hydra or Leap should work well for this game.
  • 3D Pinball: This could be very interesting: instead of two paddles, the player might have an array of square blocks to shoot up to hit the ball into a 3D obstacle course. This might work particularly well with the Leap.
  • 3D Minigolf: Using the Kinect, evaluate a golf swing and hit a golf ball into a small obstacle course.

Grading

Besides the implementation of the demo program, this project requires weekly blog updates with at least one paragraph with a progress report, and at least one picture (e.g., a screenshot) of the state of the program. The deadlines for the blog updates are on Wednesday evenings at 11:59pm. Updates are expected on the following dates: 2/26 now 2/28, 3/5, 3/12, 3/19.

The maximum number of points for the various components of this project are as follows:

  • Blog: 10 Points
  • Technical quality: 60 Points
  • Creativity: 20 Points
  • Independent, subjective UI evaluation: 10 Points
  • Extra credit: 10 Points

The blog gets graded by how complete it is. Technical and creativity score will be determined by the course staff's objective and subjective opinion of the interface. The UI evaluation aims at usability, which includes how easy it is to learn the controls. This will be decided by an independent jury member who is familiar with 3D user interfaces in general, but not with your interface specifically.

You can use any cloud-based Blog tool you'd like (such as Blogger or WordPress), as long as you can share the blog's URL with instructor, TA and tutor by email. The UCSD Ted tool supports blogs as well, feel free to use it.

Extra Credit (Max. 10 Points)

You can achieve extra credit for the following things:

  • Camera path editor: define of a series of camera positions/orientations, and allow playback of a smooth camera motion along the path by interpolating between the camera positions. (5 points)
  • Save function (particularly for the default task): allow saving your 3D model to a file on disk, and demonstrate that it can be loaded back in later, with the same ability to edit as before. (5 points)
  • Video: shoot a ~2 minute video of your application, demonstrating all of its features. It must have a title slide and either subtitles or a voice-over. Upload it to the internet (eg, Youtube), and send the URL to instructor, TA and tutor. (5 points)