Open main menu

CDOT Wiki β

GAM670/DPS905 Project Requirements 20111

Revision as of 22:27, 4 January 2011 by Chris Szalwinski (talk | contribs) (Phase 2)

Appointment Schedule

Team Name Date and Time
Tuesday January 18 10:00AM
Tuesday January 18 10:15AM
Tuesday January 18 10:30AM
Tuesday January 18 10:45AM
Tuesday January 18 11:00AM
Tuesday January 18 11:15AM


Due Dates

Proposed game and team members selected January 18
Proposal completed and members' roles selected January 31
Phase 1 completed February 22
Phase 2 completed - Presentation March 22
Approval meeting with instructor March 29
Phase 3 completed - Presentation April 12-14



Project Requirements

Your game involves a real-time audio-visual experience in some sort of 3-D world. The user must be able to control at least some aspects of the game with a controller, and there must be some use of sound, both in the background and in response to some action in your game. The user should have control over which display devices, resolution and input devices are used at any time during the game. Your game may however offer only a subset of the available resolutions and input devices. Finally, your design code must differ significantly from the samples presented in class and you must identify the unique elements of your code in your submissions. Each game is a team effort. The structure of each team is up to the team members. Each member must contribute their own work in a selected area or areas of their choosing. All members should contribute to the design part of the assignment.

Phase 1

The first phase is a 200-300 word informal, written proposal of what you intend to implement in your game: what you imagine your game doing. Your description should identify the objects in your game and include one or more illustrations of your design. The illustrations may be hand-drawn and scanned. Included in your illustrations should be a map of what you envisage the 3D world of your game will look like, with 3-dimensional coordinates of all of the major points in the world. Your map should include all of the "actors" (moving objects) in the world. You should identify the coordinates as realistically as possible, being aware that you may need to scale them up or down as you implement your design in code.

Submit the written proposal on your wiki team-page under Proposal and Map of the World of the Game.

Before continuing phase 1, please do the following

  1. Read Hints for Using SVN to collaborate on school projects
  2. Update your team's wiki page with your team's repository path information under Repo Path
  3. Create a directory with your seneca id under the branch sub-directory of your team's repository. This will be your home directory for development; for details see: Directory Structure
  4. One of the team members should volunteer to export svn://zenit.senecac.on.ca/dpsgam/trunk/15-Controller into the trunk of your team's repository
    For hints see Start the project by continuing an existing work

Each team member should have their own successfully compiled version of the 15-Controller sample in their own workspace in the branch sub-directory of their team's repository. Branch submission path: svn://zenit.senecac.on.ca/dps901_103rep??/branches/SenecaID/15C

Start doing the above by branching the 15-Controller into svn://zenit.senecac.on.ca/dps901_103rep??/branches/SenecaID/15C. See here for help: Preparing Branches/workspace for development


The source code for the upgraded 15-Controller sample should include the following updates:

  • add your own name to the caption for the dialog box
  • change the window title to include the name of the team


Merge all of the team members' 15C workspaces back to trunk so that the caption of the dialog box shows all of the names of the team members. See Merging your work back to trunk for detail


The purpose of this first phase of the project is twofold:

  • to define your game in both scope and detail and thereby to give your instructor some idea of your design: whether what you intend is too simple, too complex or about right
  • to ensure your instructor that you are ready to work with your own branch of your team's repository and ready to start modifying the framework to suit your team's design.

Your submission should enable your instructor to give you feedback and to discuss your proposal in some detail.

Your team should decide its own group to individual ratio for grading purposes and post the agreed ratio on its project page.

Your team must arrange a time and date to meet with your instructor to discuss the proposal and to commit the different responsibilities of the team members. This meeting should take place no later than week 6 of the semester, preferably earlier.

Phase 2

The second phase releases a version of the framework that includes the new features that your team has incorporated. This phase includes a presentation that shows how your new features work within your own game.

Phase 3

The third phase presents your completed game with your team's new features and two new features of other teams incorporated. Your presentation includes a demonstration of how the game plays along with an explanation of the innovative aspects that your team members have implemented. Each team has no more than 20 minutes to showcase its game.


Some Suggested Upgrades to the Framework

The Framework in its final stage consists of 12,000 source lines of code. The Framework is only a starting point and fallback position for the design of your game. There are numerous opportunities to refactor different parts depending upon what your game requires and what your personal interests are. Decisions to focus on certain parts should reflect the areas with which you wish to become more familiar. Listed below are some areas that you should consider in deciding where to devote your energy. If you wish to add items to this list, consult your instructor.

Each team will introduce its own upgrades to the Framework. The nature of these upgrades will vary from team to team. Each team member is responsible for a thorough understanding of at least one particular upgrade.