Sega 500 Scripted events and Sequences Jeff “Ezeikeil” Giles
Thus far We’ve played lots with the game dynamics to change how UT2003 runs. But, we’ve done little to nothing on how to cause a chain or sequence of events.
Today This, boys and girls is the land of the scripted sequence. We’re going to look at what it takes to include one in our game.
“I’m a programmer Jim, not a level designer” What are they and why do I care? Scripted Sequences are great tools to that allow the game to tell a story, set a mood or have something happen that “makes sense”.
“I’m a programmer Jim, not a level designer” Look a some of the other games that have used them to great effect…
Half-life
Max Payne
And of course…UT2003
UT2003
Fine, Fine… Enough about the story…why do I care…Me programmer! As programmers, we should and do care about these sequences since we could quite realistically be asked to build tools for them.
Our Goal For the next few lessons is to look at and develop an understanding of how these work. Then, develop a action sequence or two of our very own.
Oh, yeah You can also use the AIScript component of the scripted sequence to affect to behaviour of a bot in game. Thus changing it’s AI properties… e.g. it’s behaviour.
Getting started Today, our play in UScript is going to be minimal. We’re back in the Editor. But first, some set up info…
Getting started All bots in the game derive from Scripted controller, which is what allows our bots to follow other scripts. It is the AI controller which is the “brains” for the pawn. Achieved through a scripted sequence specified by an AIScript.
Getting started These work in close conjunction with AIScript’s which are placeable into the level. Used by Level Designers to specify special AI scripts for pawns placed in a level, and to change which type of AI controller to use for a pawn.
Getting started AIScripts can be shared by one or many pawns. Game specific subclasses of AIScript will have editable properties defining game specific behavior and AI.
Getting started The one we’re interested in is the UnrealScriptedSequence. This derives from ScriptedSequence provides the core functionality for setting up scripted sequences for pawns. A ScriptedController is spawned to carry out the scripted sequence.
Getting started Lastly, we have our actions list… It’s a rather long list of scripted actions available to the scripted controller These are the Actions that are used by a ScriptedSequence script which are the commands that tell the script what to do.
Getting started For a really good look and description of these actions, consult the wiki.
Getting started Now that’s out of the way, time to build our own basic sequence. In short, we’ll get a bot to run around the room and then do something at each corner.
Getting started Start off with a simple test level, a box. Then add a XPawn and an UnrealScriptedSequence.
Simple Script At this point, the Script and Bot have no knowledge of each other, they need to be linked. If we run it now, the game will run as normal with this xPawn spawning in with us.
Linking the xPawn to the Script To link a pawn to a UnrealScriptedSequence, you need to set the pawn's AIScriptTag to the Tag of the UnrealScriptedSequence. This will cause the sequence to start executing as soon as the pawn is active in the level (usually as soon as the level begins).
Linking the xPawn to the Script AIScript tag must match the xPawns events Tag.
Linking the xPawn to the Script If all goes well, when the xPawn is selected a blue line will link the pawn to it’s script.
Linking the xPawn to the Script Lastly, we need to tell the UnrealScriptedSequence which controller this script affects. For now, just set it to ScriptedController so that we have total control over our pawn. It will have no brain of its own.
Linking the xPawn to the Script If you run the level now, you should have a dumb bot that simply stands there playing it’s idle animation.
Add some actions In your UnrealScriptedSequence actor, under AIScript is a dynamic array of Actions. These actions determine how the bot will behave. Notice that it starts with a default set of actions.
Add some actions Initially, your Actions array will be empty. To add a new action, click on Add. This will create an empty element in the array (Add will always create elements at the end of the array).
Add some actions Caution: If, at any point, you click on Empty, it will clear the whole array, and you will lose any data that was in it. We don’t want the default actions, so empty the list.
Add some actions Once you have an empty element in the array, you can expand it, and get a drop-down box which lists all the items which can be added into the array. To create a specific item for the array, select the item you wish to use from the drop-down-box, and click on New. The item that has been created can then be expanded to allow access to its variables.
Getting our dude to move So in the AIScript pull down, add an action from the pull down menu. In this case ACTION_MoveToPoint and hit new. Lastly set the destination tag.
Getting our dude to move Of course we need a destination. I’m going to use pathnodes. But really, we could use anything. Place one in the far corner and give its tag the same name as the destinationTag in the ACTION_MoveToPoint
Getting our dude to move And our dude springs into action, running to the path node of matching tag.
Getting our dude to move Now, if we place a node in each corner and string them together, we can make our bot do laps. Simply by adding new move to actions and pathnodes with matching tags.
Doing laps
Cool! Your very first scripted sequence. The bot does one lap of the room and then runs in place at the last node. We can get him to stop that by adding another action at the end of the list, say ACTION_TurnTowardPlayer
Doing laps But, better idea, there’s a goto action where we can jump to any action in the list. I’m going to jump to the first on so he goes in circles….forever.
Doing laps Let’s make the circuit a bit more interesting and make him do something unique at each corner.
Doing laps Corner 1: Jump Easy to set up, Just insert the Action_Jump, select the jump type and move to corner 2.
Doing laps Corner 2: play a sound Like above, real easy. Select a sound from the list.
Doing laps Corner 3: pause then seek the player A bit different, but still easy to set up. But there are 2 Actions here, ACTION_WaitForTimer and ACTION_MoveToPlayer
Doing laps Once the player is touched, the bot will return to its circuit.
Doing laps Corner 4: Wait for an event, repeat the circuit. The bot will remain at this location until an event is received. We’ll just set up a trigger to broadcast one.
Doing laps And use ACTION_WaitForEvent to hold until the event is broadcast.
Doing laps Now, setting up the trigger is a bit different as it’s looking for an event an not the usual broadcast tag. This causes an error to be generated but it works fine. You can make the error go away by using the tag in the triggers event also.
That’s a wrap This is only scraping the surface of what can be done via scritped sequences. But it’s a good starting point. And remember, these can be used to influence / over ride regular bot AI too.
Next Day… We’ll be looking at another item know as the scripted trigger which functions in a similar manner to the scripted sequences. But can be used for timing / triggering or setting off a series of sequential events.