CMG2
From Computing and Software Wiki
| Game Name (TBD) | ||||
|  Windows Cover | ||||
| Developer(s) | SE 4GP6 GROUP2 | |||
| Designer(s) | Jeremy Poitras Roshan Jesuratnam Lokesh Thakur | |||
| Writer(s) | Jeremy Poitras Roshan Jesuratnam Lokesh Thakur | |||
| Engine | C4 | |||
| Released | TBD | |||
| Genre | Action, Strategy, Puzzle | |||
| Artwork | Cartoon, Cell Shaded | |||
| Rating | TBD | |||
| Modes | Single player, Multiplayer | |||
| Platform(s) | Microsoft Windows, Mac OS X | |||
| Media | CD, DVD or McMaster CAS Server | |||
| System requirements | 600 MHz CPU, 128 MB RAM, 1.4 GB Hard disk space, 32 MB GPU | |||
(TBD) is a computer game developed by Group 2 of the Software Engineering & Game Design 2009/2010 4GP6 Capstone Project. 
All sections of this document are subject to change as the full scope of the product requirements and restrictions become available.
| Contents | 
Overview
(TBD- GameName) is a 3D action/strategy/puzzle game where players must capture multiple enemies with the intent of building a small army. As the player captures enemies they join the player where he/she can control each unit to further attack and capture larger and more menacing enemies. These friendly units are also used to solve puzzle that help move the player through each level. Levels will have an ultimate goal such as defeating a "Boss" enemy or capturing all units within it to give the user a goal to work towards. Each level contains new enemies with new abilities allowing for the users experience to evolve with each level.
Story
The story will be kept to a strict minimum so we can focus fully on game play. However the purpose of this story is TBD. The story should give the user a sense of belonging and responsibility in the game world. Story triggers and advancement should be used to introduce new enemies and characters as well as give the user a sense of linearity in the overall story. The user should see how the overall world dilemma is being solved or goal is being achieved. Please keep this in mind when putting ideas on paper.
Key Features List
- Build your army
 
- Like any hero, a humble beginning helps to encourage any underdog to overcome the odds. Capturing small creatures in the environment will help you build up a formidable force to conquer the land and further your goals. 
- Interactive creatures/units to create your thrilling army
 
- Creatures for you to overcome are what this game is about; they will all be rendered in the game’s 3D world to ensure that the world is beautiful and immersive as possible, as well as providing a rich combination of creature interactions.	
- Play simple & quick, let your creatures help you along the way
 
- Game play shines when a player has to capture another creature. The player can interact with the world directly in only one manner. A "shock wave rifle" will allow the player to impart a force on enemies and objects in an attempt to move them around to his/her advantage while fighting, solving puzzles, or trying to capture creatures. Once a creature is captures, it can be selected and ordered to move, follow the player, attack other creatures and even move object.
- Not all heroes are born of blood and tears
 
- The overall feel of the game however should not be dark or sinister. Creature deaths as well as the overall look of the environment, the creatures, and the larger enemies will be cartoonish. The intent is to focus on game play and bring a light hearted feeling to conquering each level.
Functionality and Gameplay
- Goal of the game
 
- The goal of the game is to conquer each land by assembling an army of creatures to do your bidding.
- Basic game play
 
- The main game play elements will be collecting creatures to help grow your army as well as solving environmental puzzle to help move through each subsection of a level.
- As creatures are defeated they will join your army enabling you to defeat and collect larger and more able creatures.
- The player is limited in how they interact with the world and rely mainly on the creatures to do the work.
- Point of view
 
- Set in a 3D environment, the camera will follow behind the player in a standard 3rd person view. The player will have full freedom of rotation but will be limited in how the control the pitch of the camera. This will enable the player to easily select creatures within their army as well as aiming of their "shock wave rifle".
- Interactive creatures/units to create your thrilling army
 
- This game is about the creatures and building armies with them. Our plan for this game is to include as many different types of creatures as possible to make the game play feel diverse and amusing. The table below list possible creatures with their description. If the creation of creatures and their animations ends up being more difficult than expected, time will be spent to analyse if we are able to reduce the number of creatures but make each creature more interactive.
| List of Creatures | |||
| Creature 1 | Render 1 | ||
| Creature 2 | Render 2 | ||
| Creature 3 | Render 3 | ||
| Creature 4 | Render 4 | ||
| Creature 5 | Render 5 | ||
Pace: Quick and Simple
The core game play is all about the player’s ability to carefully build an army and decide where and when to try and capture the next level of creature. Depending on the player's current army as well as the strategy they chose to engage the enemy, players can master each level in a combination of ways.
Once a player begins a level
- Use the environment and the "Shock wave rifle" to capture small non aggressive creatures.
- Select captured creatures to help solve environmental puzzles as well as attack aggressive creatures, or trap non aggressive ones.
- If attacking creatures kill a friendly creature it is removed from the game and must be replaced by capturing a new unit.
- Should the player be attacked and killed, he or she loses the level and must restart. (Levels may have multiple incremental steps).
- Accomplishing the overall goal brings the player to a new level where he or she can discover new creatures and new puzzles to be solved.
 
Priority in User Experience
There are four aspects of the user experience that we intend to work on intently to make our game as immersive and enjoyable as possible.
- Simple controls: The control has to be simple enough to be picked up quickly by any player.
- Clear objectives: At any moment of the game, the player must know what he has to do and how to do it.
- Good feedback: For every action you need to have a reaction. Every time an action is performed the game will let the player know(either through graphics or sounds) that the action was performed and what impact it had.
- Low input and high output: The game has to be simple to play but rewards the player properly in order to keep the player feeling good about their experience and want to continue.
 
Customer Requirements (CuRS)
(THIS SECTION NEEDS TO BE CHANGED LATER INTO FORMAL REQUIREMENTS "STYLE")
The game will be implemented using the C4 Gaming engine. The C4 engine provides the tools, such as graphics rendering, scene graphs, networking.
The following is a list of the features the minimal system should contain:
- Interface such that a non-expert programmer can customize the game. This includes the development of script elements (the non-expert uses scripts to develop a particular game play). Script elements include: spawn scripts (select object type and parameters to spawn an object), message scripts (display a message on the screen)
- Moving Objects, must have one of the following properties/controller assigned:
 - Random move controller,
 
- Path following controller
 
- Intelligent evasive controller
 
- Intelligent chasing controller
 
 
- Random move controller,
All objects, including the player will respect each other (collision detection) and the environment.
- Sound effects are played if you catch an object, if you are caught, and a danger warning sound is played if an object or character is approaching you and there is danger that you could be caught.
- Worlds, Artwork, must have at least two sample worlds such as a city and a forest environment. The types of objects should be identifiable by there shape. Other players should be animated, and look different then the default C4 Soldier character.
- User Interface, must implement a splash screen, a menu system (choose network mode, character name, etc.), a current score report, and pop-ups if other players join/leave the game.
- Networking, the game has to be multi player and you have to implement a Server Mode (host a game) and a Client Mode (join a game and participate in play).
- Documentation, must use a documentation tool (e.g. Doxygen or DocBook) for your code, a code repository (so many people can work on the same code), and an on-line electronic tool to write your documentation in your group (e.g. a Wiki).
Functional Requirements (FuRS)
This section describes the functional requirements of the game. Functional requirements describe the inputs, the behaviour, and outputs of a system. The functional requirements for the implementation of the (TBD) game is divided into lower level requirements, namely System Requirements (SyRS) and Subsystem Requirements (SuRS), for modular programming. Following image shows traceability between sets of requirements.
CuRS --> SyRS + Additional RS --> SuRS + Additional RS (Make this into a picture)
Each requirement will have the following attributes assigned to it; Object ID, Title, Statement Type, and Linkages. 
| Attribute | Description | |||
| Object ID | Every requirement, constraint, and goal will have an unique ID assigned for traceability. | |||
| Title | Object requirement, constraint, or goal that is to implemented. | |||
| Statement Type | Statement type will consist of the following; Technical Requirement - Technical requirements are objects which can be tested by means of acceptance. Constraint - Constraints are restrictions on the degree of freedom for implementation. Goal - Goals are projected low-priority features that enhance the system which are expected to be achieved. Information - Information gives general features of the systems behaviour. | |||
| Links | All lower level requirements will be linked to appropriate high level requirements, and vise versa | |||
System Requirements (SyRS)
In addition to customer requirements, this section will itemize all high-level requirements and constraints relevant for sucessful project completion.
SyRS.01--Characters shall be controllable by user
SyRS.02--Characters shall have user interface with various information
SyRS.03--Characters shall be animated in different states
SyRS.04--Game shall be implemented using the C4 Engine
SyRS.05--Worlds will be created in third party 3D modelers
SyRS.06--In game objects will be created in third party 3D modelers
SyRS.07--Online play shall be avialable to users
SyRS.08--All objects, characters, worlds shall respect collision
SyRS.09--Players shall trigger all actions in game
SyRS.10--All characters will be created in thrdp party 3D modelers
SyRS.11--All external models will be imported through COLLADA
SyRS.12--All external animations will be imported through COLLADA
SyRS.13--All Characters shall have definable attributes
SyRS.14--All Characters shall be handled by thier respective managers
SyRS.15--Interface shall be customizable
SyRS.16--Interface shall have scripts to customize gameplay
SyRS.17--Interface shall have Spawn Scripts
SyRS.18--Interface shall have Message Scripts
SyRS.19--Moving objects must have one property assigned to it
SyRS.20--Moving objects shall have one of the following attributes: Random move controller, Path following controller, Intelligent evasive controller, Intelligent chasing controller
SyRS.21--All characters and objects shall produce sound effects on collision/near collision
SyRS.22--Several Worlds must exist for gameplay
SyRS.23--Game shall have a splash screen
SyRS.24--Game shall have a main menu system
SyRS.25--Game shall have a score report
SyRS.26--Game shall have messages for events
SyRS.27--Game shall have networking capabilities
SyRS.29--Game shall operate in client mode or server mode
SyRS.30--Character types shall be distinguishable by their unique character model
Convert all Usage Aspects into more general statements and put them here!!!
SubSystem Requirements (SuRS)
This section will have specific requirements pertinent to in-game characters.
Main Character SuRS
M.SuRS.10--Character shall be created in Lightwave 3D
M.SuRS.11--Character shall be textured in Lightwave 3D
M.SuRS.12--Character shall be animated in Lightwave 3D
M.SuRS.13--Character shall be imported into C4 Engine through COLLADA
M.SuRS.14--Character animations shall be imported using COLLADA in .dae format
M.SuRS.01--Character shall be able to move through user definable controls
M.SuRS.02--Character shall have health bar on UI
M.SuRS.03--Character shall have "force gun" ammunition count on UI
M.SuRS.04--Character shall have count of enemies captured on UI
M.SuRS.05--Character shall have total score displayed on UI
M.SuRS.06--Character shall have terrain of world on UI (TBD)
 
M.SuRS.07--Character shall "run" when user-definable key is pressed
M.SuRS.08--Character shall "jump" when user-definable key is pressed
M.SuRS.09--Character shall apply "force" when user-definable key is pressed
M.SuRS.22--Character shall control friendly units
M.SuRS.15--Character rate of speed shall be definable through controllers
M.SuRS.16--Character shall respect all laws of physics
M.SuRS.17--Character shall be equipped with an array of weapons
M.SuRS.18--Character shall have the capabilities to attack catchable units
M.SuRS.19--Character shall have the capabilities to attack main character
M.SuRS.20--Character shall respect collision and the environment
M.SuRS.21--Character shall have regenerative health (TBD)
Capturable Characters SuRS
C.SuRS.01--Characters will move based on required controller behaviors as stated in the CuRS
C.SuRS.02--Character's health will be displayed on screen as a symbol.
C.SuRS.03--Characters will be qualitatively larger or smaller than the playable character.
C.SuRS.04--Characters will be created in Lightwave 3D.
C.SuRS.05--Characters will be textured in Lightwave 3D.
C.SuRS.06--Characters will be animated in Lightwave 3D.
C.SuRS.07--Character's rate of speed will be definable through controllers.
C.SuRS.08--Character's rate of rotation will be definable through controllers.
C.SuRS.09--Characters will respect all laws of physics as supported by the programming engine.
C.SuRS.10--When captured characters will become a friendly creature.
Friendly Characters SuRS
F.SuRS.01--Characters will move based on commands received from the player.
F.SuRS.02--Characters will attack based on commands received from the player.
F.SuRS.03--Characters will interact with objects based on commands received from the player.
F.SuRS.04--When selected by the player, character's visualization should change to indicate it's selected state.
F.SuRS.05--When selected, character's health will be displayed on user interface.
F.SuRS.06--Characters will be created in Lightwave 3D.
F.SuRS.07--Characters will be textured in Lightwave 3D.
F.SuRS.08--Characters will be animated in Lightwave 3D.
E.SuRS.09--Characters shall be imported into C4 Engine through COLLADA
E.SuRS.10--Characters animations shall be imported using COLLADA in .dae format
F.SuRS.11--Character's rate of speed will be definable through controllers.
F.SuRS.12--Character's rate of rotation will be definable through controllers.
F.SuRS.13--Character's rate of attack will be definable through controllers.
F.SuRS.14--Character's strength of attack will be definable through controllers.
F.SuRS.15--Character's total health will be definable through controllers.
F.SuRS.16--Characters will respect all laws of physics as supported by the programming engine.
F.SuRS.16--When killed, character will be removed from level.
Enemy Character SuRS
E.SuRS.01--Enemies shall be bigger in size (2x,3x bigger)
E.SuRS.02--Enemies shall be created in Lightwave 3D
E.SuRS.03--Enemies shall be textured in Lightwave 3D
E.SuRS.04--Enemies shall be animated in Lightwave 3D
E.SuRS.11--Enemies shall be imported into C4 Engine through COLLADA
E.SuRS.12--Enemies animations shall be imported using COLLADA in .dae format
E.SuRS.05--Enemies rate of speed shall be definable through controllers
E.SuRS.13--Enemies "intelligence" shall be definable through controllers
E.SuRS.14--Enemies rotation shall be definable through controllers
E.SuRS.09--Enemies will be controlled through Enemy Manager
E.SuRS.15--Enemy manager shall manage all spawns
E.SuRS.15--Enemy manager shall manage all deaths
E.SuRS.16--Enemy manager shall communicate with Main manager for all enemy related aspects
E.SuRS.17--Enemies shall have either random move, intelligent move, or path moving attributes assigned
E.SuRS.06--Enemies shall respect all laws of physics
E.SuRS.07--If Enemies are pushed by gravity gun, then Enemy shall move XX__PUSHDIST in direction of push
E.SuRS.22--Enemies shall have the capabilities to attack friendly units
E.SuRS.23--Enemies shall have the capabilities to attack main character
E.SuRS.08--Enemies characters shall be defined through Enemy Controller
E.SuRS.10--Enemies shall respect collision and the environment
E.SuRS.18--All spawned enemies shall be restricted to a predefined roaming zone
E.SuRS.19--Enemies shall destroy friendly units in XX__FRIENDLYUNITHIT moves
E.SuRS.20--Enemies shall destroy main character in XX__MAINMAXHIT moves
E.SuRS.20--Enemies shall be destroyed in XX__ENEMYHIT continous moves
E.SuRS.21--Enemies shall have regenerative health (TBD)
Environment SuRS
En.SuRS.01--Environments shall be created in Lightwave 3D
En.SuRS.02--World Objects shall be created in Lightwave 3D
En.SuRS.03--Environments shall be textured in C4 Engine
En.SuRS.04--World Objects shall be textured in C4 Engine
En.SuRS.05--World Objects shall be animated in Lightwave 3D
En.SuRS.11--Worlds shall have a top-down approach
En.SuRS.12--Worlds shall be designed for single player and multiplayer use
En.SuRS.05--Worlds shall be designed in 2D and converted to 3D
En.SuRS.13--Worlds shall use an abundance of textures
En.SuRS.14--Worlds shall use sounds for collision
En.SuRS.06--Worlds shall respect collision for all objects
En.SuRS.07--Worlds shall trigger new behaviours of objects
En.SuRS.08--Worlds shall have defined paths for characters to follow
En.SuRS.09--Worlds shall have moderate to high ambient lighting
En.SuRS.10--Worlds shall offer interaction with characters
Usage Aspects
Players
Players must have all tools and necessary controls to correctly move the avatar within the game. The following attributes outline major components the user has to work with;
- Player Control
 The player must have the ability to move through the world by walking, running and jumping.
 
- Player Control
- World Interaction
 The user must have the ability to interact with the world.
 
- World Interaction
- Multiple Unit Selection
 The user must have the ability to select multiple units at one time.
 
- Multiple Unit Selection
- Unit Management
 (Optional) The user must have the ability to quickly select subsets of units.
 
- Unit Management
- H.U.D
 Used to display pertinent and important information to the user such as health, number of units remaining, etc.
 
- H.U.D
- Console Commands
 Changing mouse sensitivity
 Changing controls
 Etc.
 
- Console Commands
World Designers
World designers will have most interaction in the World Editor of the C4 Engine. The following attributes must be streamlined to optimize efficiency and reliability.
- Generating Paths
 World Designers need a mechanism for creating a path that will be followed by a creature
 
- Generating Paths
- Placing Players
 World Designers need a mechanism for placing a player in the world with the appropriate model
 
- Placing Players
- Placing Enemies
 World Designers need a mechanism for placing creatures in the world with the appropriate model and behaviors.
 
- Placing Enemies
- Placing Elements
 World Designers need a mechanism for placing objects in the world with the appropriate model and appropriate interaction behaviors.
 (Eg. Can be picked up by creature x, can be moved by player.)
 
- Placing Elements
Programmers
Based on the current customer requirements as well as the game concept/play mechanics outlined in this requirements document, the developers will require the following set of design tools.
Controllers
- Path followers
 Given a set of location markers in the world/level an NPC should follow the path marked out by these markers in a repeating loop.
 A path follower will travel faster than the player such that the player will be required to first analyze the path being followed before he/she can effectively capture the unit.
 
- Path followers
- Evaders
 Evasion NPCs should simply try to avoid being captured by ALL active players.
 Evaders will attempt to run from the closest player using different strategies such as zig-zag, random turns and random direction changes.
 Evaders will run only slightly slower than the player, making it possible for the player to capture the unit.
 
- Evaders
- Attackers
 Attacking characters will actively seek out and attack players as well as a players friendly units.
 Initially, attackers will simply "roam" or "wander" in designated areas based on map design and placement.
 Should an attacker encounter an enemy, it will then actively seek out that enemy in an attempt to destroy it.
 If the enemy is too quick and can distance itself adequately from the attacker, the attacker will simply return to its original roaming zone and wait for the next attacker to approach.
 
- Attackers
- Random Runners
 Place in the world based on map design these NPC simply run around in random directions waiting to be captured. Random runners will run slightly slower than the player making it possible for the player to capture the unit.
 
- Random Runners
- Follower
 Once a unit has been captured, the unit will follow the player as a "friendly unit". The unit should always follow the player within a given radius. Unit speed will be based on the units' size and properties.
 Larger units may walk slower than the player.
 
- Follower
Tools
- Enemy Manager
 The enemy manager will enable programmers to maintain a working list of the current active enemies or non "friendly units" in the world.
 
 
- Enemy Manager
- Friendly Unit Manager
 The friendly unit manager will enable programmers to maintain a working list of the active friendly units tied to a specific player.
 
 
- Friendly Unit Manager
- Controller Manager (Local)
 The controller manager will enable programmers to attach and manage multiple controllers designated to a single unit.
 
 
- Controller Manager (Local)
- Selection Manager
 The selection manager will enable the programmer to maintain a working list of the current friendly units that are selected to perform an action.
 
 
- Selection Manager
- Path Determination
 Given two points, mainly the units current location and a destination, the unit should dynamically find the most efficient path to its destination taking into account the terrain as well as any potential obstacles.
 
 
- Path Determination
- Multiple Unit Selection
 Based on a geometry drawn by the user onto the playing field, a list of friendly units that appear within that bounding geometry should be built.
 
- Multiple Unit Selection
Artwork, Sounds & Animations
Artwork
The artwork of the game is very simple and unporportioned to give a cartoon like appearance. Environments will consist mainly of open concepts with moderate to high lightning. The feel of the game is aimed to target players of all ages and is intended to give a overall 'warm' feeling to the player.
- (TBD-Name) is the main protangnist of the game. He is of moderate height compared to the rest of the characters. He is very simple phsyically, with attributes similar of a (TBD - Add more as character is created)
- (TBD-Name) are catchable characters within the game. They vary is size, shape, and texture. They are smaller than the main character but various features to distinguish their properties.
- (TBD-Name) are friendly characters which are captured characters. There characteristics might change once captured. (TBD)
- (TBD-Name) are enemy characters which vary from size to shape to physical appearance. They can be distinguished by their larger size and more agressive and darker look.
Sounds
Due to limited resources and experience in creating sound effects and soundtracks, this game will feature existing samples from video games that already exist on the market. Since this game is non-commercial, VGMusic.com and other various sources may be used to generate any sound effects and soundtracks used throughout the game.
Sounds might also be created through applications such as Apple's Garageband and mixed in with existing soundtracks.
Animations
Characters are created in Newtek's Lightwave 3D and imported into C4 Editior using the COLLADA plugin. The characters skeleton and editable mesh will be weighted and exported into COLLADA fully reset and non-scaled. All animations such as running, walking, jumping, dying, attacking, shooting, etc will also be loaded into COLLADA and will be created in Lightwave as appropriate. From this, characters and corresponding animations will be loaded into the C4 Model Editor where it will be assigned to each other for usage in design.
Terminology
- NPC - Non Player Controlled Character
- H.U.D - Heads up display
- Friendly Creature - Captured creature controlled by the player
- Unit - Interchangeable with Friendly Creature


