summaryrefslogtreecommitdiff
path: root/Assets/AmplifyShaderEditor/Plugins/Editor/Nodes/Operators/LengthOpNode.cs
diff options
context:
space:
mode:
authorchai <chaifix@163.com>2020-10-22 23:30:02 +0800
committerchai <chaifix@163.com>2020-10-22 23:30:02 +0800
commit917e9e0b320775634dc2e710f7deac74fd0822f0 (patch)
tree637f3cccc80e7738c8a077fa3ff59218b8b18ee8 /Assets/AmplifyShaderEditor/Plugins/Editor/Nodes/Operators/LengthOpNode.cs
parent8268e4e308bd110dfea4ad849a7ff74e66951349 (diff)
* amplify shader editor
Diffstat (limited to 'Assets/AmplifyShaderEditor/Plugins/Editor/Nodes/Operators/LengthOpNode.cs')
-rw-r--r--Assets/AmplifyShaderEditor/Plugins/Editor/Nodes/Operators/LengthOpNode.cs41
1 files changed, 41 insertions, 0 deletions
diff --git a/Assets/AmplifyShaderEditor/Plugins/Editor/Nodes/Operators/LengthOpNode.cs b/Assets/AmplifyShaderEditor/Plugins/Editor/Nodes/Operators/LengthOpNode.cs
new file mode 100644
index 00000000..c67f26b4
--- /dev/null
+++ b/Assets/AmplifyShaderEditor/Plugins/Editor/Nodes/Operators/LengthOpNode.cs
@@ -0,0 +1,41 @@
+// Amplify Shader Editor - Visual Shader Editing Tool
+// Copyright (c) Amplify Creations, Lda <info@amplify.pt>
+
+namespace AmplifyShaderEditor
+{
+ [System.Serializable]
+ [NodeAttributes( "Length", "Vector Operators", "Scalar Euclidean length of a vector" )]
+ public sealed class LengthOpNode : SingleInputOp
+ {
+ protected override void CommonInit( int uniqueId )
+ {
+ base.CommonInit( uniqueId );
+ m_opName = "length";
+ m_previewShaderGUID = "1c1f6d6512b758942a8b9dd1bea12f34";
+ m_inputPorts[ 0 ].CreatePortRestrictions( WirePortDataType.OBJECT,
+ WirePortDataType.FLOAT ,
+ WirePortDataType.FLOAT2,
+ WirePortDataType.FLOAT3,
+ WirePortDataType.FLOAT4,
+ WirePortDataType.COLOR ,
+ WirePortDataType.INT);
+ m_inputPorts[ 0 ].ChangeType( WirePortDataType.FLOAT4, false );
+ m_autoUpdateOutputPort = false;
+ }
+ public override void SetPreviewInputs()
+ {
+ base.SetPreviewInputs();
+ switch( m_inputPorts[0].DataType )
+ {
+ case WirePortDataType.OBJECT:
+ case WirePortDataType.INT:
+ case WirePortDataType.FLOAT:
+ case WirePortDataType.UINT:m_previewMaterialPassId = 0;break;
+ case WirePortDataType.FLOAT2:m_previewMaterialPassId = 1;break;
+ case WirePortDataType.FLOAT3:m_previewMaterialPassId = 2;break;
+ case WirePortDataType.FLOAT4:
+ case WirePortDataType.COLOR:m_previewMaterialPassId = 3;break;
+ }
+ }
+ }
+}