using System; using UnityEngine; namespace UnityEditor.U2D.Common.Path.GUIFramework { /// /// Represents an Action to process when the user clicks a particular mouse button a certain number of times. /// internal class ClickAction : HoveredControlAction { private int m_Button; private bool m_UseEvent; /// /// The number of button clicks required to satisfy the trigger condition /// public int clickCount = 1; /// /// The Action to execute when the user satisfies the trigger condition. /// public Action onClick; private int m_ClickCounter = 0; /// /// Initializes and returns an instance of ClickAction /// /// Current control /// The mouse button to check for. /// Whether to Use the current event after the trigger condition has been met. public ClickAction(Control control, int button, bool useEvent = true) : base(control) { m_Button = button; m_UseEvent = useEvent; } /// /// Checks to see if the trigger condition has been met or not. /// /// The current state of the custom editor. /// Returns `true` if the trigger condition has been met. Otherwise, returns false. protected override bool GetTriggerContidtion(IGUIState guiState) { if (guiState.mouseButton == m_Button && guiState.eventType == EventType.MouseDown) { if (guiState.clickCount == 1) m_ClickCounter = 0; ++m_ClickCounter; if (m_ClickCounter == clickCount) return true; } return false; } /// /// Calls the methods in its invocation list when the trigger conditions are met. /// /// The current state of the custom editor. protected override void OnTrigger(IGUIState guiState) { base.OnTrigger(guiState); if (onClick != null) onClick(guiState, hoveredControl); if (m_UseEvent) guiState.UseEvent(); } /// /// Checks to see if the finish condition has been met or not. For a ClickAction, this is always `true`. /// /// The current state of the custom editor. /// Returns `true`. protected override bool GetFinishContidtion(IGUIState guiState) { return true; } } }