createTrigger: Difference between revisions

From Bohemia Interactive Community
No edit summary
No edit summary
 
(126 intermediate revisions by 7 users not shown)
Line 1: Line 1:
{{Command|= Comments
{{RV|type=command
____________________________________________________________________________________________


| arma |= Game name
|game1= ofpe
|version1= 1.00


|1.00|= Game version
|game2= arma1
|eff= global|=
|version2= 1.00
____________________________________________________________________________________________


| Creates a sensor ([[trigger]]) of the given type and at the given position. The type must be a class name in CfgNonAIVehicles or CfgVehicles with simulation <nowiki>=</nowiki> detector. An array containing all units that have activated the trigger is available via [[list]] ''triggerobj''. Created triggers can be deleted using [[deleteVehicle]].<br><br>
|game3= arma2
|version3= 1.00


'''NOTE1:''' Since Arma 3 v1.43.129935 triggers can be created locally on clients using the alternative syntax.<br>
|game4= arma2oa
'''NOTE2:''' Since Arma 3 v1.53.132440 triggers can be disabled/enabled using [[enableSimulation]] command.<br><br>
|version4= 1.50


Triggers are created with default params, which are:
|game5= tkoh
* a - 50.0
|version5= 1.00
* b - 50.0
* angle - 0
* rectangular - false
* activationBy - None
* activationType - Present
* repeating - false
* timeoutMin - 0
* timeoutMid - 0
* timeoutMax - 0
* interruptable - true
* type - None
* text - ""
* name - ""
* expCond - "this"
* expActiv - ""
* expDesactiv - ""
|= Description
____________________________________________________________________________________________


| '''createTrigger''' [type, position, ''makeGlobal'']|= Syntax
|game6= arma3
|version6= 0.50


|p1= [type, position, makeGlobal]: [[Array]] |= Parameter 1
|gr1= Triggers
|p2= type: [[String]] |= Parameter 2
|p3= position: [[Position2D]], [[Position3D]] or [[Object]] |= Parameter 3
|p4= ''makeGlobal (optional)'': [[Boolean]] - locality flag, true - trigger is global {{EffArg|cmd|eff|glob}}, false - trigger is local {{EffArg|cmd|eff|local}} ''(available since Arma 3 v1.43.129935)''|= Parameter 3


| [[Object]] |= Return value
|descr= Creates a [[Trigger|trigger]] of the given type and at the given position. The type must be a class name in ''CfgNonAIVehicles'' or ''CfgVehicles'' with <syntaxhighlight lang="cpp" inline>simulation = detector</syntaxhighlight>. An array containing all units that have activated the trigger is available via <sqf inline>list triggerobj</sqf>. Since triggers are '''[[Object]]s''', commands such as [[getPosASL]], [[setPosASL]], [[deleteVehicle]] etc. work on them.
{{Feature|important|Triggers are always created on the road surface (AGL) at provided x, y coordinates. The z param is ignored. In order to place the trigger with a custom z, use a 'setPosXXX' command after trigger creation.}}
{{Feature|informative|Since {{arma3}} v1.54 triggers can be disabled/enabled using [[enableSimulation]] command.}}


Triggers are created with default parameters:
{{Columns|4|
* {{hl|a}}: 50
* {{hl|b}}: 50
* {{hl|c}}: -1
* {{hl|angle}}: 0
* {{hl|rectangular}}: false
* {{hl|activationBy}}: None
* {{hl|activationType}}: Present
* {{hl|repeating}}: false
* {{hl|timeoutMin}}: 0
* {{hl|timeoutMid}}: 0
* {{hl|timeoutMax}}: 0
* {{hl|interruptable}}: true
* {{hl|type}}: None
* {{hl|text}}: ""
* {{hl|name}}: ""
* {{hl|expCond}}: "this"
* {{hl|expActiv}}: ""
* {{hl|expDesactiv}}: ""
* {{GVI|arma3|1.98|size= 0.75}} {{hl|interval}}: 0.5
}}


____________________________________________________________________________________________
|s1= [[createTrigger]] [type, position, makeGlobal]
 
|x1= <code>_trg = [[createTrigger]] ["EmptyDetector", [[getPos]] [[player]]];
_trg [[setTriggerArea]] [5, 5, 0, [[false]]];
_trg [[setTriggerActivation]] ["CIV", "PRESENT", [[true]]];
_trg [[setTriggerStatements]] ["this", "hint 'Civilian near player'", "hint 'no civilian near'"];</code>|= Example 1
____________________________________________________________________________________________
|mp= Triggers are global and will be present on all machine(s) when this command is run. |=
|[[setTriggerActivation]], [[setTriggerArea]], [[setTriggerStatements]], [[setTriggerText]], [[setTriggerTimeout]], [[setTriggerType]], [[setEffectCondition]], [[setSoundEffect]], [[setMusicEffect]], [[setTitleEffect]], [[deleteVehicle]], [[synchronizeWaypoint]], [[synchronizeTrigger]] |= See also


}}
|p1= type: [[String]] - usually "EmptyDetector"


<h3 style="display:none">Notes</h3>
|p2= position: [[Position#Introduction|Position2D]], [[Position#Introduction|Position3D]] or [[Object]] (see the note in description)
<dl class="command_description">
<!-- Note Section BEGIN -->


<dd class="notedate">Posted on March 6, 2013 - 14:15 (CEST)
|p3= makeGlobal: [[Boolean]] - (Optional - default [[true]]) locality flag
<dt class="note">'''[[User:TeaCup|teaCup]]'''
* [[true]] - trigger is global {{Icon|globalEffect|24}}
<dd class="note">Calling [[list]] immediately after creating a trigger this way (and setting up activation, area, statements, timeout, etc..), will return <null> instead of an array. It seems the trigger needs about 1 second to initialise, after which it will behave as expected: returning an array of all the objects inside the trigger (the ones matching the criteria), or an empty array.
* [[false]] - trigger is local {{Icon|localEffect|24}}
|p3since= arma3 1.44


<!-- Note Section END -->
|r1= [[Object]] - created trigger
</dl>


<h3 style="display:none">Bottom Section</h3>
|x1= <sqf>
_trg = createTrigger ["EmptyDetector", getPos player];
_trg setTriggerArea [5, 5, 0, false];
_trg setTriggerActivation ["CIV", "PRESENT", true];
_trg setTriggerStatements ["this", "hint 'Civilian near player'", "hint 'no civilian near'"];
</sqf>


[[Category:Scripting Commands|CREATETRIGGER]]
|x2= Open/close Bar Gate automatically:
[[Category:Scripting Commands OFP Elite |CREATETRIGGER]]
<sqf>
[[Category:Scripting Commands ArmA|CREATETRIGGER]]
//--- init of the Bar Gate
[[Category:Command_Group:_Activators|{{uc:{{PAGENAME}}}}]]
if (isServer) then
[[Category:Scripting Commands ArmA2|{{uc:{{PAGENAME}}}}]]
{
[[Category:Scripting Commands Arma 3|{{uc:{{PAGENAME}}}}]]
_gateTrigger = createTrigger ["EmptyDetector", getPosWorld this, false];
[[Category:Scripting_Commands_Take_On_Helicopters|{{uc:{{PAGENAME}}}}]]
_gateTrigger setVariable ["BarGateObj", this];
_gateTrigger setTriggerActivation ["ANYPLAYER", "PRESENT", true];
_gateTrigger setTriggerArea [5, 25, getDir this, true];
_gateTrigger setTriggerStatements
[
"this",
"thisTrigger getVariable ""BarGateObj"" animateSource [""Door_1_sound_source"", 1]",
"thisTrigger getVariable ""BarGateObj"" animateSource [""Door_1_sound_source"", 0]"
];
};
</sqf>


<!-- CONTINUE Notes -->
|seealso= [[setTriggerActivation]] [[setTriggerArea]] [[setTriggerStatements]] [[setTriggerText]] [[setTriggerTimeout]] [[setTriggerType]] [[setEffectCondition]] [[setSoundEffect]] [[setMusicEffect]] [[setTitleEffect]] [[deleteVehicle]] [[synchronizeWaypoint]] [[synchronizeTrigger]] [[createGuardedPoint]] [[triggerInterval]] [[setTriggerInterval]] [[enableSimulation]] [[simulationEnabled]]
<dl class="command_description">
}}
<dd class="notedate">Posted on September 18, 2015 - 12:54 (UTC)</dd>
 
<dt class="note">[[User:MisterGoodson|MisterGoodson]]</dt>
{{Note
<dd class="note">
|user= TeaCup
Following TeaCup's note, you can reliably use the following to wait until a trigger has initialized:
|timestamp= 20130306141500
<code>waitUntil {(count (list _trigger)) > 0}; // Wait for trigger to initialize</code>
|text= Calling [[list]] immediately after creating a trigger this way (and setting up activation, area, statements, timeout, etc..), will return <null> instead of an array. It seems the trigger needs about 1 second to initialise, after which it will behave as expected: returning an array of all the objects inside the trigger (the ones matching the criteria), or an empty array.
</dd>
}}
</dl>
<!-- DISCONTINUE Notes -->

Latest revision as of 21:20, 31 October 2024

Hover & click on the images for description

Description

Description:
Creates a trigger of the given type and at the given position. The type must be a class name in CfgNonAIVehicles or CfgVehicles with simulation = detector. An array containing all units that have activated the trigger is available via list triggerobj. Since triggers are Objects, commands such as getPosASL, setPosASL, deleteVehicle etc. work on them.
Triggers are always created on the road surface (AGL) at provided x, y coordinates. The z param is ignored. In order to place the trigger with a custom z, use a 'setPosXXX' command after trigger creation.
Since Arma 3 v1.54 triggers can be disabled/enabled using enableSimulation command.

Triggers are created with default parameters:

  • a: 50
  • b: 50
  • c: -1
  • angle: 0
  • rectangular: false
  • activationBy: None
  • activationType: Present
  • repeating: false
  • timeoutMin: 0
  • timeoutMid: 0
  • timeoutMax: 0
  • interruptable: true
  • type: None
  • text: ""
  • name: ""
  • expCond: "this"
  • expActiv: ""
  • expDesactiv: ""
  • Arma 3 logo black.png 1.98 interval: 0.5
Groups:
Triggers

Syntax

Syntax:
createTrigger [type, position, makeGlobal]
Parameters:
type: String - usually "EmptyDetector"
position: Position2D, Position3D or Object (see the note in description)
since Arma 3 logo black.png 1.44
makeGlobal: Boolean - (Optional - default true) locality flag
Return Value:
Object - created trigger

Examples

Example 1:
_trg = createTrigger ["EmptyDetector", getPos player]; _trg setTriggerArea [5, 5, 0, false]; _trg setTriggerActivation ["CIV", "PRESENT", true]; _trg setTriggerStatements ["this", "hint 'Civilian near player'", "hint 'no civilian near'"];
Example 2:
Open/close Bar Gate automatically:
//--- init of the Bar Gate if (isServer) then { _gateTrigger = createTrigger ["EmptyDetector", getPosWorld this, false]; _gateTrigger setVariable ["BarGateObj", this]; _gateTrigger setTriggerActivation ["ANYPLAYER", "PRESENT", true]; _gateTrigger setTriggerArea [5, 25, getDir this, true]; _gateTrigger setTriggerStatements [ "this", "thisTrigger getVariable ""BarGateObj"" animateSource [""Door_1_sound_source"", 1]", "thisTrigger getVariable ""BarGateObj"" animateSource [""Door_1_sound_source"", 0]" ]; };

Additional Information

See also:
setTriggerActivation setTriggerArea setTriggerStatements setTriggerText setTriggerTimeout setTriggerType setEffectCondition setSoundEffect setMusicEffect setTitleEffect deleteVehicle synchronizeWaypoint synchronizeTrigger createGuardedPoint triggerInterval setTriggerInterval enableSimulation simulationEnabled

Notes

Report bugs on the Feedback Tracker and/or discuss them on the Arma Discord or on the Forums.
Only post proven facts here! Add Note
TeaCup - c
Posted on Mar 06, 2013 - 14:15 (UTC)
Calling list immediately after creating a trigger this way (and setting up activation, area, statements, timeout, etc..), will return <null> instead of an array. It seems the trigger needs about 1 second to initialise, after which it will behave as expected: returning an array of all the objects inside the trigger (the ones matching the criteria), or an empty array.