Labyrinth Zhou Zhen Barry Allison Stephen Kao Rex Ma
Software Environment OpenGL (Graphics) OpenGL (Graphics) OpenAL (Sound) OpenAL (Sound) C++ C++ Windows Environment – desirable portable code Windows Environment – desirable portable code Source Control (e.g Visual SourceSafe) Source Control (e.g Visual SourceSafe) Games Engine at least should be portable with wrapper for Environment specific code Games Engine at least should be portable with wrapper for Environment specific code Coded with Multi Processor / Dual Core PC ’ s in mind Coded with Multi Processor / Dual Core PC ’ s in mind Client Server (MMOG) Client Server (MMOG) Efficiency - Trade-offs if 60fps is goal, Full Screen more efficient, Compromises to Software Engineering Efficiency - Trade-offs if 60fps is goal, Full Screen more efficient, Compromises to Software Engineering Staged realeases – e.g. box without textures, no holes, no friction etc. Staged realeases – e.g. box without textures, no holes, no friction etc.
Architecture
Engine Components Renderer – First thing we need to see anything Renderer – First thing we need to see anything Texture Maps (MIP mapping), bump mapping (for ball) Texture Maps (MIP mapping), bump mapping (for ball) Model of World (Objects) – polygons (triangles), patches/surfaces, LOD Model of World (Objects) – polygons (triangles), patches/surfaces, LOD Physics Physics Collision Detection Collision Detection Sound Sound Spatial Partitioning / Culling, Use view frustrum (volume) with Octrees, Binary Space Partitioning (BSP), Portals. Spatial Partitioning / Culling, Use view frustrum (volume) with Octrees, Binary Space Partitioning (BSP), Portals. AI – Covered in other projects AI – Covered in other projects Animation/Simulation - Mesh, Skeletal (hierarchical), Inverse Kinematics Animation/Simulation - Mesh, Skeletal (hierarchical), Inverse Kinematics Network/Internet (MMOG) Network/Internet (MMOG)
Sound OpenAL or Commercial (Licensed) OpenAL or Commercial (Licensed) Stereo, Surround Sound – positional (but not above/below) Stereo, Surround Sound – positional (but not above/below) Mood Music – can depend on what is happening (e.g. search, fight) Mood Music – can depend on what is happening (e.g. search, fight) Filters due to environment (e.g. under water) Filters due to environment (e.g. under water) Use samples or procedurally generated sounds Use samples or procedurally generated sounds Complications - Mixing sounds, volume of each and synchronizing with events (e.g. collisions). Complications - Mixing sounds, volume of each and synchronizing with events (e.g. collisions). Occlusion (blocking – muffled & muted), obstructed (hear reflections) Occlusion (blocking – muffled & muted), obstructed (hear reflections) WAV, MP3, WMA, MIDI Samples – Maximum Memory vs. Channels WAV, MP3, WMA, MIDI Samples – Maximum Memory vs. Channels Labyrinth – Mono (stereo if time allows), Rolling based on speed, Collision with walls Labyrinth – Mono (stereo if time allows), Rolling based on speed, Collision with walls
References (Game Engine) “ Game Development – Harder Than You Think ” (2004) ACM Digital Library (See last years notes) “ Game Development – Harder Than You Think ” (2004) ACM Digital Library (See last years notes) “ Designing a PC Game Engine ” (1998) IEEE Digital Library “ Designing a PC Game Engine ” (1998) IEEE Digital Library Last Years 777 Notes Last Years 777 Notes COMPSCI 715 Resources COMPSCI 715 Resources Game Engine Anatomy Game Engine Anatomy
Modeling Three Stage of Development Three Stage of Development Stage One: Simple Model Stage One: Simple Model Single colour model Single colour model No hole in the labyrinth. No hole in the labyrinth. Stage Two: Texture Stage Two: Texture Put the basic texture into the labyrinth and ball. Put the basic texture into the labyrinth and ball. To have proper reflection on ball. To have proper reflection on ball.
Modeling Stage Three: The complete labyrinth Stage Three: The complete labyrinth Build the complete labyrinth. Build the complete labyrinth. With friction With friction Enhancement (If we have time) Enhancement (If we have time) Different environment (i.e. on the moon or Mars Different environment (i.e. on the moon or Mars
Texture mapping Aims Make it as realistic as possible Make it as realistic as possible Provide more details on the surface Provide more details on the surface
Texture mapping cont.. Ideal Provide multiple choice for user Provide multiple choice for user (ie Labyrinth can have multiple skins, user even can design their own skin) (ie Labyrinth can have multiple skins, user even can design their own skin)
Texture mapping cont.. Ideal First step First step Only use Phong shading algorithm for the ball Only use Phong shading algorithm for the ball Second step Second step Texture map a certain pattern on the ball, from that we can see how the ball actually rolling. Texture map a certain pattern on the ball, from that we can see how the ball actually rolling. Third step Third step Produce reflect image on the ball at real time Produce reflect image on the ball at real time
Texture mapping cont.. Technologies Bitmap Bitmap A traditional texture mapping method A traditional texture mapping method Bump mapping Bump mapping Creates apparent alteration to the geometry of the object surface Creates apparent alteration to the geometry of the object surface
Texture mapping cont.. Technologies Procedural textures Can get arbitrarily high resolution 3D textures for natural materials like wood and marble. Can get arbitrarily high resolution 3D textures for natural materials like wood and marble.
Interface Simple DirectMedia Layer (SDL) Simple DirectMedia Layer (SDL) A cross-platform multimedia library designed to provide low level access to audio, keyboard, mouse, joystick, 3D hardware via OpenGL. A cross-platform multimedia library designed to provide low level access to audio, keyboard, mouse, joystick, 3D hardware via OpenGL. For Labyrinth user input: For Labyrinth user input: Keyboard Keyboard Mouse Mouse Command base user interface Command base user interface Windows menu user interface Windows menu user interface
References (texture mapping) "Texture Mapping" Techniques (2004) "Texture Mapping" Techniques (2004) s22and23.html s22and23.html Burkhard's Lectures Texture Mapping (2005) Burkhard's Lectures Texture Mapping (2005) ndout6_1up.pdf ndout6_1up.pdf Nvidia (1999) Demos: Bubble Nvidia (1999) Demos: Bubble Solid Texturing of Complex Surfaces D. R. Peachey (SIGGRAPH 1985) Solid Texturing of Complex Surfaces D. R. Peachey (SIGGRAPH 1985) Reading material Lewis Procedural texture mapping on FPGAs Andy G. Ye & David M. Lewis Procedural texture mapping on FPGAs
Physically based modelling Physically based modelling is important in game development nowadays. Physically based modelling is important in game development nowadays. Laws of physics evaluated by the most modern 3D games for both motion and graphics calculation. Laws of physics evaluated by the most modern 3D games for both motion and graphics calculation. E.g. Collisions detection, Movement, Weather. E.g. Collisions detection, Movement, Weather. Physically based modelling engine has been used by many of simulator program too. Physically based modelling engine has been used by many of simulator program too.
Games in 1980s Vs Now In 80s, games is 2D and simple. Colourful, interesting game style and system requirement are the number of main factor to develop game. In 80s, games is 2D and simple. Colourful, interesting game style and system requirement are the number of main factor to develop game. Now, many games use 3D engine and physics engine to model. “ Realistic ” is the main factor for the game. Now, many games use 3D engine and physics engine to model. “ Realistic ” is the main factor for the game.
Games in 1980s Vs Now (Cont ’ d)
Physics Chips Because physics factor become more important in games today. Some computer add-on card for physics calculation have been developing too. Because physics factor become more important in games today. Some computer add-on card for physics calculation have been developing too.
Particle systems We will use Particle Systems to evalute our physical model. We will use Particle Systems to evalute our physical model. It need many of particle to support our the calculation. It need many of particle to support our the calculation. But it have many of advantages: But it have many of advantages: Reduces need for human animators Reduces need for human animators Reusable and react whatever user input Reusable and react whatever user input
Physics model evaluation We will use some formula in Newton ’ s laws and Circular motion to evaluate our physical model. We will use some formula in Newton ’ s laws and Circular motion to evaluate our physical model.
Labyrinth ball model There are 3 stage of the ball: There are 3 stage of the ball: Rolling Rolling We need to find out the location, velocity, acceleration. We need to find out the location, velocity, acceleration. Stable Stable When and why it is not rolloing. When and why it is not rolloing. Crushing Crushing Collisions detection Collisions detection
Challenge (Realistic Vs Performance) In real world: In real world: The movement of the ball is curve. The movement of the ball is curve. Friction on the wood plate. Friction on the wood plate. Collisions when ball crush the wall. Collisions when ball crush the wall. Wood is not “ perfectly ” hard. Wood is not “ perfectly ” hard. In Computer: In Computer: The movement is not curve but close to curve if large number of time calculation in a second. The movement is not curve but close to curve if large number of time calculation in a second. Friction and Collision detection model development. Friction and Collision detection model development.
Another challenge in development How many percentages of the ball, or which part of the ball on the hole to represent the ball is drop in the hole or just roll around it? How many percentages of the ball, or which part of the ball on the hole to represent the ball is drop in the hole or just roll around it? When the ball is fly over the hole but not drop? When the ball is fly over the hole but not drop?
References (Physical Model) “ Approximate and Probabilistic Algorithmn for Shading and Rendering Structured Particle Systems ” in SIGGRAPH 1985 porject Notes of Physically-Based Modelling for Compsci in University of Auckland /lectures/Burkhard/777Handout6.pdf Introduction to physically-based animation sically_Based.pdf sically_Based.pdf sically_Based.pdf sically_Based.pdf
References (Physical Model) Microsoft Flight Simulator Century of Flight Microsoft Flight Simulator Century of Flight tor/ tor/ tor/ tor/ EA - Battlefield 2 EA - Battlefield 2 attlefield2/us/features.jsp attlefield2/us/features.jsp 80 ’ s games in 80s Music Lyrics 80 ’ s games in 80s Music Lyrics
References (Physical Model) PC Hardware: Ageia PhysX Interview PC Hardware: Ageia PhysX Interview /001.htm /001.htm