// Interact Controller Appearance|Interactables|30040 namespace VRTK { using UnityEngine; using System; using System.Collections; /// /// Event Payload /// /// The object that is interacting. /// The object that is being ignored. [Obsolete("`InteractControllerAppearanceEventArgs` will be removed in a future version of VRTK.")] public struct InteractControllerAppearanceEventArgs { public GameObject interactingObject; public GameObject ignoredObject; } /// /// Event Payload /// /// this object /// [Obsolete("`InteractControllerAppearanceEventHandler` will be removed in a future version of VRTK.")] public delegate void InteractControllerAppearanceEventHandler(object sender, InteractControllerAppearanceEventArgs e); /// /// The Interact Controller Appearance script is attached on the same GameObject as an Interactable Object script and is used to determine whether the controller model should be visible or hidden on touch, grab or use. /// /// /// `VRTK/Examples/008_Controller_UsingAGrabbedObject` shows that the controller can be hidden when touching, grabbing and using an object. /// [AddComponentMenu("VRTK/Scripts/Interactions/Interactables/VRTK_InteractControllerAppearance")] [Obsolete("`VRTK_InteractControllerAppearance` has been replaced with `VRTK_InteractObjectAppearance`. This script will be removed in a future version of VRTK.")] public class VRTK_InteractControllerAppearance : MonoBehaviour { [Header("Touch Visibility")] [Tooltip("Hides the controller model when a valid touch occurs.")] public bool hideControllerOnTouch = false; [Tooltip("The amount of seconds to wait before hiding the controller on touch.")] public float hideDelayOnTouch = 0f; [Header("Grab Visibility")] [Tooltip("Hides the controller model when a valid grab occurs.")] public bool hideControllerOnGrab = false; [Tooltip("The amount of seconds to wait before hiding the controller on grab.")] public float hideDelayOnGrab = 0f; [Header("Use Visibility")] [Tooltip("Hides the controller model when a valid use occurs.")] public bool hideControllerOnUse = false; [Tooltip("The amount of seconds to wait before hiding the controller on use.")] public float hideDelayOnUse = 0f; /// /// Emitted when the interacting object is hidden. /// public event InteractControllerAppearanceEventHandler ControllerHidden; /// /// Emitted when the interacting object is shown. /// public event InteractControllerAppearanceEventHandler ControllerVisible; /// /// Emitted when the interacting object is hidden on touch. /// public event InteractControllerAppearanceEventHandler HiddenOnTouch; /// /// Emitted when the interacting object is shown on untouch. /// public event InteractControllerAppearanceEventHandler VisibleOnTouch; /// /// Emitted when the interacting object is hidden on grab. /// public event InteractControllerAppearanceEventHandler HiddenOnGrab; /// /// Emitted when the interacting object is shown on ungrab. /// public event InteractControllerAppearanceEventHandler VisibleOnGrab; /// /// Emitted when the interacting object is hidden on use. /// public event InteractControllerAppearanceEventHandler HiddenOnUse; /// /// Emitted when the interacting object is shown on unuse. /// public event InteractControllerAppearanceEventHandler VisibleOnUse; protected bool touchControllerShow = true; protected bool grabControllerShow = true; protected Coroutine hideControllerRoutine; public virtual void OnControllerHidden(InteractControllerAppearanceEventArgs e) { if (ControllerHidden != null) { ControllerHidden(this, e); } } public virtual void OnControllerVisible(InteractControllerAppearanceEventArgs e) { if (ControllerVisible != null) { ControllerVisible(this, e); } } public virtual void OnHiddenOnTouch(InteractControllerAppearanceEventArgs e) { if (HiddenOnTouch != null) { HiddenOnTouch(this, e); } } public virtual void OnVisibleOnTouch(InteractControllerAppearanceEventArgs e) { if (VisibleOnTouch != null) { VisibleOnTouch(this, e); } } public virtual void OnHiddenOnGrab(InteractControllerAppearanceEventArgs e) { if (HiddenOnGrab != null) { HiddenOnGrab(this, e); } } public virtual void OnVisibleOnGrab(InteractControllerAppearanceEventArgs e) { if (VisibleOnGrab != null) { VisibleOnGrab(this, e); } } public virtual void OnHiddenOnUse(InteractControllerAppearanceEventArgs e) { if (HiddenOnUse != null) { HiddenOnUse(this, e); } } public virtual void OnVisibleOnUse(InteractControllerAppearanceEventArgs e) { if (VisibleOnUse != null) { VisibleOnUse(this, e); } } /// /// The ToggleControllerOnTouch method determines whether the controller should be shown or hidden when touching an interactable object. /// /// If true then the controller will attempt to be made visible when no longer touching, if false then the controller will be hidden on touch. /// The touching object to apply the visibility state to. /// The object that is currently being interacted with by the touching object which is passed through to the visibility to prevent the object from being hidden as well. public virtual void ToggleControllerOnTouch(bool showController, GameObject touchingObject, GameObject ignoredObject) { if (hideControllerOnTouch) { touchControllerShow = showController; ToggleController(showController, touchingObject, ignoredObject, hideDelayOnTouch); if (showController) { OnVisibleOnTouch(SetEventPayload(touchingObject, ignoredObject)); } else { OnHiddenOnTouch(SetEventPayload(touchingObject, ignoredObject)); } } } /// /// The ToggleControllerOnGrab method determines whether the controller should be shown or hidden when grabbing an interactable object. /// /// If true then the controller will attempt to be made visible when no longer grabbing, if false then the controller will be hidden on grab. /// The grabbing object to apply the visibility state to. /// The object that is currently being interacted with by the grabbing object which is passed through to the visibility to prevent the object from being hidden as well. public virtual void ToggleControllerOnGrab(bool showController, GameObject grabbingObject, GameObject ignoredObject) { if (hideControllerOnGrab) { VRTK_InteractableObject objScript = (ignoredObject != null ? ignoredObject.GetComponentInParent() : null); //if attempting to show the controller but it's touched and the touch should hide the controller if (showController && !touchControllerShow && objScript && objScript.IsTouched()) { return; } grabControllerShow = showController; ToggleController(showController, grabbingObject, ignoredObject, hideDelayOnGrab); if (showController) { OnVisibleOnGrab(SetEventPayload(grabbingObject, ignoredObject)); } else { OnHiddenOnGrab(SetEventPayload(grabbingObject, ignoredObject)); } } } /// /// The ToggleControllerOnUse method determines whether the controller should be shown or hidden when using an interactable object. /// /// If true then the controller will attempt to be made visible when no longer using, if false then the controller will be hidden on use. /// The using object to apply the visibility state to. /// The object that is currently being interacted with by the using object which is passed through to the visibility to prevent the object from being hidden as well. public virtual void ToggleControllerOnUse(bool showController, GameObject usingObject, GameObject ignoredObject) { if (hideControllerOnUse) { VRTK_InteractableObject objScript = (ignoredObject != null ? ignoredObject.GetComponentInParent() : null); //if attempting to show the controller but it's grabbed and the grab should hide the controller if (showController && ((!grabControllerShow && objScript && objScript.IsGrabbed()) || (!touchControllerShow && objScript && objScript.IsTouched()))) { return; } ToggleController(showController, usingObject, ignoredObject, hideDelayOnUse); if (showController) { OnVisibleOnUse(SetEventPayload(usingObject, ignoredObject)); } else { OnHiddenOnUse(SetEventPayload(usingObject, ignoredObject)); } } } protected virtual void OnEnable() { if (!GetComponent()) { VRTK_Logger.Error(VRTK_Logger.GetCommonMessage(VRTK_Logger.CommonMessageKeys.REQUIRED_COMPONENT_MISSING_FROM_GAMEOBJECT, "VRTK_InteractControllerAppearance", "VRTK_InteractableObject", "the same")); } } protected virtual void OnDisable() { if (hideControllerRoutine != null) { StopCoroutine(hideControllerRoutine); } } protected virtual void ToggleController(bool showController, GameObject interactingObject, GameObject ignoredObject, float delayTime) { if (showController) { ShowController(interactingObject, ignoredObject); } else { hideControllerRoutine = StartCoroutine(HideController(interactingObject, ignoredObject, delayTime)); } } protected virtual void ShowController(GameObject interactingObject, GameObject ignoredObject) { if (hideControllerRoutine != null) { StopCoroutine(hideControllerRoutine); } VRTK_ObjectAppearance.SetRendererVisible(interactingObject, ignoredObject); OnControllerVisible(SetEventPayload(interactingObject, ignoredObject)); } protected virtual IEnumerator HideController(GameObject interactingObject, GameObject ignoredObject, float delayTime) { yield return new WaitForSeconds(delayTime); VRTK_ObjectAppearance.SetRendererHidden(interactingObject, ignoredObject); OnControllerHidden(SetEventPayload(interactingObject, ignoredObject)); } protected virtual InteractControllerAppearanceEventArgs SetEventPayload(GameObject interactingObject, GameObject ignroedObject) { InteractControllerAppearanceEventArgs e; e.interactingObject = interactingObject; e.ignoredObject = ignroedObject; return e; } } }