summaryrefslogtreecommitdiff
path: root/Library/PackageCache/com.unity.timeline@1.2.13/Editor/Manipulators/TimeAreaAutoPanner.cs
diff options
context:
space:
mode:
authorAndrew Lee <alee14498@protonmail.com>2020-04-19 17:19:32 -0400
committerAndrew Lee <alee14498@protonmail.com>2020-04-19 17:19:32 -0400
commitc55fba8ab2a1c9d3df65eda4a5a1e957f4aa1f78 (patch)
treeee4d51c7c1d633e11f46453ef1edd3c77c4ef9f7 /Library/PackageCache/com.unity.timeline@1.2.13/Editor/Manipulators/TimeAreaAutoPanner.cs
downloadProject-Sandbox-c55fba8ab2a1c9d3df65eda4a5a1e957f4aa1f78.tar.gz
Project-Sandbox-c55fba8ab2a1c9d3df65eda4a5a1e957f4aa1f78.tar.bz2
Project-Sandbox-c55fba8ab2a1c9d3df65eda4a5a1e957f4aa1f78.zip
Inital commit
Diffstat (limited to 'Library/PackageCache/com.unity.timeline@1.2.13/Editor/Manipulators/TimeAreaAutoPanner.cs')
-rw-r--r--Library/PackageCache/com.unity.timeline@1.2.13/Editor/Manipulators/TimeAreaAutoPanner.cs72
1 files changed, 72 insertions, 0 deletions
diff --git a/Library/PackageCache/com.unity.timeline@1.2.13/Editor/Manipulators/TimeAreaAutoPanner.cs b/Library/PackageCache/com.unity.timeline@1.2.13/Editor/Manipulators/TimeAreaAutoPanner.cs
new file mode 100644
index 0000000..8052d65
--- /dev/null
+++ b/Library/PackageCache/com.unity.timeline@1.2.13/Editor/Manipulators/TimeAreaAutoPanner.cs
@@ -0,0 +1,72 @@
+using UnityEngine;
+
+namespace UnityEditor.Timeline
+{
+ class TimeAreaAutoPanner
+ {
+ readonly WindowState m_State;
+ readonly TimelineWindow m_Window;
+ readonly Rect m_ViewRect;
+
+ const float k_PixelDistanceToMaxSpeed = 100.0f;
+ const float k_MaxPanSpeed = 30.0f;
+
+ public TimeAreaAutoPanner(WindowState state)
+ {
+ m_State = state;
+ m_Window = m_State.GetWindow();
+
+ var shownRange = m_State.timeAreaShownRange;
+ var trackViewBounds = m_Window.sequenceRect;
+ m_ViewRect = Rect.MinMaxRect(m_State.TimeToPixel(shownRange.x), trackViewBounds.yMin,
+ m_State.TimeToPixel(shownRange.y), trackViewBounds.yMax);
+ }
+
+ public void OnGUI(Event evt)
+ {
+ if (evt.type != EventType.Layout)
+ return;
+
+ var hFactor = 0.0f;
+ var vFactor = 0.0f;
+
+ bool horizontalPan = GetPanFactor(evt.mousePosition.x, m_ViewRect.xMin, m_ViewRect.xMax, out hFactor);
+ bool verticalPan = GetPanFactor(evt.mousePosition.y, m_ViewRect.yMin, m_ViewRect.yMax, out vFactor);
+
+ if (horizontalPan)
+ {
+ var translation = m_State.timeAreaTranslation;
+ translation.x += hFactor * k_MaxPanSpeed;
+
+ m_State.SetTimeAreaTransform(translation, m_State.timeAreaScale);
+ }
+
+ if (verticalPan)
+ {
+ var translation = m_Window.treeView.scrollPosition;
+ translation.y -= vFactor * k_MaxPanSpeed;
+
+ m_Window.treeView.scrollPosition = translation;
+ }
+ }
+
+ static bool GetPanFactor(float v, float min, float max, out float factor)
+ {
+ factor = 0.0f;
+
+ if (v < min)
+ {
+ factor = Mathf.Clamp01((min - v) / k_PixelDistanceToMaxSpeed);
+ return true;
+ }
+
+ if (v > max)
+ {
+ factor = -Mathf.Clamp01((v - max) / k_PixelDistanceToMaxSpeed);
+ return true;
+ }
+
+ return false;
+ }
+ }
+}