From 917e9e0b320775634dc2e710f7deac74fd0822f0 Mon Sep 17 00:00:00 2001 From: chai Date: Thu, 22 Oct 2020 23:30:02 +0800 Subject: * amplify shader editor --- .../Plugins/Editor/Menu/DragAndDropTool.cs | 47 ++++++++++++++++++++++ 1 file changed, 47 insertions(+) create mode 100644 Assets/AmplifyShaderEditor/Plugins/Editor/Menu/DragAndDropTool.cs (limited to 'Assets/AmplifyShaderEditor/Plugins/Editor/Menu/DragAndDropTool.cs') diff --git a/Assets/AmplifyShaderEditor/Plugins/Editor/Menu/DragAndDropTool.cs b/Assets/AmplifyShaderEditor/Plugins/Editor/Menu/DragAndDropTool.cs new file mode 100644 index 00000000..2da02086 --- /dev/null +++ b/Assets/AmplifyShaderEditor/Plugins/Editor/Menu/DragAndDropTool.cs @@ -0,0 +1,47 @@ +// Amplify Shader Editor - Visual Shader Editing Tool +// Copyright (c) Amplify Creations, Lda + +using UnityEditor; +using UnityEngine; + +namespace AmplifyShaderEditor +{ + public class DragAndDropTool + { + public delegate void OnValidDropObject(params UnityEngine.Object[] draggedObjs ); + public event OnValidDropObject OnValidDropObjectEvt; + + public void Destroy() + { + OnValidDropObjectEvt = null; + } + + public void TestDragAndDrop( Rect dropArea ) + { + Event currentEvent = Event.current; + EventType currentEventType = currentEvent.type; + + switch (currentEventType) + { + case EventType.DragUpdated: + case EventType.DragPerform: + { + + if (!dropArea.Contains(currentEvent.mousePosition)) + return; + + DragAndDrop.visualMode = DragAndDropVisualMode.Copy; + if (currentEvent.type == EventType.DragPerform) + { + DragAndDrop.AcceptDrag(); + if (OnValidDropObjectEvt != null) + { + OnValidDropObjectEvt(DragAndDrop.objectReferences); + } + } + }break; + case EventType.DragExited:DragAndDrop.PrepareStartDrag();break; + } + } + } +} -- cgit v1.1-26-g67d0