Blog Archives

Inside The Game – Tile Based Game Architecture

Hey Guys!!! today I am writing the 5th part of Inside The Game series. For those, who are not familiar with Inside The Game series, this series will provide the articles and tutorials related to mechanisms and architectures of the game. Also, in this series, you will learn to think like a game developer. Now, if you have not read the last part of this series, please click here to read it. I am summarizing the last part here for those who have not read. In the last part, we discussed different types of the games and very little introduction about the architectures behind those games.

Now, this part is very interesting part of the series, and I must say that this is very important part of the series. Many readers are asking me that when would the coding and implementation start or something like that. Then, I would like to answer the question here about it. Well, answer is simple, we will start programming soon. We are going with the flow and concepts are much important when it comes to coding.

Okay…. enough talking…. 🙂 let’s talk about the article now. Today, I will discuss in detail about the architecture behind the games. And, as you can guess it from the title, that will be the Tile Based Game Architecture. It sounds horrible…. 😛 I know that…. 🙂 But believe me, its a very simple and interestingly very useful and common architecture found in most games. To learn about tile based architecture, you have to first learn about the tile itself…

Tell em, what is a tile…!!!

Tile…. Tile is a small unit. Word tile comes from the floor. We make a floor on ground in homes, offices etc. The whole floor is made of small squares called tiles. There is nothing to worry about, tile is same thing in the games, and you will know it shortly. Well, you can also call it cell as in Cell Based Games. Well, I will prefer the tile word here. Now, you have known about the tile, so let’s move to tile based architecture.

Oh no…. its Tile Based Game Architecture buddy…!!!

Well, fasten your seat belt… we are here… and please don’t say Oh No… say Oh Yeah… its Tile Based Game Architecture buddy… :). Tile based architecture? what does that mean? Well! its the architecture used in games, and why this is called tile based architecture? Oh yeah! I forgot to mention about that. Well! this architecture works on basis of tiles, so its called as tile based architecture…

I still don’t know what is Tile Based Game Architecture …. 😦

Yeah!!! I know that…. 🙂 Well, you don’t have to worry about that. So, in tile based architecture, what we actually do is: we create an array mostly 2-Dimensional (2D), and we save all the game information in that array. Game information? Does it sound new to you? Game information means the information about the game. This contains the character positions, their status like died, alive etc, their health statistics, scores, levels, and so on. Simply, all the information related to the game is stored in game information. So, that 2D array consisting all the game information is behaved as floor and each element in the array is behaved as tile, so this is why we call it tile based game architecture. You can search more about this on Google. 😛 Everyone knows that… 😛

Games on tiles….. ??? Really…. ??? 

Yeah!!! I am going to explore that now for ya. As we have already discussed about game engines and graphics engines already, so I would like to remind you that game engine basically manages, handles and controls all the game information and graphics engine just renders and displays that game information on the device screen. So, what I mean from architecture or specifically Tile Based Game Architecture is the game engine behind tile based games. Because, you can’t display the data until you haven’t stored it. So, I am not going to discuss about the 3D graphics, or 2D graphics, or anything related to graphics. Rather, I will discuss the architecture and concepts behind the tile bases games. Well, there are thousands of tile based games. Well, the game developer company will not tell you that our game is tile based game, because we are talking about the code here, not the game and gameplay.

Examples… Please…. 😛

So, I am going to give you the examples of the tile based games. Well, the most common example of these games is a chess game. Normally, the board games like monopoly, chess, ludo, checkers etc are developed through tile based games. (Note: I haven’t took the name of cards game here.) That’s it? No!!! That’s not all.

So, the strategy games like Commandos, Age of Empires, Stronghold Crusador, The Legend of Zelda etc. also based on tile architecture. Really? Yeah…!!! That’s awesome then…. 🙂 But hey, I would like to tell you something here. Normally, there are two types of strategy games here. Well! there are no specific names of those types, but let’s give temporary names to read easily. Let’s call the first one as continuous and other one as discrete. What actually happens in discrete is that a tile is a single step of the game. It means, when we move the character one step, then it will directly come to the next tile. Examples include The Legend of Zelda, Chess, etc. However, in continuous the case is  very changed. If we move the character one step, then its not necessary that it will move to next tile. This depends on number of steps in a single tile. For example, there are 5 steps in a single tile, then it means after passing five steps, the tile will be changed. Well, both are same. The difference is only of details. In the discrete, there is not any detail in a tile, while in continuous there is detailed tile map in a tile itself.

   

Which one to choose? Discrete or Continuous?

Well! the answer depends on the game. But I will tell here some advantages and disadvantages of both mechanisms, then you can differentiate both easily. Normally, the discrete games are much easier to implement, but problem is the smoothness of the game. Like if you are changing tile on each step, then the more the tile size, the less the accurate and smooth game will be. So, you will say, “Just decrease the size of tile, GamyGuru…. :)”. Well, I will tell you one thing. A game developer’s most difficult and important task is optimization. So, the more you decrease the size of tile, the more the CPU will process and in case of mobiles or tablets, battery will die quickly. So, a true game developer’s job is to create a game with low CPU processing with high performance graphics…. So, if you want to decrease the size of cell and add smoothness in the game, then I will recommend you to apply the continuous approach. We can say that continuous approach is same like small tiles. Well, there is a difference. The difference is that in small sized tiles, number of tiles increases and in the result CPU processing also increases. However, in the continuous method, we are increasing number of tiles, so CPU performance will not be affected as plus point. Only, the tile we are interested in will be detailed for more processing, and processing one single tile is less CPU expensive than iterating through all the tiles in the game. So, I guess you have understood it.

Is tile based architecture for strategy games ONLY…. ?

Tile based architecture only for strategy games? I didn’t say it… Well, until now, we have seen two types of games; strategy and board games, which can be implemented by tile based game architecture. However, there are also other games, which can be implemented in same way. We are now going to discuss the next game type, platform games. We already discussed about the platform games in last article. So games like Mario, Sonic Hedgehog etc. follows this architecture also. Architecture is same tile based, but the concept for understanding changes a bit. For example, in board and strategy games, you saw that game was a floor covered with tiles containing small information about the game. However, in the platform games, the floor story just disappears. Because, it is a vertical scrolling or horizontal scrolling game, not some top-view game. Following figure shows a snapshot from Mario game and its tiles.

  

So, now I guess it would be clear in both images that how platform games differ than strategy games in terms of tile based architecture. Also, please note that each tile is of the same size. You can measure it from the bottom line created with brick tile. All bricks are of same size and lines are drawn accordingly.

You will be glad to know that in the next article, we will implement tile based architecture in C++ to understand its working.

So, this is another advantage of the tile based architecture that you can implement platform games also. Until now, I have understood that the 2-Dimensional (2D) games can be easily implemented with tile based architecture.

What about 3D games then…???

Well, you will be happy to know that tile based architecture is not only used in 2D games, but it is also used in 3D games. You might wonder how.. Well, we are not talking about the graphics here, which are 3D, rather we are talking about game engine and storing game information here. So, let’s see an example of 3D game type using tile based architecture.

First Person /  Third Person Shooter Games…

Oh really….!!! Did I hear it right? Did it sound like FPS or TPS? Yeah!!! 🙂 You heard it right…. The next type is First Person or Third Person Shooter games. Well! these are the most famous and played games on personal computers, consoles etc. So, every other game developer wants to develop FPS or TPS games. So, let’s take example of Hitman game, because examples make more clear image of concept.

  

So, the concept behind FPS/TPS games is that the whole map is 2D, as shown in the figure (left), and this map is tile bases architecture containing all the game information. However, the map is just displayed in 3D form like First Person or Third Person camera. That’s why these games are called 3Dimensional.

In a nutshell, we have learned in this article about a simple and common architecture called as Tile Based Game architecture. This architecture is used in board games, strategy games, platform games, as well as in first person or third person games. In the next article, we will implement this architecture in C/C++ to make a simple game. Thanks for reading this article, and if you have any questions then you can ask it here through comments…

Also, please suggest that in which language do you want to implement Tile Based architecture for a simple game.

Posted By: GamyGuru – Prince of Game World

Advertisements

Inside The Game – General Game Structure

This article is third part of the series called as Inside The Game. For those, who are not familiar with Inside The Game series, this series will provide the articles and tutorials related to mechanisms and architectures of the game. Also, in this series, you will learn to think like a game developer. Now, if you have not read the last part of this series, please click here to read it. I am summarizing the last part here for those who have not read. In the last part, it was discussed about animations, simulations, and games. In simple words, game is a controlled animation, which takes the input from user unlike animation and simulate the world like interaction. This part is more technical than last two parts but it is also sort of general as compared to the implementation or programming in any computer language. But, this article will be very important to know when it comes to game development.

Okay!!! Let’s start our article today. Today, we will discuss about the general structure of any game. You might know that there are many different types of the games such as platform games, First Person Shooter (FPS) or Third Person Shooter (TPS) games, strategy games, board games, and so on. So, it is very important to know about the structure of these games. The structure keyword means how the game is designed and what components together make a game. I am not explaining here about any specific type like how platform games are developed, Today, I am explaining about how any type of game is structured. Software include lot of coding, and sort of graphics as well for User Interface. But, normally, all software contain same Operating System’s User Interface Components like Buttons, Combo Boxes, Radio Buttons etc. So, it doesn’t become a problem to focus on User Interface more than the functionality of the software. However, in games, story takes turn to other side. Games includes many disciplines and field other than just coding. Following figure shows some of the disciplines involved in any game. It is not necessary that all the disciplines can be used in the game, but it is also possible that some of the disciplines are used in the game.

As in the figure, it is clearly shown that game contains very different disciplines to work on at the same time. For example, let’s take graphics here. Graphics is a very important part in any game, because it is the first impression of the game. The most first thing user observes in any game is the graphics. So, the more good are graphics, the more users are likely to play the game. But, let’s say that your game has got amazing graphics, but the game is slow and not good in interaction and gameplay, then users will not play the game. Because, they already observed the graphics, and they liked it so they gave a chance to your game, but when they played it, they didn’t find it enjoyable and interactive, so they just left your game. Interestingly, you can see Game Effects & Gameplay in above figure as part of the game. These all parts play almost equal role in making of any game. Let’s take Artificial Intelligence shortly AI here. You can say AI like it is the brain of the game. How computer will react and respond to the user input is the AI of the game. The enemies in the game, called as game bots or game agents, use AI to make decision. We will come to AI in details soon. Another important part of the game is Game Logic & Game Flow. Now, this is completely coding work, and in this part, all other disciplines like graphics, resources like images, sounds from Game Music part, databases, networking, etc. are assembled. You can say it the most important part of any game, but this part becomes zero, if no other part is available to you. So, all the components are tightly dependent on each other.

Well! I hope that you have known about different disciplines of the game, so let’s talk about the structure now. Behind each game, there is an engine running called as Game Engine. In the business world of games, game engine is like gold mine. You can make many games with game engine. Game engine’s objective is to manage all the data involved in any game. Following figure shows the role of the game engine.

As you are seeing the figure, game engine is managing and controlling other sub-engines like Graphics engine, AI engine, Physics engine, Sound engine, and so on. Game Engine manages all the game data and makes any game come to life. The way of game engine is to keep connected all the engines through one medium, and that medium is game engine itself. It basically takes game data, sends it to the AI for decision making, then sends it to Sound for playing, then sends it to Physics for real-life interaction, and finally sends it to the Graphics for rendering and displaying on the screen. This process keep to be repeated as long as the game is running. This is how a game engine gives birth to a game. On completing this article, I would like to ask you a simple question here:

Thanks for reading this article and series. I hope you liked it. Any suggestions, comments, or feedback is open. Thanks…. In the next part, I will discuss about some basic concepts used in game development like Graphics Engine, Game Engine, and so on. To read the next part, Inside The Game – Graphics Engine, Game Engine, and The Game, please click here.

%d bloggers like this: