Battle System Tutorial by Vakinox
This tutorial is an attempt to encourage people, new to this area of coding, to create their own simple turnbased battle systems. It is preferred you have some experience in other areas of sphere and a fair amount in learning the API before you dive off into this tutorial without the proper background. The more you practice, the more you know.
Before You Begin
First, you will need to know a few essentials.
- Good Grasp on Sphere [1]
- How to make TextBoxes
- How to problem solve
- If-Then, For-Loop, and While-Loop conditionals [2]
- An understanding of Global and Local Variables [3]
(Optional:)
Order of Importance
Every battle system must meet a list of certain criteria to operate:
1. Stats -(party members, items, enemies, and etc.)
2. Menu System - (to give the player choices)
3. The Battle System - (calculates damage, handles attack routines)
4. Graphics and Animations - (displays progress and visuals)
At the very basic level, the most important two functions are player stats and calculating the damage between the two opposing stats. However to make battle systems more entertaining, we add an interactive component (either menu choices or button smashing) and graphics to peak the player's interests. These are the fundamentals to turnbased battles, most everything else is optional.
Next, having order and structure in your coding process will help make writing scripts an easier exercise. You will always want to know what is the following item you want implement, or how to arrange everything so that it is easy to find. Having a checklist is a proper motivational tool to accomplish these things. Here is my personal order of importance:
- 1st call necessary scripts
- 2nd the game() function
- 3rd the stats
- 4th the battle system
- 5th the battle menu (options)
- 6th the attack routines
- 7th drawing the battle (graphics)
- 8th the health bars
Calling certain functions before others in the script may affect the program differently, this is why I insist the checklist to be in this order. For example, because player stats tend to reference items (equipment) you would want to define the items before you define player stats. Otherwise, defining player stats prematurely will cause the program to fail because it doesn't understand what items you are referencing. Remember: Javascript is read top-to-bottom.
And so that it's easier to find, leave Global Variables at the top of the script under where you might require or call for other scripts.
Items and Statistics
After setting up the basics, you want to create statistics for everything with a numerical value attached to it and provides the battle system with some basis for calculations. Things such as weapons, health, or attack values will all have to be grouped into statistics and coded individually into the script. In a more reasonable approach and to be better identify certain types of statistics, I find it best to split and group them under separate functions, each established to identify the certain topic they associate with.
For example, player statistics will have its own function and set of arrays that associate with it.
First what we will be doing is creating a function known as a 'Constructor', which will hold variables that we will later define through arrays. 'Arrays' are something we can group multiple values together in for various objectives. In the constructor (stats function) we need to establish variables which will then hold information for necessary things, such as player name or health, for your battle system to reference and use in calculations. The result should be structured similar to this:
function Stats()
{
this.Name = Name;
this.Hp = Hp;
this.Atk = 0;
}