diff options
Diffstat (limited to 'Client/Assets/Behavior Designer/Runtime/Conditionals/Physics/HasEnteredTrigger.cs')
-rw-r--r-- | Client/Assets/Behavior Designer/Runtime/Conditionals/Physics/HasEnteredTrigger.cs | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/Client/Assets/Behavior Designer/Runtime/Conditionals/Physics/HasEnteredTrigger.cs b/Client/Assets/Behavior Designer/Runtime/Conditionals/Physics/HasEnteredTrigger.cs new file mode 100644 index 00000000..648850fd --- /dev/null +++ b/Client/Assets/Behavior Designer/Runtime/Conditionals/Physics/HasEnteredTrigger.cs @@ -0,0 +1,41 @@ +using UnityEngine;
+
+namespace BehaviorDesigner.Runtime.Tasks
+{
+ [TaskDescription("Returns success when an object enters the trigger.")]
+ [TaskCategory("Physics")]
+ [HelpURL("http://www.opsive.com/assets/BehaviorDesigner/documentation.php?id=110")]
+ public class HasEnteredTrigger : Conditional
+ {
+ [Tooltip("The tag of the GameObject to check for a trigger against")]
+ public SharedString tag = "";
+ [Tooltip("The object that entered the trigger")]
+ public SharedGameObject otherGameObject;
+
+ private bool enteredTrigger = false;
+
+ public override TaskStatus OnUpdate()
+ {
+ return enteredTrigger ? TaskStatus.Success : TaskStatus.Failure;
+ }
+
+ public override void OnEnd()
+ {
+ enteredTrigger = false;
+ }
+
+ public override void OnTriggerEnter(Collider other)
+ {
+ if (string.IsNullOrEmpty(tag.Value) || tag.Value.Equals(other.gameObject.tag)) {
+ otherGameObject.Value = other.gameObject;
+ enteredTrigger = true;
+ }
+ }
+
+ public override void OnReset()
+ {
+ tag = "";
+ otherGameObject = null;
+ }
+ }
+}
\ No newline at end of file |