If you have any previous programming or scripting experience, the following should come naturally to you. If you don't, it may be very difficult at first but don't give up, it not so hard with some practice. If you find yourself totally lost, try to find a friend or a forum that can help you out. After you read the following sections, the greatest piece of advice to offer is to unzip the single player missions that came with AMRTS, and dive into the .cfgs and see how things are done firsthand!
Each basic script or instruction (herein called "Objective"), consists of two basic parts-the "Condition" statement, and the "Action" statement. When all conditions in the Condition statement are met, or are true, then the instructions in the Action statement are carried out. The script is saying "If this is true (condition), then do this (action)". If the conditions in the Condition statement are not true, it will wait indefinitly until they are true (or the objective is abandoned). After the Condition has become true, and the Action has been carried out, the objective will unload itself from memory and will never be carried out again (unless it is re-loaded in another objective).
Below is the basic structure of an Objective:
CreateObjectType("[objective name]", "Objective")
{
Condition("[type]")
{
[condition];
}
Action()
{
[action];
}
}
The [objective name] will be different for each objective you make. Each must have a unique name. The word next to it "Objective
" is its class and will never change.
The condition goes between the brackets under Condition()
and the action goes between the brackets under Action()
. Note the bracket structure. Brackets divide the statement down into smaller and smaller units. Notice that the entire statement is enclosed in the two outermost brackets (top and bottom ones) inside the "CreateObjectType
" statement. Within those, there is two more statements; Namely "Condition()
" and "Action()
". Also note that every statement either opens with brackets or ends with a semi-colon. Mistakes as simple as a wrong bracket or missing semi-colon will crash the game!
Now, we are going to add two Objectives to the file
CreateObjectType("objective_start_player", "Objective")
{
Condition("TRUE");
Action()
{
NewObjective("objective_player_at_goal");
}
}
This will be the initial script for the player team. TRUE is a type of condition. It means the condition will automatically be true whenever it is loaded, and immediately carry out the Action statement. Since the statement doesn't need any more information, there are no brackets needed in the condition statement. (The semi-colon after ("TRUE")
shows that the Condition statement is over.) "NewObjective
" is our script command that loads a new objective. You can call a NewObjective in any Action scope anywhere in your scripts. "objective_player_at_goal
" is an objective we will create later, but keep the line there for now.
Now let's add the AI team's initial objective to the same file.
CreateObjectType("objective_start_AI", "Objective")
{
Condition("TRUE");
Action()
{
NewObjective("objective_attack_player");
}
}
Now lets create the missing objectives we are referring to in our script. (objective_player_at_goal
and objective_attack_player
) Open "
CreateObjectType("objective_player_at_goal", "Objective")
{
Condition("TRUE");
Action();
}
Then also add the following to "
CreateObjectType("objective_attack_player", "Objective")
{
Condition("TRUE");
Action();
}
Now, we need to tell the Editor that these Objectives are going to be the initial Objectives for the each team. Load your map in the studio. Double-click on the player's team in the teams tool of the studio. On the right side you'll see a large list labeled "Mission Objectives". This lists all of the Objectives it can currently read from all your .cfg files. The Objectve we just created, "objective_start_player
", should now be on this list. Highlight "objective_start_player
" on the list, and click "Done". Now go ahead and assign "objective_start_AI
" to the AI team, then save your map. Now the game knows to look at this objective first thing when the map loads up!
As you probably noticed there are no conditions or actions, we will add these later. Your map should now load correctly in the game. Nothing will happen, but if it loads without crashing you've done everything correctly.
If you get a "unknown objective" error, that means the script cannot find the objective that it's asking for. Either your #include settings are off in
To sum up what we've covered, this is what happened in the game's logic: First the map was loaded. The game noticed
Then the game looked at the Team config settings for it's initial objectives. The player's team specified "objective_start_player". The game then searched all the .cfg files included in Objective_start_player
" had a TRUE condition, so it immediately carried out the action of loading the new objective "objective_player_at_goal
". Again, the game searched all the .cfg's for "objective_player_at_goal
" and found it. The condition was TRUE, but nothing happened since there was no Action specified. Since we set up the AI side like the player's, the same process happened there.
So, as you can see if an Objective is anywhere in the included .cfg's in types_mission.cfg, the game will find it. So, you could have everything we have in