diff --git a/README.md b/README.md
index 032f252..357b0bf 100644
--- a/README.md
+++ b/README.md
@@ -36,8 +36,6 @@ Control | Description | Menu Command | Component Command | Notes | Credits
| | | Component / UI / Extensions / AccordionItem |[demo video](http://forum.unity3d.com/threads/accordion-type-layout.271818/)| ChoMPHi
**HSVPicker** | A colour picker UI | N/A | UI / Extensions / HSVPicker | Project folder includes prefab and sample scene | judah4
**SelectionBox** | An RTS style selection box control | UI / Extensions / Selection Box | UI / Extensions / Selection Box |[tutorial video](https://www.youtube.com/watch?v=UtM3HejKL5s)| Korindian, BenZed
-**HorizontalScrollSnap** | A pages scroll rect that can work in steps / pages, includes button support | UI / Extensions / Horizontal Scroll Snap | UI / Extensions / Horizontal Scroll Snap |[tutorial video](https://www.youtube.com/watch?v=KJlIlWHlfMo)| BinaryX
-**VerticalScrollSnap** | A pages scroll rect that can work in steps / pages, includes button support | UI / Extensions / Vertical Scroll Snap | UI / Extensions / Vertical Scroll Snap |[tutorial video](https://www.youtube.com/watch?v=KJlIlWHlfMo)| BinaryX, Simon Darkside Jackson
**UIButton** | Improved Button control with additional events (PointerDown, PointerUp, PointerClick and PointerHeld) | UI / Extensions / UI Button | UI / Extensions / UI Button |Will update video, this has now been updated to a more reusable Selectable extension| AriathTheWise
**UIFlippable** | Improved Image control with image flipping options | UI / Extensions / UI Flippable | UI / Extensions / Flippable |[tutorial video](https://www.youtube.com/watch?v=Htt2RNa2qy0)| ChoMPHi
**UIWindowBase** | A draggable Window implementation | UI / Extensions / UI Window Base | UI / Extensions / UI Window Base |[tutorial video](https://www.youtube.com/watch?v=Htt2RNa2qy0)| GXMark, alexzzzz, CaoMengde777, TroyDavis
@@ -46,8 +44,31 @@ Control | Description | Menu Command | Component Command | Notes | Credits
**DropDownList** | A basic drop down list with text and image support | UI / Extensions / Dropdown List | UI / Extensions / Dropdown List |[tutorial video](https://www.youtube.com/watch?v=JrEfs47FoOE)| Perchik
**BoundToolTip** | An alternate Tooltip implementation with central listener | UI / Extensions / Bound Tooltip / Tooltip | UI / Extensions / Bound Tooltip / Tooltip Item | Offset and tooltip placement needs work | Martin Sharkbomb
| | | UI / Extensions / Bound Tooltip / Tooltip Trigger | | Martin Sharkbomb
-**LineRenderer** | Graphic control for drawing lines in the UI System | UI / Extensions / UI Line Renderer | UI / Extensions / UI Line Renderer |[tutorial video](https://www.youtube.com/watch?v=OElcWAZGHi0)| jack.sydorenko
-**UILineTextureRenderer** | Graphic control for drawing lines in the UI System | UI / Extensions / UI Line Texture Renderer | UI / Extensions / UI Line Texture Renderer |[tutorial video](https://www.youtube.com/watch?v=OElcWAZGHi0)| jack.sydorenko, jonbro5556
+
+
+## Primatives ##
+================
+
+Control | Description | Menu Command | Component Command | Notes | Credits
+--------- | -------------- | ---------------------- | ---------------------------- | ------- | ----------
+**LineRenderer** | Graphic control for drawing lines in the UI System | UI / Extensions / Primatives / UI Line Renderer | UI / Extensions / Primatives / UI Line Renderer |[tutorial video](https://www.youtube.com/watch?v=OElcWAZGHi0)| jack.sydorenko
+**UILineTextureRenderer** | Graphic control for drawing lines in the UI System | UI / Extensions / Primatives / UI Line Texture Renderer | UI / Extensions / Primatives / UI Line Texture Renderer |[tutorial video](https://www.youtube.com/watch?v=OElcWAZGHi0)| jack.sydorenko, jonbro5556
+**UICircle** | Graphic control for drawing circles in the UI System | UI / Extensions / Primatives / UI Circle | UI / Extensions / Primatives / UI Circle || zge
+
+
+
+## Layouts ##
+================
+
+Layout | Description | Menu Command | Component Command | Notes | Credits
+--------- | -------------- | ---------------------- | ---------------------------- | ------- | ----------
+**HorizontalScrollSnap** | A pages scroll rect that can work in steps / pages, includes button support | Layout / Extensions / Horizontal Scroll Snap | Layout / Extensions / Horizontal Scroll Snap |[tutorial video](https://www.youtube.com/watch?v=KJlIlWHlfMo)| BinaryX
+**VerticalScrollSnap** | A pages scroll rect that can work in steps / pages, includes button support | Layout / Extensions / Vertical Scroll Snap | Layout / Extensions / Vertical Scroll Snap |[tutorial video](https://www.youtube.com/watch?v=KJlIlWHlfMo)| BinaryX, Simon Darkside Jackson
+**FlowLayoutGroup** | A more rugged grid style layout group || Layout / Extensions / Flow Layout Group | [Example Video](https://www.youtube.com/watch?v=tMe_3tJTZvc) | Simie
+**RadialLayout** | A radial layout system || Layout / Extensions / Radial Layout || Danny Goodayle
+**TileSizeFitter** | A fitter layout that will shink / expand content by tiles || Layout / Extensions / TileSizeFitter || Ges
+
+
## Effect components ##
=====================
@@ -62,6 +83,14 @@ Effect | Description | Component Command | Notes | Credits
**RaycastMask** | An example of an enhanced mask component able to work with the image data. Enables picking on image parts and not just the Rect Transform | UI / Effects / Extensions / Raycast Mask | | senritsu
**UIFlippable** | Image component effect to flip the graphic | UI / Effects / Extensions / UI Flippable | | ChoMPHi
+## VR Components##
+=======================
+
+Component | Description | Component Command | Notes | Credits
+--------- | -------------- | ---------------------------- | ------- | ------
+**VRCursor** | Cursor script for VR use (requires VRInputModule) | UI / Extensions / VR Cursoe | | Ralph Barbagallo
+**VRInputModule** | Input module to support the VR Cursor | Event / Vr Input Module | | Ralph Barbagallo
+
## Additional Components##
=======================
@@ -71,7 +100,6 @@ Component | Description | Component Command | Notes | Credits
**ReturnKeyTrigger** | Does something?? | UI / Extensions / ReturnKey Trigger | | Melang, ddreaper
**TabNavigation** | An example Tab navigation script, updated to add manual navigation | UI / Extensions / Tab Navigation | | Melang, omatase
**uGUITools** | | Menu / uGUI | | Senshi
-**FlowLayoutGroup** | A more rugged grid style layout group | Layout / Extensions / Flow Layout Group | [Example Video](https://www.youtube.com/watch?v=tMe_3tJTZvc) | Simie
**ScrollRectTweener** | Tweening solution for ScrollRects, add smoothing automatically | UI / Extensions / ScrollRectTweener | | Martin Sharkbomb
**ScrollRectLinker** | ScrollRect Linker script, enable multiple ScrollRects to move together | UI / Extensions / ScrollRectLinker | | Martin Sharkbomb
**ScrollRectEx** | Improved ScrollRect control, enables support for Nested ScrollRects | UI / Extensions / ScrollRectEx | | CaptainSchnittchen, GamesRUs
@@ -79,11 +107,13 @@ Component | Description | Component Command | Notes | Credits
**ImageExtended** | Improved Image control with rotation support and use of filled type without an Image (useful for masks) | UI / Extensions / Image Extended | | Ges
**UIScrollToSelection** | Enables a ScrollRect to scroll based on the selected child automatically | UI / Extensions / UIScrollToSelection | | zero3growlithe
**AimerInputModule** | Replacement Input module to allow for a reciclue to interace with WorldSpace canvas UI | UI / Extensions / Aimer Input Module | | Chris Trueman
-**UISeclectableExtension** | Refactor of original UI Button control, can now add Press/Release and Hold events to any Selectable control | UI / Extensions / UI Selectable Extension | | AriathTheWise / Simon Jackson
+**UISelectableExtension** | Refactor of original UI Button control, can now add Press/Release and Hold events to any Selectable control | UI / Extensions / UI Selectable Extension | | AriathTheWise / Simon Jackson
+**switchToRectTransform** | RectTransform extension method to move one Rect to another | N/A | | Izitmee
*More to come*
+=======================
### How do I get set up? ###
Either clone / download this repository to your machine and then copy the scripts in, or use the pre-packaged .UnityPackage for your version of Unity and import it as a custom package in to your project.
diff --git a/Scripts/Editor/UIExtensionsMenuOptions.cs b/Scripts/Editor/UIExtensionsMenuOptions.cs
index 03d4d70..3a23574 100644
--- a/Scripts/Editor/UIExtensionsMenuOptions.cs
+++ b/Scripts/Editor/UIExtensionsMenuOptions.cs
@@ -207,7 +207,7 @@ namespace UnityEditor.UI
#region UI Extensions "Create" Menu items
- [MenuItem("GameObject/UI/Extensions/Horizontal Scroll Snap", false)]
+ [MenuItem("GameObject/Layout/Extensions/Horizontal Scroll Snap", false)]
static public void AddHorizontalScrollSnap(MenuCommand menuCommand)
{
GameObject horizontalScrollSnapRoot = CreateUIElementRoot("Horizontal Scroll Snap", menuCommand, s_ThickGUIElementSize);
@@ -278,7 +278,7 @@ namespace UnityEditor.UI
Selection.activeGameObject = horizontalScrollSnapRoot;
}
- [MenuItem("GameObject/UI/Extensions/Vertical Scroll Snap", false)]
+ [MenuItem("GameObject/Layout/Extensions/Vertical Scroll Snap", false)]
static public void AddVerticallScrollSnap(MenuCommand menuCommand)
{
GameObject verticalScrollSnapRoot = CreateUIElementRoot("Vertical Scroll Snap", menuCommand, s_ThickGUIElementSize);
diff --git a/Scripts/InputFieldEnterSubmit.cs b/Scripts/InputFieldEnterSubmit.cs
index 56e9a55..36916e2 100644
--- a/Scripts/InputFieldEnterSubmit.cs
+++ b/Scripts/InputFieldEnterSubmit.cs
@@ -5,31 +5,29 @@ using UnityEngine.Events;
namespace UnityEngine.UI.Extensions
{
-///
-/// Usage: Add this component to the input and add the function to execute to the EnterSubmit event of this script
-///
-[RequireComponent(typeof(InputField))]
-[AddComponentMenu("UI/Extensions/Input Field Submit")]
-public class InputFieldEnterSubmit : MonoBehaviour
-{
-
- [System.Serializable]
- public class EnterSubmitEvent : UnityEvent { }
-
- public EnterSubmitEvent EnterSubmit;
- private InputField _input;
-
- void Awake()
+ ///
+ /// Usage: Add this component to the input and add the function to execute to the EnterSubmit event of this script
+ ///
+ [RequireComponent(typeof(InputField))]
+ [AddComponentMenu("UI/Extensions/Input Field Submit")]
+ public class InputFieldEnterSubmit : MonoBehaviour
{
- _input = GetComponent();
- _input.onEndEdit.AddListener(OnEndEdit);
- }
+ [System.Serializable]
+ public class EnterSubmitEvent : UnityEvent { }
- public void OnEndEdit(string txt)
- {
- if (!Input.GetKeyDown(KeyCode.Return) && !Input.GetKeyDown(KeyCode.KeypadEnter)) return;
- EnterSubmit.Invoke(txt);
- }
+ public EnterSubmitEvent EnterSubmit;
+ private InputField _input;
-}
+ void Awake()
+ {
+ _input = GetComponent();
+ _input.onEndEdit.AddListener(OnEndEdit);
+ }
+
+ public void OnEndEdit(string txt)
+ {
+ if (!Input.GetKeyDown(KeyCode.Return) && !Input.GetKeyDown(KeyCode.KeypadEnter)) return;
+ EnterSubmit.Invoke(txt);
+ }
+ }
}
diff --git a/Scripts/Layout/RadialLayout.cs b/Scripts/Layout/RadialLayout.cs
index 9982877..61e415e 100644
--- a/Scripts/Layout/RadialLayout.cs
+++ b/Scripts/Layout/RadialLayout.cs
@@ -1,5 +1,5 @@
-/// Credit ??
+/// Credit Danny Goodayle
/// Sourced from - http://www.justapixel.co.uk/radial-layouts-nice-and-simple-in-unity3ds-ui-system/
/// Updated by ddreaper - removed dependency on a custom ScrollRect script. Now implements drag interfaces and standard Scroll Rect.
@@ -25,57 +25,60 @@ THE SOFTWARE.
namespace UnityEngine.UI.Extensions
{
-[AddComponentMenu("Layout/Extensions/Radial Layout")]
-public class RadialLayout : LayoutGroup {
- public float fDistance;
- [Range(0f,360f)]
- public float MinAngle, MaxAngle, StartAngle;
- protected override void OnEnable() { base.OnEnable(); CalculateRadial(); }
- public override void SetLayoutHorizontal()
+ [AddComponentMenu("Layout/Extensions/Radial Layout")]
+ public class RadialLayout : LayoutGroup
{
- }
- public override void SetLayoutVertical()
- {
- }
- public override void CalculateLayoutInputVertical()
- {
- CalculateRadial();
- }
- public override void CalculateLayoutInputHorizontal()
- {
- CalculateRadial();
- }
- protected override void OnValidate()
- {
- base.OnValidate();
- CalculateRadial();
- }
- void CalculateRadial()
- {
- m_Tracker.Clear();
- if (transform.childCount == 0)
- return;
- float fOffsetAngle = ((MaxAngle - MinAngle)) / (transform.childCount -1);
-
- float fAngle = StartAngle;
- for (int i = 0; i < transform.childCount; i++)
+ public float fDistance;
+ [Range(0f, 360f)]
+ public float MinAngle, MaxAngle, StartAngle;
+ protected override void OnEnable() { base.OnEnable(); CalculateRadial(); }
+ public override void SetLayoutHorizontal()
{
- RectTransform child = (RectTransform)transform.GetChild(i);
- if (child != null)
- {
- //Adding the elements to the tracker stops the user from modifiying their positions via the editor.
- m_Tracker.Add(this, child,
- DrivenTransformProperties.Anchors |
- DrivenTransformProperties.AnchoredPosition |
- DrivenTransformProperties.Pivot);
- Vector3 vPos = new Vector3(Mathf.Cos(fAngle * Mathf.Deg2Rad), Mathf.Sin(fAngle * Mathf.Deg2Rad), 0);
- child.localPosition = vPos * fDistance;
- //Force objects to be center aligned, this can be changed however I'd suggest you keep all of the objects with the same anchor points.
- child.anchorMin = child.anchorMax = child.pivot = new Vector2(0.5f, 0.5f);
- fAngle += fOffsetAngle;
- }
}
+ public override void SetLayoutVertical()
+ {
+ }
+ public override void CalculateLayoutInputVertical()
+ {
+ CalculateRadial();
+ }
+ public override void CalculateLayoutInputHorizontal()
+ {
+ CalculateRadial();
+ }
+#if UNITY_EDITOR
+ protected override void OnValidate()
+ {
+ base.OnValidate();
+ CalculateRadial();
+ }
+#endif
+ void CalculateRadial()
+ {
+ m_Tracker.Clear();
+ if (transform.childCount == 0)
+ return;
+ float fOffsetAngle = ((MaxAngle - MinAngle)) / (transform.childCount - 1);
+ float fAngle = StartAngle;
+ for (int i = 0; i < transform.childCount; i++)
+ {
+ RectTransform child = (RectTransform)transform.GetChild(i);
+ if (child != null)
+ {
+ //Adding the elements to the tracker stops the user from modifiying their positions via the editor.
+ m_Tracker.Add(this, child,
+ DrivenTransformProperties.Anchors |
+ DrivenTransformProperties.AnchoredPosition |
+ DrivenTransformProperties.Pivot);
+ Vector3 vPos = new Vector3(Mathf.Cos(fAngle * Mathf.Deg2Rad), Mathf.Sin(fAngle * Mathf.Deg2Rad), 0);
+ child.localPosition = vPos * fDistance;
+ //Force objects to be center aligned, this can be changed however I'd suggest you keep all of the objects with the same anchor points.
+ child.anchorMin = child.anchorMax = child.pivot = new Vector2(0.5f, 0.5f);
+ fAngle += fOffsetAngle;
+ }
+ }
+
+ }
}
}
-}
diff --git a/Scripts/Layout/TileSizeFitter.cs b/Scripts/Layout/TileSizeFitter.cs
index ee8abfb..0d7f674 100644
--- a/Scripts/Layout/TileSizeFitter.cs
+++ b/Scripts/Layout/TileSizeFitter.cs
@@ -1,4 +1,4 @@
-/// Credit ??
+/// Credit Ges
/// Sourced from - http://forum.unity3d.com/threads/scripts-useful-4-6-scripts-collection.264161/page-3#post-2280109
using System.Collections;
@@ -6,99 +6,102 @@ using UnityEngine.EventSystems;
namespace UnityEngine.UI.Extensions
{
-[ExecuteInEditMode]
-[RequireComponent(typeof(RectTransform))]
-[AddComponentMenu("Layout/Extensions/Tile Size Fitter")]
-public class TileSizeFitter : UIBehaviour, ILayoutSelfController
-{
- [SerializeField] private Vector2 m_Border = Vector2.zero;
- public Vector2 Border { get { return m_Border; } set { if (SetPropertyUtility.SetStruct(ref m_Border, value)) SetDirty(); } }
-
- [SerializeField] private Vector2 m_TileSize = Vector2.zero;
- public Vector2 TileSize { get { return m_TileSize; } set { if (SetPropertyUtility.SetStruct(ref m_TileSize, value)) SetDirty(); } }
+ [ExecuteInEditMode]
+ [RequireComponent(typeof(RectTransform))]
+ [AddComponentMenu("Layout/Extensions/Tile Size Fitter")]
+ public class TileSizeFitter : UIBehaviour, ILayoutSelfController
+ {
+ [SerializeField]
+ private Vector2 m_Border = Vector2.zero;
+ public Vector2 Border { get { return m_Border; } set { if (SetPropertyUtility.SetStruct(ref m_Border, value)) SetDirty(); } }
- [System.NonSerialized] private RectTransform m_Rect;
- private RectTransform rectTransform { get { if (m_Rect == null) m_Rect = GetComponent(); return m_Rect; } }
+ [SerializeField]
+ private Vector2 m_TileSize = Vector2.zero;
+ public Vector2 TileSize { get { return m_TileSize; } set { if (SetPropertyUtility.SetStruct(ref m_TileSize, value)) SetDirty(); } }
- private DrivenRectTransformTracker m_Tracker;
+ [System.NonSerialized]
+ private RectTransform m_Rect;
+ private RectTransform rectTransform { get { if (m_Rect == null) m_Rect = GetComponent(); return m_Rect; } }
- #region Unity Lifetime calls
+ private DrivenRectTransformTracker m_Tracker;
- protected override void OnEnable()
- {
- base.OnEnable();
- SetDirty();
- }
+ #region Unity Lifetime calls
- protected override void OnDisable()
- {
- m_Tracker.Clear();
- LayoutRebuilder.MarkLayoutForRebuild(rectTransform);
- base.OnDisable();
- }
+ protected override void OnEnable()
+ {
+ base.OnEnable();
+ SetDirty();
+ }
- #endregion
+ protected override void OnDisable()
+ {
+ m_Tracker.Clear();
+ LayoutRebuilder.MarkLayoutForRebuild(rectTransform);
+ base.OnDisable();
+ }
- protected override void OnRectTransformDimensionsChange()
- {
- UpdateRect();
- }
+ #endregion
- private void UpdateRect()
- {
- if (!IsActive())
- return;
+ protected override void OnRectTransformDimensionsChange()
+ {
+ UpdateRect();
+ }
- m_Tracker.Clear();
+ private void UpdateRect()
+ {
+ if (!IsActive())
+ return;
- m_Tracker.Add(this, rectTransform,
- DrivenTransformProperties.Anchors |
- DrivenTransformProperties.AnchoredPosition);
- rectTransform.anchorMin = Vector2.zero;
- rectTransform.anchorMax = Vector2.one;
- rectTransform.anchoredPosition = Vector2.zero;
+ m_Tracker.Clear();
- m_Tracker.Add(this, rectTransform,
- DrivenTransformProperties.SizeDeltaX |
- DrivenTransformProperties.SizeDeltaY);
- Vector2 sizeDelta = GetParentSize() - Border;
- if (TileSize.x > 0.001f)
- sizeDelta.x -= Mathf.Floor(sizeDelta.x / TileSize.x) * TileSize.x;
- else
- sizeDelta.x = 0;
- if (TileSize.y > 0.001f)
- sizeDelta.y -= Mathf.Floor(sizeDelta.y / TileSize.y) * TileSize.y;
- else
- sizeDelta.y = 0;
- rectTransform.sizeDelta = -sizeDelta;
- }
+ m_Tracker.Add(this, rectTransform,
+ DrivenTransformProperties.Anchors |
+ DrivenTransformProperties.AnchoredPosition);
+ rectTransform.anchorMin = Vector2.zero;
+ rectTransform.anchorMax = Vector2.one;
+ rectTransform.anchoredPosition = Vector2.zero;
- private Vector2 GetParentSize()
- {
- RectTransform parent = rectTransform.parent as RectTransform;
- if (!parent)
- return Vector2.zero;
- return parent.rect.size;
- }
+ m_Tracker.Add(this, rectTransform,
+ DrivenTransformProperties.SizeDeltaX |
+ DrivenTransformProperties.SizeDeltaY);
+ Vector2 sizeDelta = GetParentSize() - Border;
+ if (TileSize.x > 0.001f)
+ sizeDelta.x -= Mathf.Floor(sizeDelta.x / TileSize.x) * TileSize.x;
+ else
+ sizeDelta.x = 0;
+ if (TileSize.y > 0.001f)
+ sizeDelta.y -= Mathf.Floor(sizeDelta.y / TileSize.y) * TileSize.y;
+ else
+ sizeDelta.y = 0;
+ rectTransform.sizeDelta = -sizeDelta;
+ }
- public virtual void SetLayoutHorizontal() { }
- public virtual void SetLayoutVertical() { }
+ private Vector2 GetParentSize()
+ {
+ RectTransform parent = rectTransform.parent as RectTransform;
+ if (!parent)
+ return Vector2.zero;
+ return parent.rect.size;
+ }
- protected void SetDirty()
- {
- if (!IsActive())
- return;
+ public virtual void SetLayoutHorizontal() { }
+ public virtual void SetLayoutVertical() { }
- UpdateRect();
- }
+ protected void SetDirty()
+ {
+ if (!IsActive())
+ return;
+
+ UpdateRect();
+ }
#if UNITY_EDITOR
- protected override void OnValidate()
- {
- m_TileSize.x = Mathf.Clamp(m_TileSize.x, 0.001f, 1000f);
- m_TileSize.y = Mathf.Clamp(m_TileSize.y, 0.001f, 1000f);
- SetDirty();
- }
+ protected override void OnValidate()
+ {
+ m_TileSize.x = Mathf.Clamp(m_TileSize.x, 0.001f, 1000f);
+ m_TileSize.y = Mathf.Clamp(m_TileSize.y, 0.001f, 1000f);
+ SetDirty();
+ }
#endif
-}
+ }
}
\ No newline at end of file
diff --git a/Scripts/Primatives/UICircle.cs b/Scripts/Primatives/UICircle.cs
index 3d745e5..8eb2b81 100644
--- a/Scripts/Primatives/UICircle.cs
+++ b/Scripts/Primatives/UICircle.cs
@@ -1,11 +1,11 @@
-/// Credit ??
+/// Credit zge
/// Sourced from - http://forum.unity3d.com/threads/draw-circles-or-primitives-on-the-new-ui-canvas.272488/#post-2293224
using System.Collections.Generic;
namespace UnityEngine.UI.Extensions
-{
- [AddComponentMenu("UI/Extensions/Primatives/UI Circle")]
+{
+ [AddComponentMenu("UI/Extensions/Primatives/UI Circle")]
public class UICircle : Graphic
{
[SerializeField]
@@ -16,7 +16,7 @@ namespace UnityEngine.UI.Extensions
public float thickness = 5;
[Range(0, 360)]
public int segments = 360;
-
+
public override Texture mainTexture
{
get
@@ -24,8 +24,7 @@ namespace UnityEngine.UI.Extensions
return m_Texture == null ? s_WhiteTexture : m_Texture;
}
}
-
-
+
///
/// Texture to be used.
///
@@ -39,13 +38,13 @@ namespace UnityEngine.UI.Extensions
{
if (m_Texture == value)
return;
-
+
m_Texture = value;
SetVerticesDirty();
SetMaterialDirty();
}
}
-
+
protected void SetVbo(List vbo, Vector2[] vertices, Vector2[] uvs)
{
for (int i = 0; i < vertices.Length; i++)
@@ -57,15 +56,14 @@ namespace UnityEngine.UI.Extensions
vbo.Add(vert);
}
}
-
-
+
protected override void OnFillVBO(List vbo)
{
float outer = -rectTransform.pivot.x * rectTransform.rect.width;
float inner = -rectTransform.pivot.x * rectTransform.rect.width + this.thickness;
-
+
vbo.Clear();
-
+
Vector2 prevX = Vector2.zero;
Vector2 prevY = Vector2.zero;
Vector2 uv0 = new Vector2(0, 0);
@@ -76,26 +74,26 @@ namespace UnityEngine.UI.Extensions
Vector2 pos1;
Vector2 pos2;
Vector2 pos3;
-
+
float f = (this.fillPercent / 100f);
float degrees = 360f / segments;
int fa = (int)((segments + 1) * f);
-
-
+
+
for (int i = 0; i < fa; i++)
{
float rad = Mathf.Deg2Rad * (i * degrees);
float c = Mathf.Cos(rad);
float s = Mathf.Sin(rad);
-
+
uv0 = new Vector2(0, 1);
uv1 = new Vector2(1, 1);
uv2 = new Vector2(1, 0);
uv3 = new Vector2(0, 0);
-
+
pos0 = prevX;
pos1 = new Vector2(outer * c, outer * s);
-
+
if (fill)
{
pos2 = Vector2.zero;
@@ -106,16 +104,12 @@ namespace UnityEngine.UI.Extensions
pos2 = new Vector2(inner * c, inner * s);
pos3 = prevY;
}
-
+
prevX = pos1;
prevY = pos2;
-
+
SetVbo(vbo, new[] { pos0, pos1, pos2, pos3 }, new[] { uv0, uv1, uv2, uv3 });
-
}
-
}
-
-
}
}
\ No newline at end of file
diff --git a/Scripts/Utilities/switchToRectTransform.cs b/Scripts/Utilities/switchToRectTransform.cs
index fa72367..f8e52f2 100644
--- a/Scripts/Utilities/switchToRectTransform.cs
+++ b/Scripts/Utilities/switchToRectTransform.cs
@@ -1,24 +1,24 @@
-/// Credit ??
+/// Credit Izitmee
/// Sourced from - http://forum.unity3d.com/threads/find-anchoredposition-of-a-recttransform-relative-to-another-recttransform.330560/#post-2300992
+/// Updated by Brave Michael - http://forum.unity3d.com/threads/find-anchoredposition-of-a-recttransform-relative-to-another-recttransform.330560/#post-2300992
namespace UnityEngine.UI.Extensions
{
-
- public static class RectTransformExtension
- {
-///
-/// Converts the anchoredPosition of the first RectTransform to the second RectTransform,
-/// taking into consideration offset, anchors and pivot, and returns the new anchoredPosition
-///
-public static Vector2 switchToRectTransform(this RectTransform from, RectTransform to)
- {
- Vector2 localPoint;
- Vector2 fromPivotDerivedOffset = new Vector2(from.rect.width * from.pivot.x + from.rect.xMin, from.rect.height * from.pivot.y + from.rect.yMin);
- Vector2 screenP = RectTransformUtility.WorldToScreenPoint(null, from.position);
- screenP += fromPivotDerivedOffset;
- RectTransformUtility.ScreenPointToLocalPointInRectangle(to, screenP, null, out localPoint);
- Vector2 pivotDerivedOffset = new Vector2(to.rect.width * to.pivot.x + to.rect.xMin, to.rect.height * to.pivot.y + to.rect.yMin);
- return to.anchoredPosition + localPoint - pivotDerivedOffset;
- }
- }
+ public static class RectTransformExtension
+ {
+ ///
+ /// Converts the anchoredPosition of the first RectTransform to the second RectTransform,
+ /// taking into consideration offset, anchors and pivot, and returns the new anchoredPosition
+ ///
+ public static Vector2 switchToRectTransform(this RectTransform from, RectTransform to)
+ {
+ Vector2 localPoint;
+ Vector2 fromPivotDerivedOffset = new Vector2(from.rect.width * from.pivot.x + from.rect.xMin, from.rect.height * from.pivot.y + from.rect.yMin);
+ Vector2 screenP = RectTransformUtility.WorldToScreenPoint(null, from.position);
+ screenP += fromPivotDerivedOffset;
+ RectTransformUtility.ScreenPointToLocalPointInRectangle(to, screenP, null, out localPoint);
+ Vector2 pivotDerivedOffset = new Vector2(to.rect.width * to.pivot.x + to.rect.xMin, to.rect.height * to.pivot.y + to.rect.yMin);
+ return to.anchoredPosition + localPoint - pivotDerivedOffset;
+ }
+ }
}
\ No newline at end of file
diff --git a/Scripts/VR Extensions.meta b/Scripts/VR Extensions.meta
new file mode 100644
index 0000000..93f163f
--- /dev/null
+++ b/Scripts/VR Extensions.meta
@@ -0,0 +1,5 @@
+fileFormatVersion: 2
+guid: c84a253080bc0ec4995041aa5a6656ae
+folderAsset: yes
+DefaultImporter:
+ userData:
diff --git a/Scripts/VR Extensions/VRCursor.cs b/Scripts/VR Extensions/VRCursor.cs
new file mode 100644
index 0000000..c563deb
--- /dev/null
+++ b/Scripts/VR Extensions/VRCursor.cs
@@ -0,0 +1,49 @@
+/// Credit Ralph Barbagallo (www.flarb.com /www.ralphbarbagallo.com / @flarb)
+/// Sourced from - http://forum.unity3d.com/threads/vr-cursor-possible-unity-4-6-gui-bug-or-is-it-me
+
+using System.Collections;
+namespace UnityEngine.UI.Extensions
+{
+ [AddComponentMenu("UI/Extensions/VR Cursor")]
+ public class VRCursor : MonoBehaviour
+ {
+ public float xSens;
+ public float ySens;
+
+ private Collider currentCollider;
+
+ // Update is called once per frame
+ void Update()
+ {
+ Vector3 thisPosition;
+
+ thisPosition.x = Input.mousePosition.x * xSens;
+ thisPosition.y = Input.mousePosition.y * ySens - 1;
+ thisPosition.z = transform.position.z;
+
+ transform.position = thisPosition;
+
+ VRInputModule.cursorPosition = transform.position;
+
+ if (Input.GetMouseButtonDown(0) && currentCollider)
+ {
+ VRInputModule.PointerSubmit(currentCollider.gameObject);
+ }
+
+ }
+
+ void OnTriggerEnter(Collider other)
+ {
+ //print("OnTriggerEnter other " + other.gameObject);
+ VRInputModule.PointerEnter(other.gameObject);
+ currentCollider = other;
+ }
+
+ void OnTriggerExit(Collider other)
+ {
+ //print("OnTriggerExit other " + other.gameObject);
+ VRInputModule.PointerExit(other.gameObject);
+ currentCollider = null;
+ }
+ }
+}
\ No newline at end of file
diff --git a/Scripts/VR Extensions/VRCursor.cs.meta b/Scripts/VR Extensions/VRCursor.cs.meta
new file mode 100644
index 0000000..f4fa883
--- /dev/null
+++ b/Scripts/VR Extensions/VRCursor.cs.meta
@@ -0,0 +1,8 @@
+fileFormatVersion: 2
+guid: 3d7a94ee2faf9f04696882b3a2cbf035
+MonoImporter:
+ serializedVersion: 2
+ defaultReferences: []
+ executionOrder: 0
+ icon: {instanceID: 0}
+ userData:
diff --git a/Scripts/VR Extensions/VRInputModule.cs b/Scripts/VR Extensions/VRInputModule.cs
new file mode 100644
index 0000000..b78de0c
--- /dev/null
+++ b/Scripts/VR Extensions/VRInputModule.cs
@@ -0,0 +1,67 @@
+/// Credit Ralph Barbagallo (www.flarb.com /www.ralphbarbagallo.com / @flarb)
+/// Sourced from - http://forum.unity3d.com/threads/vr-cursor-possible-unity-4-6-gui-bug-or-is-it-me
+/// Fix supplied by - http://forum.unity3d.com/threads/vr-cursor-possible-unity-4-6-gui-bug-or-is-it-me.296934/
+
+using UnityEngine.EventSystems;
+namespace UnityEngine.UI.Extensions
+{
+ [AddComponentMenu("Event/VR Input Module")]
+ public class VRInputModule : BaseInputModule
+ {
+ public static GameObject targetObject;
+
+ static VRInputModule _singleton;
+
+ private int counter;
+
+ private static bool mouseClicked;
+ public static Vector3 cursorPosition;
+
+ protected override void Awake()
+ {
+ _singleton = this;
+ }
+
+ public override void Process()
+ {
+ if (targetObject == null)
+ {
+ mouseClicked = false;
+ return;
+ }
+ }
+
+ public static void PointerSubmit(GameObject obj)
+ {
+ targetObject = obj;
+ mouseClicked = true;
+ if (mouseClicked)
+ {
+ //BaseEventData data = GetBaseEventData(); //Original from Process(). Can't be called here so is replaced by the next line:
+ BaseEventData data = new BaseEventData(_singleton.eventSystem);
+ data.selectedObject = targetObject;
+ ExecuteEvents.Execute(targetObject, data, ExecuteEvents.submitHandler);
+ print("clicked " + targetObject.name);
+ mouseClicked = false;
+ }
+ }
+
+ public static void PointerExit(GameObject obj)
+ {
+ print("PointerExit " + obj.name);
+ PointerEventData pEvent = new PointerEventData(_singleton.eventSystem);
+ ExecuteEvents.Execute(obj, pEvent, ExecuteEvents.pointerExitHandler);
+ ExecuteEvents.Execute(obj, pEvent, ExecuteEvents.deselectHandler); //This fixes the problem
+ }
+
+ public static void PointerEnter(GameObject obj)
+ {
+ print("PointerEnter " + obj.name);
+ PointerEventData pEvent = new PointerEventData(_singleton.eventSystem);
+ pEvent.pointerEnter = obj;
+ RaycastResult rcr = new RaycastResult() { worldPosition = cursorPosition };
+ pEvent.pointerCurrentRaycast = rcr;
+ ExecuteEvents.Execute(obj, pEvent, ExecuteEvents.pointerEnterHandler);
+ }
+ }
+}
\ No newline at end of file
diff --git a/Scripts/VR Extensions/VRInputModule.cs.meta b/Scripts/VR Extensions/VRInputModule.cs.meta
new file mode 100644
index 0000000..42650a1
--- /dev/null
+++ b/Scripts/VR Extensions/VRInputModule.cs.meta
@@ -0,0 +1,8 @@
+fileFormatVersion: 2
+guid: 303ab8dad3437bf46814373cfb86cc5d
+MonoImporter:
+ serializedVersion: 2
+ defaultReferences: []
+ executionOrder: 0
+ icon: {instanceID: 0}
+ userData:
diff --git a/package.json b/package.json
index 229fcd4..b4cdd10 100644
--- a/package.json
+++ b/package.json
@@ -19,5 +19,5 @@
"example",
"browsenpm"
],
- "license": "MIT"
+ "license": "BSD"
}
\ No newline at end of file