Dev - Mag - 04

Download as pdf or txt
Download as pdf or txt
You are on page 1of 23

ISSUE 4 2006

SOUTH AFRICA’S FIRST GAME DEVELOPMENT MAGAZINE


BACK OF A
NAPKIN:
PART 3: WHAT IS TEXTURE
FILTERING

THE WORK
AFTER THE WORK

THE BASICS
OF SOUND
DEVELOPMENT

MOBILE GAMES:
PART 2: MAKING MOVES

REVIEWS : GAUNTLETS FEATURE :


ENGINES AND FRAMEWORKS,
DEV.MAG ISSUE 4
THE QUALITY TOUCH
Crash Bandicoot 2D
CONTENTS
REGULARS
03 - ED’S NOTE
04 - DIGITAL STOMPIES

FEATURE
05 - ENGINES AND FRAME WORKS

SPOTLIGHT
07 - Unc1354m

REVIEW
08 - GAUNTLETS

DESIGN
09 - THE WORK AFTER THE WORK

10 - BACK OF A NAPKIN PART 3:


........WHAT IS TEXTURE FILTERING?

13 - MAKING 2D ASSETS WITH 3D


.........SOFTWARE

14 - THE QUALITY TOUCH PART 1:


.........THE MINIMUM .REQUIREMENTS

15 - SOUNDS GOOD: THE BASICS OF


.........SOUND DEVELOPMENT

TECH

17 - A LITTLE BIT ABOUT RECURSION

MOBILE

18 - MOBILE GAME DEVELOPMENT


.........
. IN JAVA

TAILPIECE

20 - THE TRUTH ABOUT


INSTITUTIONS

08 10 09
ED’S NOTE THE TEAM

ENIGMATIC ED
Stuart “GoNz0” Botma

Something has really grabbed the attention of the guys at Dev.Mag and I,
DASTARDLY DEPUTY
and that is just how far this project has come. Every week I hear stories
Rodain “Nandrew” Joubert
and see the evidence of what we have accomplished. We’ve been
mentioned in NAG (a gaming magazine that gets distributed DILIGENT DESIGNERS
internationally) and we are also a regular feature on their monthly cover Brandon “CyberNinja” Rajkumar
Paul “Higushi” Myburgh
DVD. We’ve been mentioned in a newspaper (The Citizen), in blogs, and in
numerous other places.
JUBILANT JOURNALISTS
Simon “Tr00jg” de la Rouviere
This is our 4th issue, which is, apparently, the ‘life-defining’ edition of a Ricky “Insomniac” Abell
magazine. I quote a GameMaker forum member: “Most e-zines don’t get to William “cairswm” Cairns
Bernard “BurnAbis” Boshoff
their 4th edition, they get their 3rd out but never a 4th. There’s some sort of
Danny “dislekcia” Day
invisible barrier there or something. The ones that make it though are
Andre “Fengol” Odendaal
usually here to stay.” Yuri “knet” Oyoko
Heinrich “Himmler” Rall
Matt “Flint” Benic
If our increasing quality is anything to go by, we’ll be here for quite a while.
Luke “Coolhand” Lamothe
But besides all the promotional talk, I’ve also got some other news: May/
Greg "Zphyr" Reveret
June saw the release of another game development e-magazine,
GameForce. We were lucky enough to be sent a complementary copy (+3 WIZARDLY WEBSTER

points) by the staff. All I can really say to them is “good luck and I hope you Claudio “Ch1ppit” de Sa

break the 4th edition barrier”.


WEBSITE
devmag.googlepages.com

Editor To join, make suggestions or just


Stuart ‘GoNz0’ Botma tell us we’re great, contact:
devmag@gmail.com

This magazine is a project of the


NAG Game.Dev forum. Visit us at
www.nag.co.za

03 DEV MAG ISSUE 4 2006


NEW LOCAL SITE DEVELOPMENT GOLDMINE?

A prolific game developer in South Africa has Need art? Need sound? Need resources?
recently launched their own Game Development site Need anything for a game and don't want to
(www.TheGameDeveloper.co.za). Much like a blog, go to the hassle of creating it yourself? Try
TheGameDeveloper will give voice to ideas and the Game Contents Resources from
methods of game development, with a focus on gpwiki.org, a place with a lot of cool links to
things such as frameworks and Delphi. online galleries, gaming material and a whole
manner of resources including sound, music,
2D/3D art, editors, icons and more. Best of
all, it's free. Get it all now at http://gpwiki.org/
index.php/Game_Content_Resources.

MORE PODDING ABOUT ...


NEWS

Gamasutra has some interesting things to offer this month. For a start, there's
a new GDC Radio podcast out about next-gen console development (http://
www.gdcradio.net/2006/06/gdc_radio_presents_next_gen_co.html) Also
available is a cool interview with the creator of Earthworm Jim, Doug
Tennapel (http://www.gamasutra.com/features/20060606/murdey_01.shtml).
He covers why fans are wrong and where EWJ on the PSP is going.

LEARNING FROM THE PROS

"I'm Jeff Tunnell and I've been 'making it big' in the game
business for a LONG time. MBG lets you learn, for free,
the lessons I paid a high price for." Make It Big In
Games is a blog written by a professional indie game
developer, offering insight, advice and instructions
regarding many common problems that hobbyist
developers face in their quest to become pros. Blog
entries consist of topics such as "Five Realistic Steps to
starting a Game Development Company" and "How 4e5 BACK IN ACTION
Much Money Can Indie Games Make?", amongst many
others. Visit http://makeitbigingames.com/ to find out The Gamedev.net Four Elements contest (http://www.gamedev.net/
community/contest/4e5) recently released the list of element entries
needed for its latest competition: Emotion, Economics, Emblem and
Europe. The idea of the contest is to get entries centred around these
four words, while still maintaining high standards of design, gameplay
and technical expertise. The competition runs until the end of November
and prizes include a free FastCapPro license for every contestant who
enters. Time to get busy, developers!

04 DEV MAG ISSUE 4 2006


ENGINES AND
FRAMEWORKS
Most game developers understand that there are various game engines available that will make their
development time easier. However a game engine by itself is often not enough. In fact it is often the case
that a Game Framework is more important than a game engine.

A
game engine is defined as "the game. Often this is so rigid that the extended it would be difficult to modify

core software component of a engine dictates what style or genre of the user input to do RTS controls.

DESIGN
video game. It typically handles game can be created using the engine.

rendering and other necessary (for example ORTS is an engine for RTS Many game developers consider

technology, but might also handle games, Half Life 2 is an Engine for FPS building their own Game Engine before

additional tasks such as game AI, games). On the other hand a Game making their own games. These

collision detection between game Framework is only an outline, containing developers typically see the

objects, etc. The most common element suggested methods and usually some development of a game engine as a

that a game engine provides is graphics code libraries etc. Game frameworks challenge to their technical abilities. As

rendering facilities (2D or 3D)." can typically be used to create any type they develop their engine they are

(Wikipedia). of game, but often with a lot more work continually learning the functionalities

than with a Game Engine. and abilities of their chosen libraries.

A framework is defined as a "support These developers typically spend

structure in which another software Game Maker can be considered a years continually extending their

project can be organized and framework rather than an engine as it is engines with all the latest features.

developed. A framework may include designed to make any type of game

support programs, code libraries, a rather than limiting the design options to Other game developers spend time

scripting language, or other software to a specific type of game. A simple learning to use the frameworks that are

help develop and glue together the example of this would be the various available to them. These frameworks

different components of a software options available for user input. Game are typically based on existing libraries

project." (Wikipedia). Maker has the facilities to allow the or other game engines. These

game developer to define how the user developers often are able to deliver

Based on these two definitions there is a input will function. In an FPS engine completed games that make use of the

very large intersection between a these controls would typically be defined features available in the framework.

framework and an engine. A Game as part of the engine and will work as Often that means that these completed

Engine is typically a very specific and the player would expect for an FPS, games do not have all the latest

clearly structured way of creating a while these controls can certainly be

05 DEV MAG ISSUE 4 2006


functionality and hardware driven embrace the game frameworks that are

capabilities that are available. available as they contain the low level

code needed to create top class games. BY THE WAY ...


Game Developers and Engine The best game developer using a poor

Developers are interdependent on each game engine and framework will only be Game Maker is more than
just a framework. Besides
other. The greatest Game Engine in the able to turn out a mediocre game.
the Code Libraries, there are
world is worthless unless a Game
a number of tools to make
Developer has been able to take the The time has come for Game development easier. These
engine and create a game using it. For Developers and Engine Developers in tools include an Image
the Game Developer to do this the South Africa to start communicating with Editor, IDE, Compiler and
Debugging. It also has
Engine Developer must extend the each other. As a unified team we can
extensive Help files that
engine further than just being a library turn out top class games that will rival
describe how to make use
into a Game Framework that contains what the rest of the world can produce. of the Framework, Libraries
examples, code snippets and that CAIRNSWM and Tools.
defines the relevant structure games
DESIGN

using the engine should use. At the

same time Game Developers need to

The above diagram outlines a typical game framework and the components that it

consists of. The scope of a typical framework is often broader than that of a

standard game engine.

06 DEV MAG ISSUE 4 2006


An interview with Unc1354m (or Unclesam for the leet impaired), the
creator of Killer Worm.

How long have you been developing games? This was laziness on my part. After making the
sprite for the worm and pixel humans, I felt that
[Since] June\July 2005. I had always been they didn’t need colour, but with a colour[ed]
setting it looked messed up, so I decided to
interested in making stuff, and the Game.Dev
make the terrain and clouds black and white.
section on the nag forums gave me the idea About halfway through the game I got the idea
to download Game Maker 6.1. [I] spent a few to add old film scratches to blend the black and
days going through all the tutorials, [and] after white in more. It came out pretty good.

SPOT LIGHT
about 4 days I released my first game.

Can you briefly explain the idea behind Killer Any current projects you would like to let us
Worm? know about?

The idea in Killer Worm is that you are a Outlaw Ball, an action platformer. This is a very
giant, hungry worm. You need to eat, but pixel large project, but [I] will keep the community
humans are so small [that] they don’t offer updated.
much food, so you need to eat alot of them. Thread found here:
Humans will start growing in technology and try http://www.nag.co.za/e107_plugins/forum/
to kill you since you are a huge threat to them; forum_viewtopic.php?20717
they grow from small pixels walking over the
ground oblivious to the fact that there’s a huge
worm hungry under them, eventually having Your game is one of the highest rated and
aircraft, tanks and the like in their name. downloaded games at the experimentalgame-
play website. How do you feel about that?
Killer Worm’s concept is truly original. What
inspired you? I wasn’t expecting it, since there are many
other great games there, but as long as it stays
The day Game.Dev’s 08 compo was at the view of potential downloaders I’m happy.
announced, I began brainstorming ideas
instantly, [and] for some odd reason I just
Do you see yourself expanding on Killer Worm
thought of an ant lion ‘consuming’ ants. It
seemed a good idea, but instead [I] decided to at all?
make it a worm ‘consuming’ humans. [I] started In the future, maybe. It has been a success. If
work right away, ideas kept coming to me, there’s ever a time, [when] I need something to
[and] eventually I came up with the basic game work on, it might be Killer Worm.
dynamics.

Is there anything else you would like to add?


What made you design the game in black and
white, instead of colour? Thanks to everyone who enjoyed Killer Worm
or my previous
games DM

07 DEV MAG ISSUE 4 2006


GAUNTLETS

G auntlets is a top-down puzzle


game. You control a tank and
tank, allowing enemy turrets or tanks to
shoot at you freely.
your aim is to progress through the The last problem with Gauntlets is the
different levels while setting high scores. respawn time. When your tank is
The game features various upgrades destroyed, it takes less than one second
such as speed, accuracy and attack that to respawn, leaving you with virtually no
help you pass stages and defeat time to prepare for any obstacles in the
enemies and bosses. way or any enemies that were firing at

REVIEW
The levels in Gauntlets are you. A good example of this is the anti
straightforward and don’t really require tank trap in the game. It is like a timed
Gauntlets offers you upgrades that help you
much thought. All you have to do is bear trap that opens and closes every
progress though the levels.
simply time your moves and go when it few seconds. If you timed your passage
looks safe. Of course, you also have to over the trap badly and you die, you will
shoot the occasional enemy tank but respawn right on top of the trap and it’s
they're not a focal point in the game. up to you to move your tank out of the
Control of your tank is accomplished way as quickly as you can.
through the use of your keyboard and Other than that, Gauntlets is a pretty
mouse, where the keyboard controls the fun game and if you take the time to play
through a few levels, you may not be
The levels in Gauntlets are full of obstacles
disappointed.
which you have to pass through using
KNET
combinations of firepower, speed and
accuracy.

movement of the tank and the mouse


lets you aim the turret and fire.
Gauntlets also has its problems, When you die, you set your high score and

though. One of them is its level design, sadly, that’s the end of it.

the levels themselves being very


repetitive (after completing the third
stage, you’ll know what to expect in
future ones). The second problem with FIND IT!

Gauntlets regards the camera control. http://www.apfstudios.com/


gauntlets_beta4.zip
The mouse lets you control the position
of the camera relative to the field, which
means you can move the cursor too far
off the screen and lose sight of your

08 DEV MAG ISSUE 4 2006


THE WORK AFTER THE
WORK ...
can't say I have been in the game development industry on your hard drive.
I long enough to become a Jedi Master of the industry, but I
have noticed certain trends that might help you. After almost 2 Most of my own games fall into the second category. In fact,
years of flogging my games about everywhere I can stick all of them do. What I have learned is that polish is king. A
them, I stumbled upon a few gems that are other people’s non-innovative game that took 4 months to make and was
games. These people are just like me: beginners who love reworked to death is much better than an innovative game
playing and developing games. Some were really innovative; filled with countless bugs.
others just filled up my hard drive. What I've noticed will
definitely help me for future projects. At the level of Why? When you are playing a game, you escape into the
DESIGN

development where you create games solely for the love of it other world and every kink (bug) you find along the way snaps
and not for the want of any money, you get 3 types of games. you back to reality. If you polish a game to every last bit, you
create not only a game, but an experience. The longer you
1. Teh SuXXor. manage to suspend the player's disbelief, the better that
player’s experience will be.
These games are not even half way decent, yet these
abominations are thrown out to the world. Their creators want I hate polishing my games and sifting through bugs. It
to show what they have, even though it is not really something sometimes feels as if the last bit, polishing, takes more time to
special. Usually, these games are platformers with ripped do correctly than the entire game up to that point. However,
sprites and very annoying midi music. once learned, the habit of polishing could be the best thing you
have done to your game development life.
2. Middle-McDonalds TROOJG

These games show some sign of innovation. They come from


The popular Indie title, Eets, is a good example of a game which
the minds that live to create something new, yet they fall off is simple at heart, but has been constructed with care.
the bus somewhere in the middle, usually due to being riddled
with bugs. These games, if done correctly, have the most
potential.

3. The Cream

Now this is the interesting category. These games are


spectacular for one reason: POLISH. Most of the time these
game are not even innovative, yet the creators had a goal and
stuck with their project, working countless hours to make it
perfect. These games are the ones that have endless forum
threads dedicated to them and that you bury in a special folder

09 DEV MAG ISSUE 4 2006


ON THE BACK OF A NAPKIN:
PART 3: WHAT IS TEXTURE FILTERING?
Now that we’ve got a solid foundation to work with, we can start looking at more relevant issues in 3D. This week we’ll
explore the idea of texture filtering and why it’s a good thing. We’ll find out what the various types of filtering actually do,
how they do them and how much of a frame rate hit each one causes. Read on if you want to know the difference
between bilinear, trilinear and anisotropic filtering.

T
he reason that texture filtering is used in 3D is a small
problem in the graphics industry called aliasing. Aliasing
problems are very easy to spot and can ruin the visual illusion
in a game.
Any computer screen is divided into pixels, duh. Each pixel
can only be a single colour, it’s impossible to have a pixel start
DESIGN

off being red on one side and then fade to black on the other.
The idea is that any image can be abstracted (see, it IS all
lies, even your screen) by splitting it into enough individual
pixels, unfortunately that doesn’t always work very well: We Bilinear filtering:
notice “blockiness” on diagonal and nearly vertical/horizontal
lines very easily. All you have to do to see the effects of bilinear filtering is to run
almost any game in software mode and then again with
Aliasing issues: hardware acceleration. Bilinear filtering makes textures
“smoother” and less blocky by grabbing four texels near the
Aliasing is called that because it’s the process of referring to sample point and averaging their values to get a blended
one thing by a set of different handles or names. In this case, colour for the screen pixel. It’s this “blurring” that smoothes out
we’re trying to get the pixels in a rendered image to refer to the the textures on the screen and avoids aliasing misses.
pixels in a texture. As each pixel in our image is rasterised, (if
you have no idea what that means, read the article on Vertices
again) interpolation gives us a unique set of texture co-
ordinates that tell us where on the texture to fetch the colour
our pixel should be. That sounds complex, but it isn’t:
Rasteriser starts on a new pixel onscreen -> interpolation
gives us the various values that pixel needs (by blending
between the various vertices) -> texture co-ordinates give us
an x and y point on our texture -> pixel is made that colour, There are a few problems with bilinear filtering though. The
with some adjustments for lighting and all that jazz. first and most visible is caused by mipmapping. Mipmapping is
Groovy. But textures are also made up of pixels (which we a technique used to manually limit aliasing issues by providing
call texels to save on headaches), so they can have aliasing smaller versions of textures that an engine uses when objects
issues of their own… Damn. Here’s a picture of some of the are far away, this means that there are less texels that it’s
problems: possible to miss when there are large “gaps” between sample

10 DEV MAG ISSUE 4 2006


points… Some engines use many levels of mipmaps,
especially if it’s possible to see very far into the distance. Anisotropic filtering, the next level:

Trivia: The famous “picmip 5” setting that Quake3 pros used So, both bilinear and trilinear filtering work in texture space to
simply scales down all the textures in the game, making a try to calculate the correct colour for a textured pixel.
512x512 texture effectively a 64x64 or 32x32 image instead. Unfortunately this isn’t always the best approach: It works fine
This blurs all the textures like crazy, but that’s not why the pros when the textures that are being filtered are displayed on
did it: They were after the small increase in FPS caused by polygons that are at right-angles to the camera, but it’s a poor
having smaller textures and less texel lookups and a rather approximation for polygons that are at non-perpendicular
debatable “visibility increase”… Oh what crap textures you angles. This is because of the shape of a pixel on screen
have grandma! All the better to see you with dear. when projected into texture space depends on the angle of the
polygon the texture is being used on. Wait, that sounds
So, mipmapping was invented before bilinear filtering as a way confusing… Here’s a picture:
to deal with distance aliasing issues. The smaller textures
(remember how the U and V texture coordinates only range
from 0 to 1? The different sizes of mipmapped textures are

DESIGN
one of the reasons for that) allow for less “misses” of texels
because there are less texels in total. But, when you’re using
bilinear filtering AND mipmapping, the smaller textures are
blurred a lot more by the bilinear filter:

This sudden increase in blur is what we see in games as a Anisotropic filtering takes this difference in mapping into
horizontal or vertical “line” on floors and walls, especially when account and uses many samples of the texture in patterns that
moving. It ends up looking like there’s an error that stays a depend on the projection to calculate the final colour of our
certain distance ahead of us in the game, which can get very on-screen pixel. Unfortunately ATI and NVIDIA use different
frustrating. That’s why there’s the option to turn on trilinear patterns and sometimes even different amounts of samples to
filtering. arrive at their final values, so it’s not really possible to draw a
simple snapshot of anisotropic filtering. It is possible to
Trilinear filtering: mention that anisotropic filtering uses a lot more texture
samples per pixel (obviously) so both card manufacturers
Just as bilinear filters across two dimensions, trilinear filters decided to allow us to have some say in the amount of
across three. Except that the third dimension is the Dimension bandwidth vs the visual quality of anisotropic filtering by giving
of MipMapping! This means that where bilinear filtering grabs us the arbly named 2x, 4x, 8x and even 16x Aniso settings that
four texels and averages them out according to an algorithm, we can tweak in our drivers.
trilinear grabs eight texels (four from one mipmap and four
from the other) and again averages them out to get a final
colour for the pixel on screen.

11 DEV MAG ISSUE 4 2006


But what does that all mean? algorithms to attempt to apply anisotropic filtering to only those
parts of a scene that need it.
Why don’t we take a step back and figure out what all this
means for our gaming? If you really hate fuzzy textures, enable the highest level of
aniso filtering you can, but it will give you slower fill rates as
Texture filtering makes games look better by making our each pixel reads tons of memory. The slowdown will get worse
textures less dependant on resolution. Of course, we could the larger your resolution, but such a high level of filtering
simply up our resolutions and make our games look smoother might make it tolerable to take your screen size down a notch
and crisper that way. That’s option 1, but it does mean that our or two. But that’s all purely personal choice.
whole rendering pipeline is calculating a lot more pixels, so
DESIGN

your FPS will depend on the speed of your GPU’s core clock. The bottom line:

If you can stand it, turning filtering off (and living with only point - Point sampling = simple + fast + blegh.
sampling and mipmaps) is the fastest approach in terms of
memory bandwidth. It doesn’t look great at all though… - Bilinear = “blurs” textures, effective but has nasty mip-lines.

Bi- and tri-linear filtering are the current standards because an - Trilinear = fancy sounding slower upgrade to bilinear, kills
average graphics card these days has a memory clock that’s mip-lines and not much else.
fast enough to allow 4 (for bilinear) and 8 (for trilinear) texture-
memory reads per pixel. So, depending on your card, you can - Anisotropic = different method (actually uses bilinear as
probably afford to use either of those filtering methods without samples), tries to match screen-space by doing more work,
taking a FPS hit at all. slowest + prettiest.
DISLEKCIA
Anisotropic filtering ups the memory reads per pixel quite
dramatically, sometimes even doing as many as 128 reads on
the highest settings! So your memory clock speed is really
important if you want to use aniso. Newer cards can handle
the lower levels of aniso (4x and lower) without pushing
themselves too much, both manufacturers use optimization

12 DEV MAG ISSUE 4 2006


MAKING 2D
MAKING 2D ASSETS
ASSETS WITH
WITH
3D SOFTWARE
3D SOFTWARE

What are the most wanted people in the Indie game development world? Well, I think you may know already. Artists.
Having a graphics artist in your group is like having superpowers. Yet every one of us must have the creative gene in
us, otherwise we wouldn’t be making games. What makes it so impossible for us to make our own assets?

T hese days, the artists out there


concentrate on 3D modelling, as
You should also use a plane in the same
color of your games environment. For
For this situation I created a Raytrace
material with metallic settings, and a
they should. It is where the industry is example, if it’s a space shooter a black gradient reflection setting. My diffuse
going. But we, the Indie game plane may be needed, or a desert map is a nice goldish color.
developers, need 2d sprites or animated shooter an orange plane would be good. Next we need to pre-setup the
.gif files to do our job. So how can we This will help loads in the editing of the renderer. We need to be sure on the
still use the 3d models produced by “near opaque” area of your images. For size we require. I usually make the
today’s artists in our games? Well, that’s my lamp, I am going for a white plane, to renders slightly bigger than the size I
exactly what I’m trying to show you all make it more universal. So, I create my need in game maker. The size I chose
here in this series of articles. We will run lamp and place it in the centre of the is 96x72. This added resolution helps
through the various steps I follow to field (0, 0, 0). I then use the Max loads when post editing. I adjust some
make working assets for my games. function to extend the view to fit all custom settings and I do my first
Now, I'm not an expert, not nearly, but I objects (most programs have this render.
can handle a 3d modelling package. function). I add a huge plane at co-
This tutorial should be universal to all ordinates (0, 0, 0) and make sure it does This is really simple, but usable. Next
programs out there – the package used not overlap the main model. When month we will add lighting to the scene
must just be able to “render” a scene. moving and adding objects, I do not use and animate the model. In the mean
So, let’s get started. the top view port which I would later use time, you are all welcome to collect
For these articles I will be using 3D for rendering, as one can easily resize some free 3D models from http://
Studio Max (any version will work), Paint or move the viewport without knowing, www.3dtotal.com and http://
Shop Pro 7, and Game Maker 6.1 and that is not desirable. www.3dcafe.com for the next issue,
(registered). Now you should apply the UV Map and and we can make some nice assets.
texture you would like on the object, and See you next month.
Setting up the scene also the required material settings you HIMMLER
want to use.
This, if any, is the most important step in
the process, and if not done correctly
will cause a lot of work to pop up later.
In your modeller import the model you
would like to use in your game. Most
cases you would like to get a top view of
your model, or a side view. For my
“golden lamp” I will be using the top
viewport as my rendering viewport. The
use of cameras are advised for
Isometric assets, as you would like to
setup up a template scene first, that is
used in all the assets, to keep informality
for post editing and style.

13 DEV MAG ISSUE 4 2006


THE QUALITY TOUCH

PART 1:
MINIMUM REQUIREMENTS
A complete game is more than just gameplay. A complete game must be equipped with easy access to features,
information about the game and its creators and options to adjust the experience of play. In this article,
CAIRNSWM and FENGOL cover some of the basics that a game needs to “feel” complete.

T
hese features are mostly slog work If a player can’t work out how to play Readme File: While a player won’t
that creative and most hobbyist your game within a few minutes, the necessarily read the readme, it’s
developers leave out due to lack of chances are good that they will just important to include a readme for
DESIGN

enthusiasm or time constraints. delete your game and forget about it. logistical reasons. The readme should
However, players notice the lack of Rarely does a player think about or include: licensing information (may
attention to these details and they're spend time looking for a readme file in someone sell, give out or distribute
worth spending a little extra time on. the project directory, so clear and easily your game without your permission?),
read tutorial or help screens will keep the various copyright holders'
Splash Screen: A good splash screen the player from getting frustrated. information (in fact, include all the
serves two purposes in a game. Firstly, it information from the Credits and About
acts as an immediate indication to the Credits: Hobbyist developers rarely Screens), a list of known bugs and
player that the game has started, while create their own content for their games; issues (if there are any that you are
the game loads in the background. we rely on graphic artists, midi aware of) with work-arounds and a
Secondly, it gives a new player an musicians and other artists for content, history of what’s changed in your
indication of the theme of the game. often for free! A credit screen is a good version updates.
place to thank the people who’ve helped
Main Menu: A clearly defined main make the game what it is. These features make it easy for the
menu gives a game a very nice player to get involved in your game and
completed feeling. The Main Menu must About Screen: While this could easily it’s worth spending time adding them to
be clear, responsive and rather intuitive, be part of the Credits screen, the About your development cycle. Practice by
and should make it easy for the player to screen serves a different purpose. The always adding these features, and they
access the various other game features About screen gives the game’s version won’t be the hard work that they may
or exit the game without using Alt-F4. number, copyright information, the appear to be at first.
game’s homepage where the player can
Tutorial or Help Screen: More often get more help or information and an In the next article, we’ll cover “adjusting
than not, a new player will download email or link to provide feedback. The the user experience” where players
your game and dive into the action About screen can also give more should be able to control aspects of
without exactly knowing what to do; only information about you, the hobbyist your game like music volume, graphical
if he can’t figure it out for himself or is developer; your email address, website effects and speed performance.
struggling to get very far with the game or blog, and other games you’ve made.
will he look for a help or tutorial button. Cairnswm, Fengol

14 DEV MAG ISSUE 4 2006


SOUNDS GOOD

THE BASICS OF SOUND


DEVELOPMENT
n the vast world of audio, our jobs much am I willing to spend?” There are sequencing, audio/visual editing,

I become more and more complex as


the ever-evolving matrix of
plenty of choices that will suit any
budget, whether you want to spend as
recording and even post production
work. Expect to pay a fair amount for
technology pushes us into having to be little money as possible or if you’re this kind of software, however, as they
multi-skilled professionals, where a willing to give an arm and a leg for it. hold seemingly endless features. Also
single person can now do the job that an Luckily, there is something for everyone, be sure to have a somewhat powerful
entire team of skilled individuals did in even if you’re not prepared to spend PC at your side with at least 1 GB of
the past. As our computers get faster, anything at all! RAM; these tools are normally quite
our software becomes more and more process intensive. External equipment
DESIGN

complicated, allowing us to live in a The External/Hardware Sound Card: is available to take some of the load off
world where the boundaries of our the CPU, but we’ll leave that topic for a
capabilities are set only by the limits of (Assuming that you already have a future article.
our imagination. It is for this reason that I computer) The sound card is the piece A free sequencer to check out is
would like to start off this audio column of hardware that acts as the “audio Kristal Audio. ( www.kreatives.org/
by introducing to you some of the “tools brain” of your setup. It’s an interface kristal ) This type of software is
of the trade” used in the audio industry which allows you to connect external generally hard to come by as a free tool
today. But with such a vast array of sound sources, and be ready for due to the complex tasks that are
powerful tools at our disposal, some of recording. Most sound cards feature required from it. Kristal has quite a few
us can’t help but feel a little bit multiple inputs, such as microphone limitations, but is a good introduction to
overwhelmed at all these technical inputs, line inputs (keyboard/guitar etc) sequencers nonetheless.
gimmicks that prome to make our games and, usually a MIDI In/Out/Thru feature
sound like they’ve just stepped out of Mr. will also be available (amongst others). If The Audio Editor:
Lucas’ sky-walker ranch. you want to take sound seriously, one of
Sure, some software might perform these babies will definitely need to be by This is the tool which I feel is most
certain tasks better than others, some your side. It’s a fair investment that will relevant to us in the small game
are designed only to do one certain reap many audio advantages. development community. This is not
thing, and some might even claim to do only because these tools are quite
it all! But the question is: Which one is The “Multi-track” software sequencer: simple and cheap, but because the
the right one for you? Let’s talk more type of functions that this kind of
functionality and less gibberish. Let's These are generally the most popular software performs very much apply to
help you spend your money wisely on a software tools. These “all rounder” tools, what we are doing.
product that best suits your needs for and cater for most audio tasks such as The editor is a sound designer’s best
making successful game audio. general editing, music creation/ friend. With excellent visual
The first question that you would
naturally have to ask yourself is: “How Some other popular sequencers:
Steinberg’s “Cubase SX” Apple’s “Logic”(MAC) Digidesign’s “Pro-Tools”
( www.steinberg.net ) ( www.apple.com/logicpro ) (www.digidesign.com)

15 DEV MAG ISSUE 4 2006


Left:
Digidesigns Pro-Tools LE 7. The
industry standard.

Right:
Steinberg’s Wavelab 6. A common
favourite amongst audio junkies

interpretation of your audio wave, you someone walking on wet lawn during a
can literally “read” your sound like a Audacity windy day, or more specific
book allowing you to decipher what the http://audacity.sourceforge.net/ categorized libraries.
next critical audio decision will have to This one is 100% free and is really quite A really good place to get free
be. And if that isn’t enough, you’ll have good! I would recommend Audacity as samples is the free-sound project, an
an entire militia of different types of really good starting-point/budget friendly online sound sharing community that I
metering tools at your side which allow audio editor. can highly recommend.
you to critically analyze your wave. The (http://freesound.iua.upf.edu)
main features that we will be focusing on Audio Plug-ins: Also be sure to check out
with the audio editor will be: http://www.sound-ideas.com (a popular
Plug-ins are stand-alone software source for the professional industry-
applications that work independently, features an excellent gaming library
- Monitoring our mix, (checking for but still use your sequencer/editor as a too!) and
clipping/distortion) host. These become very useful when http://www.hollywoodedge.com

DESIGN
- Checking overall levels, (consistency in you require something specific that your (another popular choice for the
sound, correct compression applied) editor might not cater for. Just open it professional industry).
- Multi-track capabilities, (the layering of through your VSTi/DXi link and, presto!
our sound effects and overall mix) Your editor has become that much more Remember, whatever choice you make
- EQ and overall effects applications, powerful. for your everyday audio tool, make
(plug-ins) sure that the software you use works
- Proper conversion/compression of our There are literally thousands of plug-ins for you and doesn’t block your creative
sound files, (eg. WAV to MP3 available, some costing up to R90000! process. A tool is there to enhance
conversion) Yes, there are many good free ones too, your creativity, not to make your life
- The “batch converter”, a common but for the sake of trying to keep this an complicated. As time goes by and you
feature amongst audio editors that introductory column, I would rather go try more and more software, eventually
allows us to convert multiple audio files into more detail on plug-ins at a later you will found the right one -- the one
at once! (More detail in the near future ) stage. that works best for you!
As the months go by, I will go into
more and more detail about these
Two free(ish) editors really worth Sound-Effects Libraries: topics. I believe that, to get into actual
checking out are: production, we need to become familiar
Your sound-effects library is the source with our tools and understand the basic
Goldwave editor of all your sounds. These too, come in fundamentals of audio.
http://www.goldwave.com/ all shapes and sizes. Available are ZPHYR
This one can be continuously kept in general “all-rounder” libraries with
demo mode (and is very affordable everything in them, from the sound of
none-the-less) gun-shot effects, planes, right through to

Other popular editors:


Steinberg’s “Wavelab” Sony’s “Sound-Forge”
( http://www.steinberg.net ) ( http://www.sonymediasoftware.com/Products/
ShowProduct.asp?PID=961 )

16 DEV MAG ISSUE 4 2006


THE TECH WIZARD

RECURSION
Recursion is yet another one of those fancy terms that computer scientists use to describe a technique that is actually

quite simple in practice.

A t its base level, it is merely a method where a function


does some work, then “calls” itself to do the same work
to its previous level where it merges the data of the two lists
into one:
again. However, instead of using the data that was used at
the start of the previous work, it uses the data that was
created as a result of the work. This process is repeated until

TECH
MergeSort(data, low, high)
a certain condition is met, at which point the recursion ends {
if(low < high)
by returning from the current level of the function, instead of {
continuing into another recursive call of itself. mid = (low + high) / 2;
MergeSort(data, low, mid);
MergeSort(data, mid + 1, high);
MergeData(data, low, mid, high);
Recursion is typically used to apply what is known as the }
}
divide-and-conquer approach (mentioned briefly in last
month’s article), which is made up of the following three
steps:

Divide: It is quite easy to see where the recursion happens in the


Divide a problem into a smaller number of “sub-problems”. above pseudo-code. MergeSort calls itself with modified data
until low is the same value as high. At this point the
Conquer: recursion stops, the function returns to its previous level, and
Process each sub-problem by using recursion until the “size” the MergeData process begins on the list of data. Once the
of the problem is small enough to be solved in a data is merged, the function returns to its previous level and
straightforward manner the merge process continues until the original level of the
function is reached, at which point the data has now been
Combine: sorted completely.
Combine the solutions for each sub-problem to create a
solution for the original problem. Now that you know what recursion is, it doesn’t mean that
you should run out and make use of it all over the place. The
A typical example of recursion being used is the merge sort. real trick is to know what problems should be solved by
Merge sorting works by recursively breaking up a list of data implementing a recursive algorithm, and what problems
into two smaller lists, each of (list_size / 2) size, until there is should instead be solved with an iterative approach.
only one element in the list at the current level of recursion. COOLHAND
At this point, the recursion is ended and the function returns

17 DEV MAG ISSUE 4 2006


MOBILE GAME
DEVELOPMENT IN JAVA

PART 2: MAKING MOVES


W
elcome to the second tutorial in when the Canvas is repainted. The control to another thread. There are two
cellphone game development. actual paint implementation simply important things to note here: firstly,
Let’s start off by reviewing the MIDlet clears the screen to white by setting the never explicitly call paint; use the safer
from the previous tutorial. The first thing colour, then drawing a rectangle the repaint instead. Secondly, the only way
to notice is our two class declarations: size of the screen. We then set the to stop a thread in J2ME is for it’s run
the first being our MIDlet class, which is colour again (to red) and draw some method to finish. The programmer is
the mobile application that the system text. required to ensure that all threads they
runs. The second is the Canvas class start are stopped when the MIDlet is
that is used to actually display objects. To extend this simple application to do destroyed as the JVM is not guaranteed
As you can see, our MIDlet doesn’t do more than draw text once, we need an to do this automatically.
very much other than create the canvas update loop. As can be seen in Listing

MOBILE
and set it as the MIDlet's main display. 3, this is achieved by implementing the This brings us to the changes to the
The three methods, pauseApp, startApp Runnable interface in our Canvas MIDlet (Listing 4): We have made the
and destroyApp, are called respectively subclass. We also add a static Thread canvas a member variable, set it as the
when the MIDlet enters the pause state, member variable, gameThread, and a display, and ensured that it’s initialised
the running state and when it is boolean member variable, exit, to allow in startApp. In destroyApp we make
destroyed. It is important to note that the thread to be stopped. The new sure the canvas’s thread will stop.
startApp may be called more than once, constructor simply assigns a new We have the beginnings of a game
so what we’ve done by creating our Thread to gameThread. The run loop, so let's add some game-like
canvas in this method is technically method is where we do our work. For behaviour. We need a ball in our game,
incorrect. Within the TutorialCanvas now we just check if we need to exit, so let's add that to our Canvas and give
class we have overridden only the paint and if not we request a repaint (and wait it a simple bouncing animation. There is
method. As you can guess this is called for that repaint to happen) and pass no support for floating point numbers in

Listing 3. TutorialCanvas updated to implement Runnable.

class TutorialCanvas extends Canvas implements Runnable


{
public static Thread gameThread;
public static boolean exit = false;
Listing 1. Class declarations.
//Constructor
public class TutorialMIDlet extends MIDlet
public TutorialCanvas()
..
{
class TutorialCanvas extends Canvas
gameThread = new Thread(this);
}

//run the game loop


Listing 2. Paint method implementation. public void run()
{
g.setColor(0xffffff); while(!exit)
g.fillRect(0, 0, getWidth(), getHeight()); {
g.setColor(0xff0000); //paint everything
g.drawString("Hello World", 0, 0, 0); repaint();
serviceRepaints();
//give other threads a chance
Thread.yield();
}
}
}

18 DEV MAG ISSUE 4 2006


the J2ME configuration we're using, Listing 5, and, as always, I have for improvement and optimisation, but
(CLDC1.0) so we have to settle for two omitted code that has not changed. my focus has been clarity, so I’ll leave
integer values for the ball’s position. We all that as an exercise for you. Next
also add velocity values for the ball, and That’s all for this lesson. We now have time, we’ll delve into the MIDP game
define a constant for the ball’s size. In an update loop running in a separate engine.
our constructor we set some initial thread that is animating a bouncing ball. FLINT
values for the position and velocity. In The code as it stands has a lot of room
our update method, before we call
repaint, we update the ball’s position. Listing 4. Updated MIDlet class.
This is easy enough, since we just have public class TutorialMIDlet extends MIDlet
to add our velocity and change direction {
TutorialCanvas canvas = new TutorialCanvas();
if we are outside the bounds of the
//Constructor
screen. We actually allow the ball to public TutorialMIDlet() {}
slightly exit the screen because it’s a bit
//Called when the app starts
simpler this way. Finally, we replace our public void startApp()
{
text with the ball in the paint method. We
Display.getDisplay(this).setCurrent(canvas);
use the Graphics.fillArc method to TutorialCanvas.gameThread.run();
MOBILE

specify our circle. Note that the position }

in this method refers to the top left //called when the app is destroyed
public void destroyApp(boolean unconditional)
corner of the rectangle that would {
//make sure we stop the game thread
contain the arc, not the origin of the arc. TutorialCanvas.exit = true;
All of these changes can be seen in }
}

Listing 5. TutorialCanvas updated o include a bouncing ball.

..
static int ballX, ballY, ballVX, ballVY;
static final int BALL_RADIUS = 5;

//Constructor
public TutorialCanvas()
{
..
ballX = ballY = ballVX = ballVY = 1;
}

//run the game loop


public void run()
{
..
//update our ball position
if(ballX < 0 || ballX > getWidth())
{
ballVX = -ballVX;
}
ballX += ballVX;
if(ballY < 0 || ballY > getHeight())
{
ballVY = -ballVY;
}
ballY += ballVY;
..
}

//paint the canvas


protected void paint(Graphics g)
{
..
g.setColor(0xff0000);
g.fillArc(ballX-BALL_RADIUS, ballY-BALL_RADIUS,
A ball bouncing around the screen. 2*BALL_RADIUS, 2*BALL_RADIUS, 0, 360);

19 DEV MAG ISSUE 4 2006


THE TRUTH ABOUT INSTITUTIONS
So, off to a tertiary institution? Studying for your future? Excited about the opportunities in professional game-making
that your studies will present? Well, know now that there's another side to going to university, something that's
overlooked by a lot of students. You're going to be surrounded by tons of interesting people while you're studying, and

TAILPIECE
if you don't use that time to make contacts and learn about things "not in your field", you're missing a big opportunity to
get ahead as a game creator.

H
ow does one go about learning, though? Well, one of The same goes for music classes, but typically those are
the best ways to get to know different people is to take much harder for "lay-listeners" to understand. I'd suggest
elective courses that are totally off your "stream". If you're getting to know some of the design students and hanging
careful and study your university handbooks, you'll be able to around in the "art" areas of campus for a while. You'll meet the
get credit for them no matter how strange they might be. A musicians eventually...
good way to decide if something is as interesting as it sounds
is to spend a bit of time exploring exotic-sounding classes in BUSINESS / MARKETING COURSES
first year, once you're settled in it's really easy to just sit in on If you're planning to do it alone and start up a company to
a couple of lectures. If the course is interesting, relevant to you build games, knowing all the little things you need to do to
or has types people that you know you're going to need to incorporate and understand how investment works can be
involve yourself with during your working life, sign up for it next invaluable.
year. You should be able to find entrepreneurship courses without
Here are a couple of ideas for things that you might be able too much difficulty and they'll probably fit into your course-
to use to strengthen your CV and network at the same time. structure quite well. Once again, they'll be a bit simpler than
You should always keep a hard-copy of your contacts and how your tech-minded CS courses, but it's a different method of
/ why you know this person and what they can do. thinking. Once you've got an understanding of business, you'll
know if it's something you can do or if you'll need to get a
ART / DESIGN COURSES partner to run the business side of things. The people in these
If you want to make games, you're going to need art courses can be valuable if you have questions later when you
resources. Making friends with the arty students can lead to start up.
some of them wanting to help you with your games and The dark art of marketing is a driving force behind the
providing graphics that you would never be able to do. success or failure of games these days. Getting into a couple
You don't have to do hectic art classes either, most of marketing courses will give you useful contacts if you need
universities offer "lighter" courses such as Visual marketing help, plus you can continue with it through to
Communication or Semiotics. While they can be very strange second-year level to give you an edge – if you're built to
to a technically-minded BSc student, learning the theory withstand the lovely task of manipulating people all day, of
behind perception or how colours define emotions can be very course!
useful and immediately applicable in your games. At the very
least, you'll have some understanding of how to talk to artists ENGLISH COURSES
in their own language afterwards – never underestimate the Not only are some English modules excellent for helping you
importance of good communication! develop that story-writing side of yourself, there's also a whole
I've got a short-list of contacts from my design classes that I lot of information about the publishing industry that can be
send work to every once in a while when people ask me for learned here. Yes, the basic principles of publishing are the
business cards or logos. They're all keen to work with me on same for books, music and games, so a good publishing
games and I send them playable versions of what I'm messing course will equip you to deal with publishers on a much better
with every once in a while. One of them even likes GM footing.
because she can change the graphics without having to code. Personally, I'd recommend getting to know the publishing /

20 DEV MAG ISSUE 4 2006


English students through the first-year art modules you take,
they'll probably be in those. Then once they start talking about
things that interest you, start sitting in on the odd lecture.

PSYCHOLOGY COURSES
A little bit of psych can be really useful in helping you decide
how to invoke powerful emotions with your games.
Unfortunately most 1st year psych modules are very low level,
but if you feel that you're learning something applicable, go for
it.
Usability and Human-Computer-Interaction courses:
TAILPIECE

Most informatics faculties will have a few courses dedicated to


these fields. In the gaming sphere, the most important person
you're ever going to interact with is your user – the person
playing your game. Any techniques and skills you can learn to
make their experience better will translate into success later,
even if you're simply a programmer...
While these courses are most useful for aspiring game
designers, learning the ins and outs of usability will make your
code better and less error-prone, despite what the hardcore
CompSci guys say about it. Trust me. Being able to make a
piece of software fun and understanding WHY it's fun will
serve you in good stead.

REGULAR COURSES
Most CS degrees will have you doing at least some maths. Go
to it and work hard, you can do ok without it, but knowing your
algebra makes graphics coding much, much easier. Trying to
understand AI without combinations, permutations and some
calculus will break your head.
Don't run away from the physics course. It's not as hard as
you think, provided you keep working on it every week... It'll
help you out in the days of physics cards and emergent
gameplay.

There are tons of other courses which might prove useful.


Remember that you need to sit down and decide what you
should focus on and what not. Your degree will try to push you
towards certain things, but remember that this is all for you to
use – get the most out of everything you can.
DISLEKCIA

21 DEV MAG ISSUE 4 2006

You might also like