How To Develop An RTS Game – Brief Guide

Red Alert 2 (Westwood Studios) and Age of Empires 2 (Microsoft) were two games which defined the generation of computing just getting used to GUI (mid/past due ninety’s).

Originally designed for DOS, Red Alert changed into constructed by means of Westwood Studios – RTS pioneer thru titles which include Dune. The game was a step forward because of its realtime nature For more detail Please Visit

Add to that a killer storyline, splendid pics and close to-legendary gameplay mechanics and you’ve got a winner. As a software program developer, it is clean to be in awe at video games like this… But it’s another knowing how they paintings. This academic is a quick creation into what I realize about it.

OOP (Object Orientated Programming)

The most critical factor you want to understand with any game is that they may be programmed using OOP standards. OOP stands for object oriented programming, and essentially the other of go with the flow-primarily based programming:

Flow based packages paintings with the drift of an software. They will awareness on consumer input and manipulate their device based on bureaucracy – normally clean the UI whenever an input is provided.
Object oriented packages work by way of loading a base application and the use of that to load a chain of variables (objects). These variables are held in memory and can be interacted with at the screen in realtime.
The center of OOP is the capacity to “invoke” lessons. Classes are a kind of variable which can help you keep “attributes”, and use the ones attributes in “public” (magnificence) and “private” (example) techniques.
The manner almost all video games paintings is to invoke a number of facts objects into memory, populate them with the proper attributes (hit points and so forth) after which continue to name the various instance / class techniques on them as the user interacts with them in-recreation.

Data + Renderer

On top of a core OOP structure, RTS video games paintings with two factors – a data backend and “renderer” front cease. Understanding how those paintings together is the core of whether you’ll apprehend the way to make an RTS sport paintings from a programmatic angle.

Imagine an RTS as a easy application. Ignore the graphics and art work and many others – focus on the way you’d make the objects flow round on-display screen.

It works like this – the application masses up. This gives you the capability to control your credentials (load beyond video games, exchange your information and many others). The task of the application (in an RTS) is to then create new “games”. These video games exist between or more gamers, and acts like a giant chessboard onto that you’re capable of upload new buildings, units and many others.

Each “recreation” hundreds up two sets of facts (your records & the alternative participant’s). The task of the game is that will help you control this information to overcome out your enemy.

Data (Buildings / Units / and so forth)

When a brand new “sport” is loaded, the records for you and your enemies are loaded into reminiscence. For instance, you can have a data-set which seems like this:

Player #1
– Buildings
– 12
– 34
– eighty one
– 19
– Units
– 109
– 109
– 109
– 109
Player #2
– Buildings
– 12
– 34
– Units
– 10
– 12
– 24
Each wide variety above corresponds to an ID for a information item. In relational databases, the ID will act as a foreign_key.

The manner you control those items is to have a central records shop (for instance a relational database) which shops the homes as particular objects on their own.

This manner, while you create a brand new constructing, what you’re doing is creating a brand new reference within the database. For Rails, you would have the subsequent setup:

factions_table (has_many homes, has_many devices thru homes)
objects_table (this can be superclassed as buildings & units)
games_table (acts as a be part of table for gamers) (belongs_to:player_1, belongs_to:player_2)
actions_table (this data the actions of the sport “player 1 started out constructing x”)
The way you would set up the sport is the following:
The goal of the software is to create gamers
Once the player has “logged in” (either with serial or e mail), they’ll be capable of create a “game”
The game will then allow every participant to “build” homes and construct devices. The units are available through buildings (you have to construct gadgets which will make gadgets available)
Each building/unit is available thru a faction.
You need some type of tech tree to permit precise unit / building production for positive research investments
The way this will paintings is to load a “clean” facts set when the sport hundreds.
From right here, the person is capable of construct the numerous decrease degree homes / units with the assets they’re able to collect. Each time the consumer “creates” a brand new constructing, they are creating a new information object which adds to their array of homes / units.

Please appreciate this information-set has surely no touching on how the sport looks.

Part of what makes RTS games so appealing is the seamless bridge among records and renderer. Imagine the records as a pure list of numbers, etc. There is NOTHING visual approximately it.

In fact, in case you ran a “console” view of the game, you’d essentially see sets of data, constantly having their attributes (hit points, position, etc) changed by means of the sport engine.


This is wherein the magic occurs, and is of route the maximum complex element of the sport itself. I don’t have everywhere near the extent of revel in with this as I do with the natural facts.

The renderer is generally what throws off maximum would-be builders.

The manner it works is very simple.

Firstly, when a brand new “game” is loaded, it creates a “chessboard” onto which your records gadgets are placed. This chessboard is manifestly the map.

The map has constraints (dimensions) which offers the application the capacity to “draw” a grid. This grid lets in you to use a series of co-ordinates to “position” new homes (items).

Whilst the dataset does not care about the positions, the renderer does. This approach that if you desired to build a new building in a vicinity already occupied with the aid of another, you may be not able to.

The way you would handle that is to send the co-ordinates thru in a new construct request to the server. The co-ordinates will then permit the server to control whether or not the consumer is capable of build a new building. If the reaction is effective, the engine will showcase the constructing’s creation. If no longer, it’ll no longer permit the building to be built.

The biggest factor with the renderer lies within the “AI”.

This is the actual magic of the game. When you flow a unit from function A to put B, how does it engage with different factors in the game, for example.

Programming Languages / Architecture

How you design an RTS depends absolutely on the medium wherein it’ll be delivered. Back within the day, you simply had to create a computing device application.

Today, you have got the internet, mobile and laptop to recall. As such, the overall panorama of video games has changed to be a more inclusive experience.

More importantly, we have seen the movement of recreation mechanics to the server. This method that if you play a sport for your browser, in your laptop or thru cell, all you are doing is sending requests to the server and it will respond with updates for the renderer.

None of the physics, recreation information or construct mechanics are kept in the consumer aspect application anymore.

There are presently no assets on how to in particular broaden an RTS game. If you wanted to piece together your very own thoughts, you may do properly to look at the e-book Game AI Pro three and also a VERY true resource “How to RTS” on GitHub.

Add a Comment

Your email address will not be published. Required fields are marked *