From 6717c9b54c284376d6cb96769b5f4e5faa593cf8 Mon Sep 17 00:00:00 2001 From: Bruno Mikoski Date: Wed, 21 Sep 2022 16:49:26 +0100 Subject: [PATCH] add: meta changes and settings file --- CHANGELOG.MD | 8 ++ ...nimationSequencerControllerCustomEditor.cs | 6 +- .../Editor/Core/AnimationSequencerSettings.cs | 18 ++++ .../Core/AnimationSequencerSettings.cs.meta | 3 + .../Utility/ScriptableObjectForPreferences.cs | 82 +++++++++++++++++++ .../ScriptableObjectForPreferences.cs.meta | 3 + .../DOTweenActions/ColorGraphicDOTWeen.cs | 11 +-- package.json | 2 +- 8 files changed, 121 insertions(+), 12 deletions(-) create mode 100644 Scripts/Editor/Core/AnimationSequencerSettings.cs create mode 100644 Scripts/Editor/Core/AnimationSequencerSettings.cs.meta create mode 100644 Scripts/Editor/Utility/ScriptableObjectForPreferences.cs create mode 100644 Scripts/Editor/Utility/ScriptableObjectForPreferences.cs.meta diff --git a/CHANGELOG.MD b/CHANGELOG.MD index b4000ef..bf06afe 100644 --- a/CHANGELOG.MD +++ b/CHANGELOG.MD @@ -6,6 +6,13 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## Unreleased +## [0.5.0] +### Changed +- Added support to control AnimationSequencer though regular unity animations, in both runtime / playtime +- Fixed issue with color tweens no working on the editor > 2021 +- Added a settings menu on `Edit/Preferences/AnimationSequencer` +- You can now disable the auto foldout of the steps while previewing on the Settings + ## [0.4.0] ### Changed - Fixed Unity 2020 compability @@ -185,6 +192,7 @@ Thanks for all the [suggestions](https://github.com/brunomikoski/Animation-Seque ### Added - First initial working version +[0.5.0]: https://github.com/brunomikoski/Animation-Sequencer/releases/tag/v0.5.0 [0.4.0]: https://github.com/brunomikoski/Animation-Sequencer/releases/tag/v0.4.0 [0.3.9]: https://github.com/brunomikoski/Animation-Sequencer/releases/tag/v0.3.9 [0.3.8]: https://github.com/brunomikoski/Animation-Sequencer/releases/tag/v0.3.8 diff --git a/Scripts/Editor/Core/AnimationSequencerControllerCustomEditor.cs b/Scripts/Editor/Core/AnimationSequencerControllerCustomEditor.cs index 8895187..1d2e6e5 100644 --- a/Scripts/Editor/Core/AnimationSequencerControllerCustomEditor.cs +++ b/Scripts/Editor/Core/AnimationSequencerControllerCustomEditor.cs @@ -97,14 +97,14 @@ private void EditorUpdate() { if (Application.isPlaying) return; - + SerializedProperty progressSP = serializedObject.FindProperty("progress"); if (Mathf.Approximately(progressSP.floatValue, -1)) return; SetProgress(progressSP.floatValue); } - + private void OnEditorPlayModeChanged(PlayModeStateChange playModeState) { if (playModeState == PlayModeStateChange.ExitingEditMode) @@ -448,7 +448,7 @@ private void PlaySequence() } wasShowingStepsPanel = showStepsPanel; - showStepsPanel = false; + showStepsPanel = !AnimationSequencerSettings.GetInstance().AutoHideStepsWhenPreviewing; } private void DrawProgressSlider() diff --git a/Scripts/Editor/Core/AnimationSequencerSettings.cs b/Scripts/Editor/Core/AnimationSequencerSettings.cs new file mode 100644 index 0000000..901711a --- /dev/null +++ b/Scripts/Editor/Core/AnimationSequencerSettings.cs @@ -0,0 +1,18 @@ +using UnityEditor; +using UnityEngine; + +namespace BrunoMikoski.AnimationSequencer +{ + public sealed class AnimationSequencerSettings : ScriptableObjectForPreferences + { + [SerializeField] + private bool autoHideStepsWhenPreviewing = true; + public bool AutoHideStepsWhenPreviewing => autoHideStepsWhenPreviewing; + + [SettingsProvider] + private static SettingsProvider SettingsProvider() + { + return CreateSettingsProvider("Animation Sequencer", null); + } + } +} diff --git a/Scripts/Editor/Core/AnimationSequencerSettings.cs.meta b/Scripts/Editor/Core/AnimationSequencerSettings.cs.meta new file mode 100644 index 0000000..77f27f0 --- /dev/null +++ b/Scripts/Editor/Core/AnimationSequencerSettings.cs.meta @@ -0,0 +1,3 @@ +fileFormatVersion: 2 +guid: e3a6b363871842658d8fbe8d6348611c +timeCreated: 1663765620 \ No newline at end of file diff --git a/Scripts/Editor/Utility/ScriptableObjectForPreferences.cs b/Scripts/Editor/Utility/ScriptableObjectForPreferences.cs new file mode 100644 index 0000000..3e13715 --- /dev/null +++ b/Scripts/Editor/Utility/ScriptableObjectForPreferences.cs @@ -0,0 +1,82 @@ +using System; +using System.Collections.Generic; +using UnityEditor; +using UnityEngine; + +namespace BrunoMikoski.AnimationSequencer +{ + //From https://github.com/baba-s/UniScriptableObjectForPreferences/blob/master/Editor/ScriptableObjectForPreferences.cs + public abstract class ScriptableObjectForPreferences : ScriptableObject + where T : ScriptableObjectForPreferences + { + private static string ConfigName => typeof(T).Name; + private static T instance; + + public static T GetInstance() + { + if (instance != null) + { + return instance; + } + + instance = CreateInstance(); + string json = EditorUserSettings.GetConfigValue(ConfigName); + EditorJsonUtility.FromJsonOverwrite(json, instance); + if (instance == null) + { + instance = CreateInstance(); + } + + return instance; + } + + public static SettingsProvider CreateSettingsProvider( + string settingsProviderPath = null, + Action onGUI = null, + Action onGUIExtra = null + ) + { + if (settingsProviderPath == null) + { + settingsProviderPath = $"{typeof(T).Name}"; + } + + T foundInstance = GetInstance(); + SerializedObject serializedObject = new SerializedObject(foundInstance); + IEnumerable keywords = SettingsProvider.GetSearchKeywordsFromSerializedObject(serializedObject); + SettingsProvider provider = new SettingsProvider(settingsProviderPath, SettingsScope.User, keywords); + provider.guiHandler += _ => OnGuiHandler(onGUI, onGUIExtra); + return provider; + } + + private static void OnGuiHandler(Action onGUI, + Action onGUIExtra) + { + T foundInstance = GetInstance(); + Editor editor = Editor.CreateEditor(foundInstance); + using (EditorGUI.ChangeCheckScope scope = new EditorGUI.ChangeCheckScope()) + { + SerializedObject serializedObject = editor.serializedObject; + serializedObject.Update(); + if (onGUI != null) + { + onGUI(serializedObject); + } + else + { + editor.DrawDefaultInspector(); + } + + onGUIExtra?.Invoke(serializedObject); + if (!scope.changed) + { + return; + } + + serializedObject.ApplyModifiedProperties(); + string json = EditorJsonUtility.ToJson(editor.target); + EditorUserSettings.SetConfigValue(ConfigName, json); + } + } + } +} diff --git a/Scripts/Editor/Utility/ScriptableObjectForPreferences.cs.meta b/Scripts/Editor/Utility/ScriptableObjectForPreferences.cs.meta new file mode 100644 index 0000000..bf66464 --- /dev/null +++ b/Scripts/Editor/Utility/ScriptableObjectForPreferences.cs.meta @@ -0,0 +1,3 @@ +fileFormatVersion: 2 +guid: 43e853692c4d4b03a749c094b983417d +timeCreated: 1663765550 \ No newline at end of file diff --git a/Scripts/Runtime/Core/DOTweenActions/ColorGraphicDOTWeen.cs b/Scripts/Runtime/Core/DOTweenActions/ColorGraphicDOTWeen.cs index 1a9261d..4d266de 100644 --- a/Scripts/Runtime/Core/DOTweenActions/ColorGraphicDOTWeen.cs +++ b/Scripts/Runtime/Core/DOTweenActions/ColorGraphicDOTWeen.cs @@ -16,11 +16,6 @@ public sealed class ColorGraphicDOTWeen : DOTweenActionBase [SerializeField] private Color color; - public Color Color - { - get => color; - set => color = value; - } private Graphic targetGraphic; private Color previousColor; @@ -40,15 +35,15 @@ protected override Tweener GenerateTween_Internal(GameObject target, float durat previousColor = targetGraphic.color; TweenerCore graphicTween = targetGraphic.DOColor(color, duration); -#if UNITY_EDITOR +#if UNITY_EDITOR if (!Application.isPlaying) { // Work around a Unity bug where updating the colour does not cause any visual change outside of PlayMode. // https://forum.unity.com/threads/editor-scripting-force-color-update.798663/ graphicTween.OnUpdate(() => { - targetGraphic.enabled = false; - targetGraphic.enabled = true; + targetGraphic.transform.localScale = new Vector3(1.001f, 1.001f, 1.001f); + targetGraphic.transform.localScale = new Vector3(1, 1, 1); }); } #endif diff --git a/package.json b/package.json index 1e409dc..1c34759 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "com.brunomikoski.animationsequencer", "displayName": "Animation Sequencer", - "version": "0.4.0", + "version": "0.5.0", "unity": "2018.4", "description": "Animation sequencer is a way to create complex animations of sequence of events by a friendly user interface. Requires DOTween v1.2.632", "keywords": [