From fddbbd006653c0af23be26561366f53aaa653094 Mon Sep 17 00:00:00 2001 From: "Simon (darkside) Jackson" Date: Wed, 26 Aug 2015 10:01:08 +0100 Subject: [PATCH] Started 5.1 branch (supports 5.0-5.1) Added new selection box control. Ready for merging 5.x fixes --HG-- branch : develop-Unity5.1 --- Scripts/SelectionBox/ExampleSelectable.cs | 4 +- Scripts/SelectionBox/SelectionBox.cs | 2 +- Scripts/UIScrollToSelection.cs | 200 +++++++++++----------- Scripts/UIScrollToSelection.cs.meta | 8 + 4 files changed, 110 insertions(+), 104 deletions(-) create mode 100644 Scripts/UIScrollToSelection.cs.meta diff --git a/Scripts/SelectionBox/ExampleSelectable.cs b/Scripts/SelectionBox/ExampleSelectable.cs index 96d9ec5..580d3b2 100644 --- a/Scripts/SelectionBox/ExampleSelectable.cs +++ b/Scripts/SelectionBox/ExampleSelectable.cs @@ -84,9 +84,9 @@ namespace UnityEngine.UI.Extensions { image.color = color; } - else if (renderer) + else if (GetComponent()) { - renderer.material.color = color; + GetComponent().material.color = color; } diff --git a/Scripts/SelectionBox/SelectionBox.cs b/Scripts/SelectionBox/SelectionBox.cs index bb1f847..1169beb 100644 --- a/Scripts/SelectionBox/SelectionBox.cs +++ b/Scripts/SelectionBox/SelectionBox.cs @@ -235,7 +235,7 @@ namespace UnityEngine.UI.Extensions } else { //If it doesn't have a rectTransform, we need to get the radius so we can use it as an area around the center to detect a click. //This works because a 2D or 3D renderer will both return a radius - var radius = selectable.transform.renderer.bounds.extents.magnitude; + var radius = selectable.transform.GetComponent().bounds.extents.magnitude; var selectableScreenPoint = GetScreenPointOfSelectable(selectable); diff --git a/Scripts/UIScrollToSelection.cs b/Scripts/UIScrollToSelection.cs index 83c4bee..aab4fda 100644 --- a/Scripts/UIScrollToSelection.cs +++ b/Scripts/UIScrollToSelection.cs @@ -2,105 +2,103 @@ /*USAGE: Simply place the script on the ScrollRect that contains the selectable children we'll be scroling to -and drag'n'drop the RectTransform of the options "container" that we'll be scrolling.*/ - -using UnityEngine; -using System.Collections; -using UnityEngine.UI; -using UnityEngine.EventSystems; - -public class UIScrollToSelection : MonoBehaviour { - -/* ### VARIABLES ============================================================== */ - - // settings - public float scrollSpeed = 10f; - - [SerializeField] - private RectTransform layoutListGroup; - - // temporary variables - private RectTransform targetScrollObject; - private bool scrollToSelection = true; - - // references - private RectTransform scrollWindow; - private RectTransform currentCanvas; - private ScrollRect targetScrollRect; - - -/* ### MAIN METHODS =========================================================== */ - // Use this for initialization - private void Start () { - targetScrollRect = GetComponent(); - scrollWindow = targetScrollRect.GetComponent(); - currentCanvas = transform.root.GetComponent(); - } - - // Update is called once per frame - private void Update () { - ScrollRectToLevelSelection(); - } - - private void ScrollRectToLevelSelection (){ - // check main references - bool referencesAreIncorrect = - (targetScrollRect == null || layoutListGroup == null || scrollWindow == null); - if (referencesAreIncorrect == true){ - return; - } - - // get calculation references - EventSystem events = EventSystem.current; - RectTransform selection = events.currentSelectedGameObject != null ? - events.currentSelectedGameObject.GetComponent() : - null; - RectTransform lastSelection = events.lastSelectedGameObject != null ? - events.lastSelectedGameObject.GetComponent() : - selection; - - if (selection != targetScrollObject) - scrollToSelection = true; - - // check if scrolling is possible - bool isScrollDirectionUnknown = - (selection == null || lastSelection == null || scrollToSelection == false); - - if (isScrollDirectionUnknown == true || selection.transform.parent != layoutListGroup.transform) - return; - - // move the current scroll rect to correct position - float selectionPos = -selection.anchoredPosition.y; - int direction = (int)Mathf.Sign(selection.anchoredPosition.y - lastSelection.anchoredPosition.y); - - float elementHeight = layoutListGroup.sizeDelta.y / layoutListGroup.transform.childCount; - float maskHeight = currentCanvas.sizeDelta.y + scrollWindow.sizeDelta.y; - float listPixelAnchor = layoutListGroup.anchoredPosition.y; - - // get the element offset value depending on the cursor move direction - float offlimitsValue = 0; - if (direction > 0 && selectionPos < listPixelAnchor) - { - offlimitsValue = listPixelAnchor - selectionPos; - } - if (direction < 0 && selectionPos + elementHeight > listPixelAnchor + maskHeight) - { - offlimitsValue = (listPixelAnchor + maskHeight) - (selectionPos + elementHeight); - } - // move the target scroll rect - targetScrollRect.verticalNormalizedPosition += - (offlimitsValue / layoutListGroup.sizeDelta.y) * Time.deltaTime * scrollSpeed; - // check if we reached our destination - if (Mathf.Abs(offlimitsValue) < 2f) - scrollToSelection = false; - // save last object we were "heading to" to prevent blocking - targetScrollObject = selection; - } - -/* ### ENUMS ================================================================== */ - - -/* ### CUSTOM TYPES =========================================================== */ - - +and drag'n'drop the RectTransform of the options "container" that we'll be scrolling.*/ + +using UnityEngine.EventSystems; + +namespace UnityEngine.UI.Extensions +{ + public class UIScrollToSelection : MonoBehaviour + { + + /* ### VARIABLES ============================================================== */ + + // settings + public float scrollSpeed = 10f; + + [SerializeField] + private RectTransform layoutListGroup; + + // temporary variables + private RectTransform targetScrollObject; + private bool scrollToSelection = true; + + // references + private RectTransform scrollWindow; + private RectTransform currentCanvas; + private ScrollRect targetScrollRect; + + private EventSystem events = EventSystem.current; + + /* ### MAIN METHODS =========================================================== */ + // Use this for initialization + private void Start() + { + targetScrollRect = GetComponent(); + scrollWindow = targetScrollRect.GetComponent(); + currentCanvas = transform.root.GetComponent(); + } + + // Update is called once per frame + private void Update() + { + ScrollRectToLevelSelection(); + } + + private void ScrollRectToLevelSelection() + { + // check main references + bool referencesAreIncorrect = + (targetScrollRect == null || layoutListGroup == null || scrollWindow == null); + if (referencesAreIncorrect == true) + { + return; + } + + // get calculation references + RectTransform selection = events.currentSelectedGameObject != null ? + events.currentSelectedGameObject.GetComponent() : + null; + RectTransform lastSelection = events.lastSelectedGameObject != null ? + events.lastSelectedGameObject.GetComponent() : + selection; + + if (selection != targetScrollObject) + scrollToSelection = true; + + // check if scrolling is possible + bool isScrollDirectionUnknown = + (selection == null || lastSelection == null || scrollToSelection == false); + + if (isScrollDirectionUnknown == true || selection.transform.parent != layoutListGroup.transform) + return; + + // move the current scroll rect to correct position + float selectionPos = -selection.anchoredPosition.y; + int direction = (int)Mathf.Sign(selection.anchoredPosition.y - lastSelection.anchoredPosition.y); + + float elementHeight = layoutListGroup.sizeDelta.y / layoutListGroup.transform.childCount; + float maskHeight = currentCanvas.sizeDelta.y + scrollWindow.sizeDelta.y; + float listPixelAnchor = layoutListGroup.anchoredPosition.y; + + // get the element offset value depending on the cursor move direction + float offlimitsValue = 0; + if (direction > 0 && selectionPos < listPixelAnchor) + { + offlimitsValue = listPixelAnchor - selectionPos; + } + if (direction < 0 && selectionPos + elementHeight > listPixelAnchor + maskHeight) + { + offlimitsValue = (listPixelAnchor + maskHeight) - (selectionPos + elementHeight); + } + // move the target scroll rect + targetScrollRect.verticalNormalizedPosition += + (offlimitsValue / layoutListGroup.sizeDelta.y) * Time.deltaTime * scrollSpeed; + // check if we reached our destination + if (Mathf.Abs(offlimitsValue) < 2f) + scrollToSelection = false; + // save last object we were "heading to" to prevent blocking + targetScrollObject = selection; + } + } } \ No newline at end of file diff --git a/Scripts/UIScrollToSelection.cs.meta b/Scripts/UIScrollToSelection.cs.meta new file mode 100644 index 0000000..5c24bcc --- /dev/null +++ b/Scripts/UIScrollToSelection.cs.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: a5f5420166e1c6d4f849661cbdbc52f8 +MonoImporter: + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: