Difference between revisions of "Spawning AI with triggers"
Views
Actions
Namespaces
Variants
Tools
Jester2138 (talk | contribs) |
Jester2138 (talk | contribs) |
||
Line 13: | Line 13: | ||
Here's what you need to place in each trigger: | Here's what you need to place in each trigger: | ||
In the trigger that saves and deletes the scene you want to load later: | '''In the trigger that saves and deletes the scene you want to load later:''' | ||
*''Variable Name:'' whatever you want, e.g. "saveBridgeSCene" | *''Variable Name:'' whatever you want, e.g. "saveBridgeSCene" | ||
Line 28: | Line 28: | ||
*''On Deactivation:'' leave blank | *''On Deactivation:'' leave blank | ||
In the trigger that waits for a condition to be met and then loads the scene | '''In the trigger that waits for a condition to be met and then loads the scene:''' | ||
You can set it up however you want depending on how you want to activate the trigger, but the "On Activation" field must contain the command below. Here's how to do it so that when a Blufor player enters the area, the scene loads: | |||
*''Variable Name:'' whatever you want, e.g. "loadBridgeScene" | *''Variable Name:'' whatever you want, e.g. "loadBridgeScene" | ||
Line 43: | Line 45: | ||
*''On Deactivation:'' leave blank | *''On Deactivation:'' leave blank | ||
In the description.ext | '''In the description.ext:''' | ||
You need to add another class under the section beginning with "cfgFunctions": | |||
<nowiki> | <nowiki> |
Revision as of 05:09, 16 April 2018
There is a little-documented but easy method to spawn AI in complex arrangements without scripting a bunch of stuff.
Here is an example vanilla-Arma mission on Jester's Google Drive: https://drive.google.com/open?id=1mn49T-tMc3TO4rG5V-fD-S32tCghy8I8
This works great for loading objective areas only as they're needed for performance reasons, or for spawning specific ambushes, or any number of things.
In the editor, you'll see all the AI placed as well as two triggers. The first trigger looks at all the AI in its area, saves their locations and waypoints, and immediately deletes them. The second trigger loads what was saved in the first when the player walks onto the bridge. Load the mission in MP and you'll see that when you walk onto the bridge a few AI spawn in front of you with cycling waypoints. It must be loaded in MP because the triggers will only run on the server.
Note: for cycling waypoints to work, you must place the "Cycle" waypoint such that a line is automatically drawn between it and the first "Move" waypoint. This is because the function does not save which waypoint is currently active, and if the final "Cycle" is not connected to the first "Move," the AI will only go through the list once and then stop. If this doesn't make sense, look at the example mission and note how the waypoints are placed.
There are three steps to making this work in your mission. 1) add the trigger that saves and deletes the scene 2) add the trigger that loads the scene 3) edit the description.ext file of you mission to configure the necessary functions
Here's what you need to place in each trigger:
In the trigger that saves and deletes the scene you want to load later:
- Variable Name: whatever you want, e.g. "saveBridgeSCene"
- Type: none
- Activation: none
- Repeatable: unchecked
- Server Only: checked
- Condition: true
- On Activation:
[thisTrigger, "bridgeScene"] call mytag_fnc_savescene; ["bridgeScene", false] call mytag_fnc_deletescene
- On Deactivation: leave blank
In the trigger that waits for a condition to be met and then loads the scene:
You can set it up however you want depending on how you want to activate the trigger, but the "On Activation" field must contain the command below. Here's how to do it so that when a Blufor player enters the area, the scene loads:
- Variable Name: whatever you want, e.g. "loadBridgeScene"
- Type: None
- Activation: Blufor
- Activation Type: Present
- Repeatable: unchecked
- Server Only: checked
- Condition: player in thisList
- On Activation:
["bridgeScene", false] call mytag_fnc_loadscene
- On Deactivation: leave blank
In the description.ext:
You need to add another class under the section beginning with "cfgFunctions":
class MyScenes { tag = "MyTag"; class Scenes { file = "A3\Missions_F_Bootcamp\Campaign\Functions\Scenes"; class deleteScene {}; class loadScene {}; class saveScene {}; class setSceneInit {}; }; };