diff --git a/Runtime/Scripts/Controls/ComboBox/DropDownList.cs b/Runtime/Scripts/Controls/ComboBox/DropDownList.cs
index 7de1b07..00ff714 100644
--- a/Runtime/Scripts/Controls/ComboBox/DropDownList.cs
+++ b/Runtime/Scripts/Controls/ComboBox/DropDownList.cs
@@ -5,25 +5,25 @@ using System.Collections.Generic;
namespace UnityEngine.UI.Extensions
{
- ///
- /// Extension to the UI class which creates a dropdown list
- ///
- [RequireComponent(typeof(RectTransform))]
+ ///
+ /// Extension to the UI class which creates a dropdown list
+ ///
+ [RequireComponent(typeof(RectTransform))]
[AddComponentMenu("UI/Extensions/ComboBox/Dropdown List")]
public class DropDownList : MonoBehaviour
{
public Color disabledTextColor;
public DropDownListItem SelectedItem { get; private set; } //outside world gets to get this, not set it
- [Header("Dropdown List Items")]
- public List Items;
+ [Header("Dropdown List Items")]
+ public List Items;
- [Header("Properties")]
+ [Header("Properties")]
- [SerializeField]
- private bool isActive = true;
+ [SerializeField]
+ private bool isActive = true;
- public bool OverrideHighlighted = true;
+ public bool OverrideHighlighted = true;
//private bool isInitialized = false;
private bool _isPanelActive = false;
@@ -46,10 +46,13 @@ namespace UnityEngine.UI.Extensions
private List _panelItems = new List();
- private GameObject _itemTemplate;
+ private GameObject _itemTemplate;
private bool _initialized;
- [SerializeField]
+ private string _defaultMainButtonCaption = null;
+ private Color _defaultNormalColor;
+
+ [SerializeField]
private float _scrollBarWidth = 20.0f;
public float ScrollBarWidth
{
@@ -61,7 +64,6 @@ namespace UnityEngine.UI.Extensions
}
}
- // private int scrollOffset; //offset of the selected item
private int _selectedIndex = -1;
[SerializeField]
@@ -76,42 +78,42 @@ namespace UnityEngine.UI.Extensions
}
}
- [SerializeField]
- private float dropdownOffset;
+ [SerializeField]
+ private float dropdownOffset;
- [SerializeField]
- private bool _displayPanelAbove = false;
+ [SerializeField]
+ private bool _displayPanelAbove = false;
- public bool SelectFirstItemOnStart = false;
+ public bool SelectFirstItemOnStart = false;
- [SerializeField]
- private int selectItemIndexOnStart = 0;
- private bool shouldSelectItemOnStart => SelectFirstItemOnStart || selectItemIndexOnStart > 0;
+ [SerializeField]
+ private int selectItemIndexOnStart = 0;
+ private bool shouldSelectItemOnStart => SelectFirstItemOnStart || selectItemIndexOnStart > 0;
- [System.Serializable]
+ [System.Serializable]
public class SelectionChangedEvent : Events.UnityEvent { }
- // fires when item is changed;
- [Header("Events")]
- public SelectionChangedEvent OnSelectionChanged;
+ // fires when item is changed;
+ [Header("Events")]
+ public SelectionChangedEvent OnSelectionChanged;
- [System.Serializable]
- public class ControlDisabledEvent : Events.UnityEvent { }
+ [System.Serializable]
+ public class ControlDisabledEvent : Events.UnityEvent { }
- // fires when item is changed;
- public ControlDisabledEvent OnControlDisabled;
+ // fires when item changes between enabled and disabled;
+ public ControlDisabledEvent OnControlDisabled;
- public void Start()
- {
- Initialize();
- if (shouldSelectItemOnStart && Items.Count > 0)
- {
- SelectItemIndex(SelectFirstItemOnStart ? 0 : selectItemIndexOnStart);
- }
- RedrawPanel();
- }
+ public void Start()
+ {
+ Initialize();
+ if (shouldSelectItemOnStart && Items.Count > 0)
+ {
+ SelectItemIndex(SelectFirstItemOnStart ? 0 : selectItemIndexOnStart);
+ }
+ RedrawPanel();
+ }
- private bool Initialize()
+ private bool Initialize()
{
if (_initialized) return true;
@@ -121,6 +123,9 @@ namespace UnityEngine.UI.Extensions
_rectTransform = GetComponent();
_mainButton = new DropDownListButton(_rectTransform.Find("MainButton").gameObject);
+ _defaultMainButtonCaption = _mainButton.txt.text;
+ _defaultNormalColor = _mainButton.btn.colors.normalColor;
+
_overlayRT = _rectTransform.Find("Overlay").GetComponent();
_overlayRT.gameObject.SetActive(false);
_scrollPanelRT = _overlayRT.Find("ScrollPanel").GetComponent();
@@ -147,32 +152,32 @@ namespace UnityEngine.UI.Extensions
Debug.LogError("Something is setup incorrectly with the dropdownlist component causing a Null Reference Exception");
success = false;
}
- _initialized = true;
+ _initialized = true;
- RebuildPanel();
+ RebuildPanel();
RedrawPanel();
return success;
}
- ///
+ ///
/// Update the drop down selection to a specific index
///
///
public void SelectItemIndex(int index)
- {
- ToggleDropdownPanel(false);
- OnItemClicked(index);
- }
+ {
+ ToggleDropdownPanel(false);
+ OnItemClicked(index);
+ }
- // currently just using items in the list instead of being able to add to it.
- ///
- /// Rebuilds the list from a new collection.
- ///
- ///
- /// NOTE, this will clear all existing items
- ///
- ///
- public void RefreshItems(params object[] list)
+ // currently just using items in the list instead of being able to add to it.
+ ///
+ /// Rebuilds the list from a new collection.
+ ///
+ ///
+ /// NOTE, this will clear all existing items
+ ///
+ ///
+ public void RefreshItems(params object[] list)
{
Items.Clear();
List ddItems = new List();
@@ -197,76 +202,94 @@ namespace UnityEngine.UI.Extensions
}
Items.AddRange(ddItems);
RebuildPanel();
- RedrawPanel();
- }
+ RedrawPanel();
+ }
- ///
- /// Adds an additional item to the drop down list (recommended)
- ///
- /// Item of type DropDownListItem
- public void AddItem(DropDownListItem item)
- {
+ ///
+ /// Adds an additional item to the drop down list (recommended)
+ ///
+ /// Item of type DropDownListItem
+ public void AddItem(DropDownListItem item)
+ {
Items.Add(item);
RebuildPanel();
RedrawPanel();
- }
+ }
- ///
- /// Adds an additional drop down list item using a string name
- ///
- /// Item of type String
- public void AddItem(string item)
+ ///
+ /// Adds an additional drop down list item using a string name
+ ///
+ /// Item of type String
+ public void AddItem(string item)
{
Items.Add(new DropDownListItem(caption: (string)item));
RebuildPanel();
- RedrawPanel();
- }
+ RedrawPanel();
+ }
- ///
- /// Adds an additional drop down list item using a sprite image
- ///
- /// Item of type UI Sprite
- public void AddItem(Sprite item)
+ ///
+ /// Adds an additional drop down list item using a sprite image
+ ///
+ /// Item of type UI Sprite
+ public void AddItem(Sprite item)
{
Items.Add(new DropDownListItem(image: (Sprite)item));
RebuildPanel();
- RedrawPanel();
- }
+ RedrawPanel();
+ }
- ///
- /// Removes an item from the drop down list (recommended)
- ///
- /// Item of type DropDownListItem
- public void RemoveItem(DropDownListItem item)
+ ///
+ /// Removes an item from the drop down list (recommended)
+ ///
+ /// Item of type DropDownListItem
+ public void RemoveItem(DropDownListItem item)
{
Items.Remove(item);
RebuildPanel();
- RedrawPanel();
- }
+ RedrawPanel();
+ }
- ///
- /// Removes an item from the drop down list item using a string name
- ///
- /// Item of type String
- public void RemoveItem(string item)
+ ///
+ /// Removes an item from the drop down list item using a string name
+ ///
+ /// Item of type String
+ public void RemoveItem(string item)
{
Items.Remove(new DropDownListItem(caption: (string)item));
RebuildPanel();
- RedrawPanel();
- }
+ RedrawPanel();
+ }
- ///
- /// Removes an item from the drop down list item using a sprite image
- ///
- /// Item of type UI Sprite
- public void RemoveItem(Sprite item)
+ ///
+ /// Removes an item from the drop down list item using a sprite image
+ ///
+ /// Item of type UI Sprite
+ public void RemoveItem(Sprite item)
{
Items.Remove(new DropDownListItem(image: (Sprite)item));
RebuildPanel();
- RedrawPanel();
- }
+ RedrawPanel();
+ }
- public void ResetItems()
+ public void ResetDropDown()
+ {
+ if (!_initialized)
+ {
+ return;
+ }
+
+ _mainButton.txt.text = _defaultMainButtonCaption;
+ for (int i = 0; i < _itemsPanelRT.childCount; i++)
+ {
+ _panelItems[i].btnImg.color = _defaultNormalColor;
+ }
+
+ _selectedIndex = -1;
+ _initialized = false;
+ Initialize();
+ }
+
+ public void ResetItems()
{
Items.Clear();
RebuildPanel();
@@ -304,7 +327,7 @@ namespace UnityEngine.UI.Extensions
_panelItems[i].txt.text = item.Caption;
if (item.IsDisabled) _panelItems[i].txt.color = disabledTextColor;
- if (_panelItems[i].btnImg != null) _panelItems[i].btnImg.sprite = null;//hide the button image
+ if (_panelItems[i].btnImg != null) _panelItems[i].btnImg.sprite = null;//hide the button image
_panelItems[i].img.sprite = item.Image;
_panelItems[i].img.color = (item.Image == null) ? new Color(1, 1, 1, 0)
: item.IsDisabled ? new Color(1, 1, 1, .5f)
@@ -349,25 +372,25 @@ namespace UnityEngine.UI.Extensions
_mainButton.txt.text = SelectedItem.Caption;
- //update selected index color
- if (OverrideHighlighted)
- {
- for (int i = 0; i < _itemsPanelRT.childCount; i++)
- {
- _panelItems[i].btnImg.color = (_selectedIndex == i) ? _mainButton.btn.colors.highlightedColor : new Color(0, 0, 0, 0);
- }
- }
- }
+ //update selected index color
+ if (OverrideHighlighted)
+ {
+ for (int i = 0; i < _itemsPanelRT.childCount; i++)
+ {
+ _panelItems[i].btnImg.color = (_selectedIndex == i) ? _mainButton.btn.colors.highlightedColor : new Color(0, 0, 0, 0);
+ }
+ }
+ }
private void RedrawPanel()
{
float scrollbarWidth = _panelItems.Count > ItemsToDisplay ? _scrollBarWidth : 0f;//hide the scrollbar if there's not enough items
_scrollBarRT.gameObject.SetActive(_panelItems.Count > ItemsToDisplay);
- float dropdownHeight = _itemsToDisplay > 0 ? _rectTransform.sizeDelta.y * Mathf.Min(_itemsToDisplay, _panelItems.Count) : _rectTransform.sizeDelta.y * _panelItems.Count;
- dropdownHeight += dropdownOffset;
+ float dropdownHeight = _itemsToDisplay > 0 ? _rectTransform.sizeDelta.y * Mathf.Min(_itemsToDisplay, _panelItems.Count) : _rectTransform.sizeDelta.y * _panelItems.Count;
+ dropdownHeight += dropdownOffset;
- if (!_hasDrawnOnce || _rectTransform.sizeDelta != _mainButton.rectTransform.sizeDelta)
+ if (!_hasDrawnOnce || _rectTransform.sizeDelta != _mainButton.rectTransform.sizeDelta)
{
_hasDrawnOnce = true;
_mainButton.rectTransform.SetSizeWithCurrentAnchors(RectTransform.Axis.Horizontal, _rectTransform.sizeDelta.x);
@@ -377,12 +400,12 @@ namespace UnityEngine.UI.Extensions
itemsRemaining = itemsRemaining < 0 ? 0 : itemsRemaining;
_scrollPanelRT.SetParent(transform, true);
- _scrollPanelRT.anchoredPosition = _displayPanelAbove ?
- new Vector2(0, dropdownOffset + dropdownHeight) :
- new Vector2(0, -(dropdownOffset + _rectTransform.sizeDelta.y));
+ _scrollPanelRT.anchoredPosition = _displayPanelAbove ?
+ new Vector2(0, dropdownOffset + dropdownHeight) :
+ new Vector2(0, -(dropdownOffset + _rectTransform.sizeDelta.y));
- //make the overlay fill the screen
- _overlayRT.SetParent(_canvas.transform, false);
+ //make the overlay fill the screen
+ _overlayRT.SetParent(_canvas.transform, false);
_overlayRT.SetSizeWithCurrentAnchors(RectTransform.Axis.Horizontal, _canvasRT.sizeDelta.x);
_overlayRT.SetSizeWithCurrentAnchors(RectTransform.Axis.Vertical, _canvasRT.sizeDelta.y);
@@ -392,7 +415,7 @@ namespace UnityEngine.UI.Extensions
if (_panelItems.Count < 1) return;
- _scrollPanelRT.SetSizeWithCurrentAnchors(RectTransform.Axis.Vertical, dropdownHeight);
+ _scrollPanelRT.SetSizeWithCurrentAnchors(RectTransform.Axis.Vertical, dropdownHeight);
_scrollPanelRT.SetSizeWithCurrentAnchors(RectTransform.Axis.Horizontal, _rectTransform.sizeDelta.x);
_itemsPanelRT.SetSizeWithCurrentAnchors(RectTransform.Axis.Horizontal, _scrollPanelRT.sizeDelta.x - scrollbarWidth - 5);
@@ -407,38 +430,63 @@ namespace UnityEngine.UI.Extensions
}
///
- /// Toggle the drop down list
+ /// Toggle the drop down list if it is active
///
- /// whether an item was directly clicked on
- public void ToggleDropdownPanel(bool directClick)
+ /// Retained for backwards compatibility only.
+ [Obsolete("DirectClick Parameter is no longer required")]
+ public void ToggleDropdownPanel(bool directClick = false)
{
- if (!isActive) return;
-
+ ToggleDropdownPanel();
+ }
+
+ ///
+ /// Toggle the drop down list if it is active
+ ///
+ public void ToggleDropdownPanel()
+ {
+ if (!isActive)
+ {
+ return;
+ }
+
_overlayRT.transform.localScale = new Vector3(1, 1, 1);
_scrollBarRT.transform.localScale = new Vector3(1, 1, 1);
_isPanelActive = !_isPanelActive;
_overlayRT.gameObject.SetActive(_isPanelActive);
+
if (_isPanelActive)
{
transform.SetAsLastSibling();
}
- else if (directClick)
- {
- // scrollOffset = Mathf.RoundToInt(itemsPanelRT.anchoredPosition.y / _rectTransform.sizeDelta.y);
- }
}
- ///
- /// Updates the control and sets its active status, determines whether the dropdown will open ot not
- ///
- ///
- public void SetActive(bool status)
- {
- if (status != isActive)
- {
- OnControlDisabled?.Invoke(status);
- }
- isActive = status;
- }
- }
+ ///
+ /// Hides the drop down panel if its visible at the moment
+ ///
+ public void HideDropDownPanel()
+ {
+ if (!_isPanelActive)
+ {
+ return;
+ }
+
+ ToggleDropdownPanel(false);
+ }
+
+ ///
+ /// Updates the control and sets its active status, determines whether the dropdown will open ot not
+ /// and takes care of the underlying button to follow the status.
+ ///
+ ///
+ public void SetActive(bool status)
+ {
+ if (status == isActive)
+ {
+ return;
+ }
+ isActive = status;
+ OnControlDisabled?.Invoke(isActive);
+ _mainButton.btn.enabled = isActive;
+ }
+ }
}
\ No newline at end of file
diff --git a/Runtime/Scripts/Effects/UIParticleSystem.cs b/Runtime/Scripts/Effects/UIParticleSystem.cs
index 4083b02..a004b7b 100644
--- a/Runtime/Scripts/Effects/UIParticleSystem.cs
+++ b/Runtime/Scripts/Effects/UIParticleSystem.cs
@@ -16,6 +16,9 @@ namespace UnityEngine.UI.Extensions
[Tooltip("Enables 3d rotation for the particles")]
public bool use3dRotation = false;
+ [Tooltip("Enables using Renderer.lengthScale parameter")]
+ public bool _useLengthScale = false;
+
private Transform _transform;
private ParticleSystem pSystem;
private ParticleSystem.Particle[] particles;
@@ -91,7 +94,7 @@ namespace UnityEngine.UI.Extensions
pRenderer = pSystem.GetComponent();
if (pRenderer != null)
pRenderer.enabled = false;
-
+
if (material == null)
{
var foundShader = ShaderLibrary.GetShaderInstance("UI Extensions/Particles/Additive");
@@ -183,8 +186,6 @@ namespace UnityEngine.UI.Extensions
#else
Vector2 position = (pSystem.simulationSpace == ParticleSystemSimulationSpace.Local ? particle.position : _transform.InverseTransformPoint(particle.position));
#endif
- float rotation = -particle.rotation * Mathf.Deg2Rad;
- float rotation90 = rotation + Mathf.PI / 2;
Color32 color = particle.GetCurrentColor(pSystem);
float size = particle.GetCurrentSize(pSystem) * 0.5f;
@@ -280,13 +281,29 @@ namespace UnityEngine.UI.Extensions
_quad[3].color = color;
_quad[3].uv0 = temp;
+
+ float rotation = -particle.rotation * Mathf.Deg2Rad;
+ var lengthScale = pRenderer.lengthScale;
+ if (_useLengthScale)
+ {
+ // rotate towards velocity
+ var normalizedVelocity = particle.velocity.normalized;
+ rotation = Mathf.Atan2(normalizedVelocity.y, normalizedVelocity.x);
+ }
+ else
+ {
+ lengthScale = 1f;
+ }
+
+ float rotation90 = rotation + Mathf.PI / 2;
+
if (rotation == 0)
{
// no rotation
corner1.x = position.x - size;
- corner1.y = position.y - size;
+ corner1.y = position.y - size * lengthScale;
corner2.x = position.x + size;
- corner2.y = position.y + size;
+ corner2.y = position.y + size * lengthScale;
temp.x = corner1.x;
temp.y = corner1.y;
@@ -339,7 +356,7 @@ namespace UnityEngine.UI.Extensions
else
{
// apply rotation
- Vector2 right = new Vector2(Mathf.Cos(rotation), Mathf.Sin(rotation)) * size;
+ Vector2 right = new Vector2(Mathf.Cos(rotation), Mathf.Sin(rotation)) * size * lengthScale;
Vector2 up = new Vector2(Mathf.Cos(rotation90), Mathf.Sin(rotation90)) * size;
_quad[0].position = position - right - up;
diff --git a/Runtime/Scripts/Primitives/UILineRenderer.cs b/Runtime/Scripts/Primitives/UILineRenderer.cs
index d3b5d3d..3e50eb8 100644
--- a/Runtime/Scripts/Primitives/UILineRenderer.cs
+++ b/Runtime/Scripts/Primitives/UILineRenderer.cs
@@ -287,7 +287,7 @@ namespace UnityEngine.UI.Extensions
PopulateMesh (vh, m_points);
}
- else if (m_segments != null && m_segments.Count > 0) {
+ if (m_segments != null && m_segments.Count > 0) {
GeneratedUVs ();
vh.Clear ();
@@ -480,4 +480,4 @@ namespace UnityEngine.UI.Extensions
}
}
}
-}
\ No newline at end of file
+}