Difference between revisions of "DPS905 Hic Sunt Dracones"
(52 intermediate revisions by 9 users not shown) | |||
Line 1: | Line 1: | ||
− | {{ | + | {{GAM670/DPS905 Index | 20111}} |
− | = | + | = Razed by Fire = |
− | == | + | == Project Marking Percentage == |
− | === | + | <big> |
+ | Group work: 25% (25 <= xx <= 50) | ||
+ | Individual work: 75% + (50 <= xx <= 75) | ||
+ | ------------------------- | ||
+ | Total 100% | ||
+ | </big> | ||
− | + | == Information == | |
+ | Our code uses the [http://www.microsoft.com/downloads/en/details.aspx?displaylang=en&FamilyID=3021d52b-514e-41d3-ad02-438a3ba730ba June 2010 DirectX SDK]. You'll need to uninstall the August 2007 SDK, and install the June 2010 SDK. | ||
+ | Download the code from svn trunk, and compile. | ||
+ | All resource files required for running the game (audio, models, textures) can be found in \branches\resources | ||
+ | Audio files (.xwm) are encoded in the xWMA format, which offers 30x compression ratios over regular WAVE files. The audio engine is perfectly capable of playing .wav files without any modification, but you should encode them using the [http://msdn.microsoft.com/en-us/library/ee415930(v=VS.85).aspx xmaencode] tool located in the DirectX SDK Command Prompt before committing to the repository. | ||
− | + | Right now audio files are only played globally. Jon will be implementing X3DAudio within the next few days. | |
− | + | == Repository == | |
+ | === Repo path === | ||
+ | * old path | ||
+ | *: svn://zenit.senecac.on.ca/dps901_103rep8 | ||
+ | * new path | ||
+ | *: svn://zenit.senecac.on.ca/dps905_111rep5 | ||
+ | === Trunk Status === | ||
+ | Current repository status information can be found by typing "!svn" in the [irc://irc.freenode.net/hsd IRC chat channel] | ||
== Team Members == | == Team Members == | ||
Line 18: | Line 34: | ||
''' [mailto:dhhodgin@learn.senecac.on.ca,jrbuckley@learn.senecac.on.ca,jboelen@learn.senecac.on.ca,sweerdenburg@learn.senecac.on.ca,dacallow@learn.senecac.on.ca?subject=dps901 Group Email]''' | ''' [mailto:dhhodgin@learn.senecac.on.ca,jrbuckley@learn.senecac.on.ca,jboelen@learn.senecac.on.ca,sweerdenburg@learn.senecac.on.ca,dacallow@learn.senecac.on.ca?subject=dps901 Group Email]''' | ||
− | * [mailto:dhhodgin@learn.senecac.on.ca?subject= | + | * [mailto:dhhodgin@learn.senecac.on.ca?subject=dps905 Daniel Hodgin] |
− | * [mailto:jrbuckley@learn.senecac.on.ca?subject= | + | * [mailto:jrbuckley@learn.senecac.on.ca?subject=dps905 Jon Buckley] |
− | * [mailto: | + | * [mailto:dacallow@learn.senecac.on.ca?subject=dps905 Kaitlyn Callow] |
− | + | * [mailto:dperit@learn.senecac.on.ca?subject=dps905 David Perit] | |
− | * [mailto: | ||
− | |||
Line 29: | Line 43: | ||
* '''IRC''' | * '''IRC''' | ||
− | ** Sundays at | + | ** Sundays at 9pm in channel [irc://irc.freenode.net/hsd #HSD] on irc.FreeNode.net |
+ | |||
+ | == Game Information == | ||
+ | |||
+ | == Phase 1 == | ||
+ | === Proposal === | ||
+ | For our second run at this project we will be adding more functionality to the game. More in depth COLLADA loading, more refined particle systems, refined XAudio, and visibility performance increases. | ||
+ | |||
+ | == Phase 2 == | ||
− | + | == Phase 3 == | |
− | |||
− | = | + | =Old history from DPS901= |
== Phase 1 == | == Phase 1 == | ||
Line 53: | Line 74: | ||
* soldiers as simple rectangles | * soldiers as simple rectangles | ||
* flat level ground for the world | * flat level ground for the world | ||
− | * ability to look around with a mouse and steer with keyboard. Movement is on x and y planes but not z, the dragon is at a fixed elevation in the air. | + | * ability to look around with a mouse and steer with keyboard. Movement is on x and y planes but not z, the dragon is at a fixed elevation in the air. The process of [http://www.marvelousessays.com essay writing] will be much easier with MarvelousEssays.Com as there are a lot of highly professional and talented writers who are always eager to help you out with any sort of academic assignments regardless of the complexity levels. The process of [http://www.marvelousessays.com essay writing] will be much easier with MarvelousEssays.Com as there are a lot of highly professional and talented writers who are always eager to help you out with any sort of academic assignments regardless of the complexity levels. I do know what I�m talking about! I do know what I�m talking about! |
* a 'shoot' mechanic to attack cubes and rectangles | * a 'shoot' mechanic to attack cubes and rectangles | ||
Line 77: | Line 98: | ||
|- | |- | ||
− | |game logic | + | |game logic, camera, world |
|James | |James | ||
|- | |- | ||
− | |improvements to audio, specifically to | + | |improvements to audio, specifically to use OOG files |
|Jon | |Jon | ||
|- | |- | ||
− | | | + | |particle effects |
|Kaitlyn | |Kaitlyn | ||
|- | |- | ||
− | | | + | |collision detection, enemy management |
+ | |Steven | ||
+ | |||
+ | |- | ||
+ | |add stock objects (sphere, torus, etc.), more primitives | ||
|Steven | |Steven | ||
Line 102: | Line 127: | ||
{| border="1" | {| border="1" | ||
|- | |- | ||
− | | | + | |computer a.i. logic |
|--- | |--- | ||
Line 111: | Line 136: | ||
|- | |- | ||
|} | |} | ||
+ | |||
+ | === Game Mockups === | ||
+ | |||
+ | * '''Objects''' | ||
+ | [[Image:btp901-fall2010-HSD-mockups-objects.jpg||| ]] | ||
+ | |||
+ | * '''Interface''' | ||
+ | [[Image:btp901-fall2010-HSD-mockups-Interface.jpg||| ]] | ||
+ | |||
+ | * '''Possible Map of the World of the Game''' | ||
+ | [[Image:btp901-fall2010-HSD-mockups-map.jpg||| ]] | ||
+ | == Phase 2 == | ||
+ | === Information === | ||
+ | ==== Class Diagram ==== | ||
+ | [[Image:HSD_ClassDiagram.png|700px| ]] | ||
+ | ====Collision Detection==== | ||
+ | For collision detection, we used axis-aligned bounding boxes (AABB). These build an imaginary box around a visible object, as defined by: | ||
+ | * minx | ||
+ | * miny | ||
+ | * minz | ||
+ | * maxx | ||
+ | * maxy | ||
+ | * maxz | ||
− | + | These specify the minimum and maximum bounds of the bounding box in world space. From these, collisions (or general overlap) may be determined via the [http://en.wikipedia.org/wiki/Separating_axis_theorem separating axis theorem]. This theorem can be applied to three-space using the name separating plane theorem and states that "if two convex objects are not penetrating, there exists an axis for which the projection of the objects will not overlap." In implementation, this can be done as such: | |
− | {| | + | |
− | |- | + | <pre> |
− | | | + | typedef struct Rect3D { |
− | + | float minx; | |
+ | float miny; | ||
+ | float minz; | ||
+ | float maxx; | ||
+ | float maxy; | ||
+ | float maxz; | ||
+ | }; | ||
+ | |||
+ | // AABB Collision Detection in C | ||
+ | int doesOverlap(Rect3D a, Rect3D b) { | ||
+ | return !( a.minx > b.maxx || a.maxx < b.minx | ||
+ | || a.maxy < b.miny || a.miny > b.maxy | ||
+ | || a.maxz < b.minz || a.minz > b.maxz ); | ||
+ | } | ||
+ | </pre> | ||
+ | |||
+ | Note that AABB vs. AABB collision is one of a vast number of cases. For a more comprehensive listing, see [http://www.realtimerendering.com/intersections.html Real Time Rendering]. Also, for performance increase one may wish to investigate [http://en.wikipedia.org/wiki/Space_partitioning spatial partitioning]. | ||
+ | |||
+ | === Screenshots === | ||
+ | [[Image:DPS901_HSD_103_Mansions.png|200px| ]] | ||
+ | [[Image:BTP901-fall2010-HSD-sceenshot-12-04-10.JPG.JPG|200px| ]] | ||
+ | |||
+ | [[Image:BTP901-fall2010-HSD-enemies-11 30 2010.jpg.jpg|400px| ]] | ||
+ | |||
+ | [[Image:BTP901-fall2010-HSD-particles-2-11_30_2010.jpg|400px| ]] | ||
− | + | [[Image:BTP901-fall2010-HSD-particles-1-11_29_2010.jpg|400px| ]] | |
− | |||
− | |||
− | | | + | [[Image:BTP901-fall2010-HSD-sceenshot-11_22_10-1.JPG|200px| ]] |
− | | | ||
− | + | [[Image:BTP901-fall2010-HSD-sceenshot-11_22_10-2.JPG|200px| ]] | |
− | + | [[Image:BTP901-fall2010-HSD-sceenshot-11_17_10.JPG|200px| ]] | |
− | |||
− | + | [[Image:BTP901-fall2010-HSD-sceenshot-Skybox.JPG||200px| ]] | |
− | |||
− | + | [[Image:Water.JPG||200px| ]] | |
− | |||
− | + | [[Image:dragon4.jpg|200px| ]] | |
− |
Latest revision as of 07:31, 13 January 2012
GAM670/DPS905 | Weekly Schedule | Student List | Project Requirements | Teams and their Projects | Student Resources
Contents
Razed by Fire
Project Marking Percentage
Group work: 25% (25 <= xx <= 50) Individual work: 75% + (50 <= xx <= 75) ------------------------- Total 100%
Information
Our code uses the June 2010 DirectX SDK. You'll need to uninstall the August 2007 SDK, and install the June 2010 SDK. Download the code from svn trunk, and compile.
All resource files required for running the game (audio, models, textures) can be found in \branches\resources
Audio files (.xwm) are encoded in the xWMA format, which offers 30x compression ratios over regular WAVE files. The audio engine is perfectly capable of playing .wav files without any modification, but you should encode them using the xmaencode tool located in the DirectX SDK Command Prompt before committing to the repository.
Right now audio files are only played globally. Jon will be implementing X3DAudio within the next few days.
Repository
Repo path
Trunk Status
Current repository status information can be found by typing "!svn" in the IRC chat channel
Team Members
Meetings
- IRC
- Sundays at 9pm in channel #HSD on irc.FreeNode.net
Game Information
Phase 1
Proposal
For our second run at this project we will be adding more functionality to the game. More in depth COLLADA loading, more refined particle systems, refined XAudio, and visibility performance increases.
Phase 2
Phase 3
Old history from DPS901
Phase 1
Proposal
Our game is a third-person action shooter where the user is a dragon that is flying over villages and attempting to reign havoc. In reaction to the attacks soldiers gather in increasingly greater numbers and try to fight back against the dragon. The dragon will be able to destroy both the villages and the soldiers by shooting fire at them. The rate that villages & soldiers appear at will increase over time making it more difficult to kill enough to keep their numbers down.
A bar at the top of the screen will represent how close the number of soldiers is to reaching the amount required to 'fight you off'. Once the bar is full you the game ends and your score is awarded. The goal is to kill soldiers at a fast enough rate to lower the bar and survive the longest while destroying all the villages that you can.
Some technical design challenges include adding controller support for mouse, keyboard and maybe joystick and algorithms for choosing where and when to create new buildings or villagers.
The initial version of our game will include:
- villages as simple cubes
- soldiers as simple rectangles
- flat level ground for the world
- ability to look around with a mouse and steer with keyboard. Movement is on x and y planes but not z, the dragon is at a fixed elevation in the air. The process of essay writing will be much easier with MarvelousEssays.Com as there are a lot of highly professional and talented writers who are always eager to help you out with any sort of academic assignments regardless of the complexity levels. The process of essay writing will be much easier with MarvelousEssays.Com as there are a lot of highly professional and talented writers who are always eager to help you out with any sort of academic assignments regardless of the complexity levels. I do know what I�m talking about! I do know what I�m talking about!
- a 'shoot' mechanic to attack cubes and rectangles
Later versions -could- include (time permitting):
- increasing numbers of soldiers with bar showing representation of numbers
- dynamic village and soldier placement
- multiple attacks using a 'rock paper scissor' concept with certain attacks needed for certain targets. Make the user need to think about their attack choice
- some visceral feedback to user (such as: slight screen bob with dragon's wings, more dramatic elongated perspective when flying forward to make it feel faster, screen shakes and bobs to various things like attacks, etcs)
- extra terrain details
- line of sight checks
- collision detection
Likely Improvements To Engine
primary focus areas
graphic improvements | Daniel, Kaitlyn |
game logic, camera, world | James |
improvements to audio, specifically to use OOG files | Jon |
particle effects | Kaitlyn |
collision detection, enemy management | Steven |
add stock objects (sphere, torus, etc.), more primitives | Steven |
import model script | Daniel |
other possible
computer a.i. logic |
comprehensive camera motion |
Game Mockups
- Objects
- Interface
- Possible Map of the World of the Game
Phase 2
Information
Class Diagram
Collision Detection
For collision detection, we used axis-aligned bounding boxes (AABB). These build an imaginary box around a visible object, as defined by:
- minx
- miny
- minz
- maxx
- maxy
- maxz
These specify the minimum and maximum bounds of the bounding box in world space. From these, collisions (or general overlap) may be determined via the separating axis theorem. This theorem can be applied to three-space using the name separating plane theorem and states that "if two convex objects are not penetrating, there exists an axis for which the projection of the objects will not overlap." In implementation, this can be done as such:
typedef struct Rect3D { float minx; float miny; float minz; float maxx; float maxy; float maxz; }; // AABB Collision Detection in C int doesOverlap(Rect3D a, Rect3D b) { return !( a.minx > b.maxx || a.maxx < b.minx || a.maxy < b.miny || a.miny > b.maxy || a.maxz < b.minz || a.minz > b.maxz ); }
Note that AABB vs. AABB collision is one of a vast number of cases. For a more comprehensive listing, see Real Time Rendering. Also, for performance increase one may wish to investigate spatial partitioning.