summaryrefslogtreecommitdiff
path: root/Runtime/Graphs/UnityEngine.Graphs/LogicNodeLibrary/Input/OnMouseButton.cs
diff options
context:
space:
mode:
Diffstat (limited to 'Runtime/Graphs/UnityEngine.Graphs/LogicNodeLibrary/Input/OnMouseButton.cs')
-rw-r--r--Runtime/Graphs/UnityEngine.Graphs/LogicNodeLibrary/Input/OnMouseButton.cs38
1 files changed, 38 insertions, 0 deletions
diff --git a/Runtime/Graphs/UnityEngine.Graphs/LogicNodeLibrary/Input/OnMouseButton.cs b/Runtime/Graphs/UnityEngine.Graphs/LogicNodeLibrary/Input/OnMouseButton.cs
new file mode 100644
index 0000000..544a1e8
--- /dev/null
+++ b/Runtime/Graphs/UnityEngine.Graphs/LogicNodeLibrary/Input/OnMouseButton.cs
@@ -0,0 +1,38 @@
+using UnityEngine;
+
+namespace UnityEngine.Graphs.LogicGraph
+{
+ public partial class InputNodes
+ {
+ [Logic]
+ [Title("Input/On Mouse Button")]
+ public sealed class OnMouseButton : OnStateInputNode
+ {
+ private int m_MouseButton;
+ public int mouseButton { set { m_MouseButton = value; } }
+
+ public OnMouseButton (GraphBehaviour graphBehaviour) : base (graphBehaviour) { }
+ public OnMouseButton (IMonoBehaviourEventCaller graphBehaviour, int mouseButton) : base (graphBehaviour)
+ {
+ m_MouseButton = mouseButton;
+ }
+
+ protected override void OnUpdate ()
+ {
+ if (onDown != null && Input.GetMouseButtonDown (m_MouseButton))
+ onDown ();
+
+ if (onUp != null && Input.GetMouseButtonUp (m_MouseButton))
+ onUp ();
+
+ if (down != null || up != null)
+ {
+ var stateDelegate = Input.GetMouseButton (m_MouseButton) ? down : up;
+ if (stateDelegate != null)
+ stateDelegate ();
+ }
+ }
+ }
+ }
+}
+