diff options
author | chai <chaifix@163.com> | 2020-10-22 23:30:02 +0800 |
---|---|---|
committer | chai <chaifix@163.com> | 2020-10-22 23:30:02 +0800 |
commit | 917e9e0b320775634dc2e710f7deac74fd0822f0 (patch) | |
tree | 637f3cccc80e7738c8a077fa3ff59218b8b18ee8 /Assets/AmplifyShaderEditor/Plugins/Editor/Templates/TemplateOptionsDefinesContainer.cs | |
parent | 8268e4e308bd110dfea4ad849a7ff74e66951349 (diff) |
* amplify shader editor
Diffstat (limited to 'Assets/AmplifyShaderEditor/Plugins/Editor/Templates/TemplateOptionsDefinesContainer.cs')
-rw-r--r-- | Assets/AmplifyShaderEditor/Plugins/Editor/Templates/TemplateOptionsDefinesContainer.cs | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/Assets/AmplifyShaderEditor/Plugins/Editor/Templates/TemplateOptionsDefinesContainer.cs b/Assets/AmplifyShaderEditor/Plugins/Editor/Templates/TemplateOptionsDefinesContainer.cs new file mode 100644 index 00000000..affbd406 --- /dev/null +++ b/Assets/AmplifyShaderEditor/Plugins/Editor/Templates/TemplateOptionsDefinesContainer.cs @@ -0,0 +1,69 @@ +using UnityEngine; +using System; +using System.Collections.Generic; + +namespace AmplifyShaderEditor +{ + [Serializable] + public class TemplateOptionsDefinesContainer + { + [SerializeField] + private List<PropertyDataCollector> m_definesList = new List<PropertyDataCollector>(); + + [NonSerialized] + private Dictionary<string, PropertyDataCollector> m_definesDict = new Dictionary<string, PropertyDataCollector>(); + + void Refresh() + { + if( m_definesDict.Count != m_definesList.Count ) + { + m_definesDict.Clear(); + for( int i = 0; i < m_definesList.Count; i++ ) + { + m_definesDict.Add( m_definesList[ i ].PropertyName, m_definesList[ i ] ); + } + } + } + + public void RemoveTemporaries() + { + List<PropertyDataCollector> temporaries = m_definesList.FindAll( ( x ) => ( x.NodeId == 1 ) ); + for( int i = 0; i < temporaries.Count; i++ ) + { + m_definesList.Remove( temporaries[ i ] ); + m_definesDict.Remove( temporaries[ i ].PropertyName ); + } + } + + public void AddDefine( string define , bool temporary ) + { + Refresh(); + if( !m_definesDict.ContainsKey( define ) ) + { + int nodeId = temporary ? 1 : 0; + PropertyDataCollector data = new PropertyDataCollector( nodeId, define ); + m_definesDict.Add( define, data ); + m_definesList.Add( data ); + } + } + + public void RemoveDefine( string define ) + { + Refresh(); + if( m_definesDict.ContainsKey( define ) ) + { + m_definesList.Remove( m_definesDict[define] ); + m_definesDict.Remove( define ); + } + } + + public void Destroy() + { + m_definesDict.Clear(); + m_definesDict = null; + m_definesList.Clear(); + m_definesList = null; + } + public List<PropertyDataCollector> DefinesList { get { return m_definesList; } } + } +} |