From c55fba8ab2a1c9d3df65eda4a5a1e957f4aa1f78 Mon Sep 17 00:00:00 2001 From: Andrew Lee Date: Sun, 19 Apr 2020 17:19:32 -0400 Subject: Inital commit --- .../Editor/Activation/ActivationTrackEditor.cs | 56 ++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 Library/PackageCache/com.unity.timeline@1.2.13/Editor/Activation/ActivationTrackEditor.cs (limited to 'Library/PackageCache/com.unity.timeline@1.2.13/Editor/Activation/ActivationTrackEditor.cs') diff --git a/Library/PackageCache/com.unity.timeline@1.2.13/Editor/Activation/ActivationTrackEditor.cs b/Library/PackageCache/com.unity.timeline@1.2.13/Editor/Activation/ActivationTrackEditor.cs new file mode 100644 index 0000000..a7552f1 --- /dev/null +++ b/Library/PackageCache/com.unity.timeline@1.2.13/Editor/Activation/ActivationTrackEditor.cs @@ -0,0 +1,56 @@ +using JetBrains.Annotations; +using UnityEngine; +using UnityEngine.Timeline; +using UnityEngine.Playables; + +namespace UnityEditor.Timeline +{ + [UsedImplicitly] + [CustomTimelineEditor(typeof(ActivationTrack))] + class ActivationTrackEditor : TrackEditor + { + static readonly string ClipText = LocalizationDatabase.GetLocalizedString("Active"); + + static readonly string k_ErrorParentString = LocalizationDatabase.GetLocalizedString("The bound GameObject is a parent of the PlayableDirector."); + static readonly string k_ErrorString = LocalizationDatabase.GetLocalizedString("The bound GameObject contains the PlayableDirector."); + + public override TrackDrawOptions GetTrackOptions(TrackAsset track, Object binding) + { + var options = base.GetTrackOptions(track, binding); + options.errorText = GetErrorText(track, binding); + return options; + } + + string GetErrorText(TrackAsset track, Object binding) + { + var gameObject = binding as GameObject; + var currentDirector = TimelineEditor.inspectedDirector; + if (gameObject != null && currentDirector != null) + { + var director = gameObject.GetComponent(); + if (currentDirector == director) + { + return k_ErrorString; + } + + if (currentDirector.gameObject.transform.IsChildOf(gameObject.transform)) + { + return k_ErrorParentString; + } + } + + return base.GetErrorText(track, binding, TrackBindingErrors.PrefabBound); + } + + public override void OnCreate(TrackAsset track, TrackAsset copiedFrom) + { + // Add a default clip to the newly created track + if (copiedFrom == null) + { + var clip = track.CreateClip(0); + clip.displayName = ClipText; + clip.duration = System.Math.Max(clip.duration, track.timelineAsset.duration * 0.5f); + } + } + } +} -- cgit v1.2.3