header

Developing an Arcade Game


Semester:

WS 2013

Type:

Pro-Practical

Lecturer:

Credits:

Links:

Campus , Results

Contact:

mingli@informatik.rwth-aachen.de
Note: This page is for a course from a previous semester.
Find a list of current courses on the Teaching page.
Course Dates:

Type

Date

Room

Team Assignment Meeting September 23 2013, 15:00–16:30 E3 119
Tech Intro Meeting October 2 2013, 10:00–15:00 E3 118
Kickoff Meeting October 14 2013, 14:00–15:30 E3 118
Milestone Meeting 2 December 16 2013, 14:00–15:30 E3 118
Milestone Meeting 3 January 27 2014, 14:00–15:30 E3 118
Milestone Meeting 1 November 18 2013, 14:00–15:30 E3 118
Final Release Deadline February 3 2014, 23:59 <via git/email>

In this practical course, the students will implement an arcade game, which combines concepts of classic games, like Super Mario Bros. or Battle City, with eye catching 3D visual effects (cf. Battle Rush, Battlefield 3, Super Mario Bros 2.5D, or Super Mario 3D Land).

The game will be a single-player game for PC platform. Participants will work in small teams. Within each team, there will be subteams concentrating on the game engine (graphics and game logic) or the content creation. Although the students can focus on a smaller problem, they have to ensure that their parts fit into the whole framework of the game. Therefore, the intercommunication between the group members is of a very high priority in order to define precise interfaces and common data structures.

Basically, students will learn to organize themselves as part of a bigger project. Depending on the topic of the group, students will learn to implement a specific part of a game.

  • Graphics:

    For a high visual quality of the game, students will have to implement several shaders in the rendering pipeline that is based on OpenGL. This includes effects like complex materials (e.g. relief mapping) and post processing effects (e.g. glow, deferred lighting, motion blur, reflection). A template based on ACGL (Aachen Computer Graphics Library, a high level abstraction of OpenGL) will be provided for a quick start.

  • Game Logic:

    Although the rendering is in 3D, the game logic is implemented in 2D. Students will implement basic physics simulation, like collision and gravity. The movement of the game character will be restricted by the static scene, e.g. the tank can move only in the streets, and it can be blocked by an obstacle. Of course if you want you can create destructible assets and roll over! Students should also handle the event trigger, e.g. earn speed boost when hit bonus box.

  • Content Creation:

    Students will have to create the game world, e.g. a super mario level or a city scene for the tank battle. Since this kind of modeling should be done on a very high abstraction level, single instances of geometry will have to be created with common tools like blender or 3dsmax. Furthermore, the group has to create the textures for the geometry, which can be done with tools like gimp or photoshop.

Every group can propose its favourite arcade game concept and themes, e.g. paper tank/catoon style in a kids room.


Software Engineering

The course will teach the participants how to develop a complex project using software engineering techniques.

  • Application Specification:

    In our scenario, the supervisors will provide a description for each part of the project. The students have to understand it and clarify any questions in the first stage of the project.

  • Software Design:

    The students have to create rough class diagrams that describe the data structures and the internal relationships of their application. The team has to organize itself and it has to set the responsibilities for the different components of the software. In this stage, any common interfaces and data structures with other groups have to be defined.

  • Coding:

    Each group has to implement their specific topic. Most of the work can be done independently of other groups as long as the interfaces and data structures do not change. If any changes are necessary for a single group, it has to make an appointment with the other groups to clarify the changes as fast as possible.

  • Testing:

    The students will have to test their application with artificial data as long as it is not integrated into the full framework. However, in order to ensure the quality of the product, the supervisors will also test the application from time to time and therefore the program has to run on a specific target computer that is provided by our chair.

  • Integration:

    After each milestone, the groups will have to integrate the single parts in order to present the full game in regular time intervals.

  • Report:

    During the course, the students should make some notes on problems, difficulties and solutions which they have chosen. At the end of the course, they have to hand in a very small report including the mentioned aspects.

Requirements

  • Students have to know C/C++ programming.
  • OpenGL: It would be better to know OpenGL.

Downloads

Disclaimer Home Visual Computing institute RWTH Aachen University