From b82da95b5181ac8bbae38efb13e950d5e88a4caa Mon Sep 17 00:00:00 2001 From: chai Date: Fri, 23 Oct 2020 13:08:43 +0800 Subject: =?UTF-8?q?*=E7=A7=BB=E5=8A=A8amplify=20shader=20editor=E5=88=B0th?= =?UTF-8?q?ird=20party=E7=9B=AE=E5=BD=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../Templates/TemplateOptionsDefinesContainer.cs | 69 ++++++++++++++++++++++ 1 file changed, 69 insertions(+) create mode 100644 Assets/ThirdParty/AmplifyShaderEditor/Plugins/Editor/Templates/TemplateOptionsDefinesContainer.cs (limited to 'Assets/ThirdParty/AmplifyShaderEditor/Plugins/Editor/Templates/TemplateOptionsDefinesContainer.cs') diff --git a/Assets/ThirdParty/AmplifyShaderEditor/Plugins/Editor/Templates/TemplateOptionsDefinesContainer.cs b/Assets/ThirdParty/AmplifyShaderEditor/Plugins/Editor/Templates/TemplateOptionsDefinesContainer.cs new file mode 100644 index 00000000..affbd406 --- /dev/null +++ b/Assets/ThirdParty/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 m_definesList = new List(); + + [NonSerialized] + private Dictionary m_definesDict = new Dictionary(); + + 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 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 DefinesList { get { return m_definesList; } } + } +} -- cgit v1.1-26-g67d0