summaryrefslogtreecommitdiff
path: root/Library/PackageCache/com.unity.timeline@1.2.13/Editor/Window/PlaybackScroller.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/Window/PlaybackScroller.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/Window/PlaybackScroller.cs')
-rw-r--r--Library/PackageCache/com.unity.timeline@1.2.13/Editor/Window/PlaybackScroller.cs54
1 files changed, 54 insertions, 0 deletions
diff --git a/Library/PackageCache/com.unity.timeline@1.2.13/Editor/Window/PlaybackScroller.cs b/Library/PackageCache/com.unity.timeline@1.2.13/Editor/Window/PlaybackScroller.cs
new file mode 100644
index 0000000..96a9247
--- /dev/null
+++ b/Library/PackageCache/com.unity.timeline@1.2.13/Editor/Window/PlaybackScroller.cs
@@ -0,0 +1,54 @@
+using UnityEngine;
+
+namespace UnityEditor.Timeline
+{
+ enum PlaybackScrollMode
+ {
+ None,
+ Pan,
+ Smooth
+ }
+
+ static class PlaybackScroller
+ {
+ public static void AutoScroll(WindowState state)
+ {
+ if (Event.current.type != EventType.Layout)
+ return;
+
+ switch (state.autoScrollMode)
+ {
+ case PlaybackScrollMode.Pan:
+ DoPanScroll(state);
+ break;
+ case PlaybackScrollMode.Smooth:
+ DoSmoothScroll(state);
+ break;
+ }
+ }
+
+ static void DoSmoothScroll(WindowState state)
+ {
+ if (state.playing)
+ state.SetPlayHeadToMiddle();
+
+ state.UpdateLastFrameTime();
+ }
+
+ static void DoPanScroll(WindowState state)
+ {
+ if (!state.playing)
+ return;
+
+ var paddingDeltaTime = state.PixelDeltaToDeltaTime(WindowConstants.autoPanPaddingInPixels);
+ var showRange = state.timeAreaShownRange;
+ var rightBoundForPan = showRange.y - paddingDeltaTime;
+ if (state.editSequence.time > rightBoundForPan)
+ {
+ var leftBoundForPan = showRange.x + paddingDeltaTime;
+ var delta = rightBoundForPan - leftBoundForPan;
+ state.SetTimeAreaShownRange(showRange.x + delta, showRange.y + delta);
+ }
+ }
+ }
+}