Glue:GlueVault:Component Pages:Game Scripting Plugin:AfterThat


The AfterThat function can simplify delaying the execution of Scripts after other scripts have run. The AfterThat function will look at the previous Do calls which are grouped under the previous “If” or “AfterThat”, and will only execute it’s Do’s when all of the previous Do’s are finished. This allows the creation of cascading sequences. For example, you may create a script which must wait for the player to advance the text before the next part of the script executes.

Requirements to use AfterThat

To use the AfterThat function effectively, your Do’s must contain logic to return when they are finished. If a Do (specifically a GeneralAction) does not contain a function for determining if it has finished, then it will be treated as if it has immediately finished once it has executed. Therefore, not all Do’s need to contain timing values if using AfterThat – only Do’s which you’d like to take a certain amount of time to execute.

Tutorial Introduction

For this tutorial we will use a Circle and move it right, then back left, then back right. We’ll use the AfterThat function to turn the circle around when it has reached its destination.

Setting up the If and Do functions

The first step is to create the If and Do functions that will be available in our game script. I won’t cover the steps here because they are identical to the implementation tutorial which can be found here|which can be found here.

In short the setup is:

  1. Create a new project
  2. Use the menu option provided by the Game Scripting plugin to add all of the required code files to your project.
  3. Create a screen called GameScreen
  4. Create a class called GameScript which should have the following contents:

Adding If.True()

It’s common to have a “True” function available under the If interface to kick off scripts. Our interface above already defines it, so we now have to implement the function in GameScript.

To implement this, add the following to your GameScript class:

Addding Do.MoveLeft() and Do.MoveRight()

Next, we’ll need to implement the MoveLeft and MoveRight functions. To do this, add the following to your GameScript class:

Notice that the MoveLeft and MoveRight functions are structured the same, but they use different values for velocity and for IsCompleteFunction. Let’s look specifically at MoveRight and identify what each line of code does:

This line of code creates an Action using a lambda expression. This could be done using anonymous delegates, or even functions that you create in your script code. This line of code will simply assign the argument objectToMove’s XVelocity to the argument speed variable when the script executes.

This line of code takes the “action” that we created above and stores it for execution. Calling CreateGeneralAction tells the scripting system to store this action and execute it when its owning If evaluates to true.

This line of code assigns a “IsCompleteFunction” which is used to determine when the action is complete. In this case we’re checking to see what the objectToMove’s X value is.

Again, we’re using a lambda expression here but this code could have been written with anonymous delegates or standard functions.

Creating Initialize

Now that we have our If and Do functions defined, let’s implement the script. To do this, add an Initialize function to your GameScript class which should look like this:

Notice that “AfterThat” takes the place of “If” for the second and third Do calls. The first AfterThat will wait until the first Do.MoveRight is finished before it executes its MoveLeft. Similarly, the second AfterThat will wait for Do.MoveLeft to finish before it executes its MoveRight.

Adding the Script to your Screen

Finally we need to add the script to the GameScreen. Once finished your GameScreen should look like this:

If you run your game you should now see your circle move right, then left, then back to the right on its own. Notice that we never specified any timing values – the AfterThat’s simply execute after the previous scripts run. This means that you can adjust any script and subsequent scripts will adjust automatically.