-
Notifications
You must be signed in to change notification settings - Fork 254
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[NUI] Add multi-mimetype feature for Drag and Drop #6294
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||||
---|---|---|---|---|---|---|---|---|
|
@@ -18,6 +18,7 @@ | |||||||
using System.ComponentModel; | ||||||||
using System.Runtime.InteropServices; | ||||||||
using System.Collections.Generic; | ||||||||
using System.Linq; | ||||||||
using System.Diagnostics.CodeAnalysis; | ||||||||
using Tizen.NUI.BaseComponents; | ||||||||
|
||||||||
|
@@ -32,10 +33,10 @@ public class DragAndDrop : BaseHandle | |||||||
{ | ||||||||
public delegate void SourceEventHandler(DragSourceEventType sourceEventType); | ||||||||
private delegate void InternalSourceEventHandler(int sourceEventType); | ||||||||
public delegate void DragAndDropEventHandler(View targetView, DragEvent dragEvent); | ||||||||
public delegate void DragAndDropEventHandler(View targetView, DragEvent navtiveDragEvent); | ||||||||
[EditorBrowsable(EditorBrowsableState.Never)] | ||||||||
public delegate void DragAndDropWindowEventHandler(Window targetWindow, DragEvent dragEvent); | ||||||||
private delegate void InternalDragAndDropEventHandler(global::System.IntPtr dragEvent); | ||||||||
public delegate void DragAndDropWindowEventHandler(Window targetWindow, DragEvent navtiveDragEvent); | ||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||||||
private delegate void InternalDragAndDropEventHandler(global::System.IntPtr navtiveDragEvent); | ||||||||
private InternalSourceEventHandler sourceEventCb; | ||||||||
private Dictionary<View, InternalDragAndDropEventHandler> targetEventDictionary = new Dictionary<View, InternalDragAndDropEventHandler>(); | ||||||||
private Dictionary<Window, InternalDragAndDropEventHandler> targetWindowEventDictionary = new Dictionary<Window, InternalDragAndDropEventHandler>(); | ||||||||
|
@@ -46,11 +47,107 @@ public class DragAndDrop : BaseHandle | |||||||
private int dragWindowOffsetX = 0; | ||||||||
private int dragWindowOffsetY = 0; | ||||||||
|
||||||||
private bool initDrag = false; | ||||||||
|
||||||||
private const int MinDragWindowWidth = 100; | ||||||||
private const int MinDragWindowHeight = 100; | ||||||||
|
||||||||
private void ProcessDragEventTargetCallback(IntPtr navtiveDragEvent, View targetView, DragAndDropEventHandler callback) | ||||||||
{ | ||||||||
DragType type = (DragType)Interop.DragAndDrop.GetAction(navtiveDragEvent); | ||||||||
DragEvent dragEvent = new DragEvent(); | ||||||||
global::System.IntPtr cPtr = Interop.DragAndDrop.GetPosition(navtiveDragEvent); | ||||||||
dragEvent.Position = (cPtr == global::System.IntPtr.Zero) ? null : new Position(cPtr, true); | ||||||||
|
||||||||
IntPtr nativeMimeTypes; | ||||||||
int count; | ||||||||
Interop.DragAndDrop.GetMimeTypes(navtiveDragEvent, out nativeMimeTypes, out count); | ||||||||
if (count > 0) | ||||||||
{ | ||||||||
IntPtr [] nativeMimeTypesArrary = new IntPtr[count]; | ||||||||
Marshal.Copy(nativeMimeTypes, nativeMimeTypesArrary, 0, count); | ||||||||
|
||||||||
string [] managedMimeTypes = new string[count]; | ||||||||
|
||||||||
for (int iterator = 0; iterator < count; iterator++) | ||||||||
{ | ||||||||
managedMimeTypes[iterator] = Marshal.PtrToStringAnsi(nativeMimeTypesArrary[iterator]); | ||||||||
} | ||||||||
|
||||||||
dragEvent.MimeType = managedMimeTypes[0]; | ||||||||
dragEvent.MimeTypes = managedMimeTypes; | ||||||||
} | ||||||||
|
||||||||
if (type == DragType.Enter) | ||||||||
{ | ||||||||
dragEvent.DragType = type; | ||||||||
callback(targetView, dragEvent); | ||||||||
} | ||||||||
else if (type == DragType.Leave) | ||||||||
{ | ||||||||
dragEvent.DragType = type; | ||||||||
callback(targetView, dragEvent); | ||||||||
} | ||||||||
else if (type == DragType.Move) | ||||||||
{ | ||||||||
dragEvent.DragType = type; | ||||||||
callback(targetView, dragEvent); | ||||||||
} | ||||||||
else if (type == DragType.Drop) | ||||||||
{ | ||||||||
dragEvent.DragType = type; | ||||||||
dragEvent.Data = Interop.DragAndDrop.GetData(navtiveDragEvent); | ||||||||
callback(targetView, dragEvent); | ||||||||
} | ||||||||
} | ||||||||
|
||||||||
private void ProcessDragEventWindowCallback(IntPtr navtiveDragEvent, Window targetWindow, DragAndDropWindowEventHandler callback) | ||||||||
{ | ||||||||
DragType type = (DragType)Interop.DragAndDrop.GetAction(navtiveDragEvent); | ||||||||
DragEvent dragEvent = new DragEvent(); | ||||||||
global::System.IntPtr cPtr = Interop.DragAndDrop.GetPosition(navtiveDragEvent); | ||||||||
dragEvent.Position = (cPtr == global::System.IntPtr.Zero) ? null : new Position(cPtr, false); | ||||||||
|
||||||||
IntPtr nativeMimeTypes; | ||||||||
int count; | ||||||||
Interop.DragAndDrop.GetMimeTypes(navtiveDragEvent, out nativeMimeTypes, out count); | ||||||||
if (count > 0) | ||||||||
{ | ||||||||
IntPtr [] nativeMimeTypesArrary = new IntPtr[count]; | ||||||||
Marshal.Copy(nativeMimeTypes, nativeMimeTypesArrary, 0, count); | ||||||||
|
||||||||
string [] managedMimeTypes = new string[count]; | ||||||||
|
||||||||
for (int iterator = 0; iterator < count; iterator++) | ||||||||
{ | ||||||||
managedMimeTypes[iterator] = Marshal.PtrToStringAnsi(nativeMimeTypesArrary[iterator]); | ||||||||
} | ||||||||
|
||||||||
dragEvent.MimeType = managedMimeTypes[0]; | ||||||||
dragEvent.MimeTypes = managedMimeTypes; | ||||||||
} | ||||||||
|
||||||||
if (type == DragType.Enter) | ||||||||
{ | ||||||||
dragEvent.DragType = type; | ||||||||
callback(targetWindow, dragEvent); | ||||||||
} | ||||||||
else if (type == DragType.Leave) | ||||||||
{ | ||||||||
dragEvent.DragType = type; | ||||||||
callback(targetWindow, dragEvent); | ||||||||
} | ||||||||
else if (type == DragType.Move) | ||||||||
{ | ||||||||
dragEvent.DragType = type; | ||||||||
callback(targetWindow, dragEvent); | ||||||||
} | ||||||||
else if (type == DragType.Drop) | ||||||||
{ | ||||||||
dragEvent.DragType = type; | ||||||||
dragEvent.Data = Interop.DragAndDrop.GetData(navtiveDragEvent); | ||||||||
callback(targetWindow, dragEvent); | ||||||||
} | ||||||||
} | ||||||||
|
||||||||
private DragAndDrop() : this(Interop.DragAndDrop.New(), true) | ||||||||
{ | ||||||||
if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve(); | ||||||||
|
@@ -92,14 +189,7 @@ private void ReleaseDragWindow() | |||||||
/// <param name="callback">The source event callback</param> | ||||||||
/// <since_tizen> 10 </since_tizen> | ||||||||
public void StartDragAndDrop(View sourceView, View shadowView, DragData dragData, SourceEventHandler callback) | ||||||||
{ | ||||||||
if (initDrag) | ||||||||
{ | ||||||||
Tizen.Log.Fatal("NUI", "Start Drag And Drop Initializing..."); | ||||||||
return; | ||||||||
} | ||||||||
initDrag = true; | ||||||||
|
||||||||
{ | ||||||||
if (Window.IsSupportedMultiWindow() == false) | ||||||||
{ | ||||||||
throw new NotSupportedException("This device does not support surfaceless_context. So Window cannot be created."); | ||||||||
|
@@ -155,7 +245,7 @@ public void StartDragAndDrop(View sourceView, View shadowView, DragData dragData | |||||||
{ | ||||||||
if ((DragSourceEventType)sourceEventType != DragSourceEventType.Start) | ||||||||
{ | ||||||||
Tizen.Log.Fatal("NUI", "DnD Source Event is Called"); | ||||||||
Tizen.Log.Fatal("NUI", "DnD Source Event is Called"); | ||||||||
ReleaseDragWindow(); | ||||||||
} | ||||||||
|
||||||||
|
@@ -165,15 +255,29 @@ public void StartDragAndDrop(View sourceView, View shadowView, DragData dragData | |||||||
//Show Drag Window before StartDragAndDrop | ||||||||
mDragWindow.Show(); | ||||||||
|
||||||||
if (!Interop.DragAndDrop.StartDragAndDrop(SwigCPtr, View.getCPtr(sourceView), Window.getCPtr(mDragWindow), dragData.MimeType, dragData.Data, | ||||||||
string [] mimeTypes; | ||||||||
string [] dataSet; | ||||||||
|
||||||||
if (string.IsNullOrEmpty(dragData.MimeType) && dragData.DataMap != null) | ||||||||
{ | ||||||||
mimeTypes = dragData.DataMap.Keys.ToArray(); | ||||||||
dataSet = dragData.DataMap.Values.ToArray(); | ||||||||
myroot marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||||
} | ||||||||
else | ||||||||
{ | ||||||||
mimeTypes = new string[1]; | ||||||||
mimeTypes[0] = dragData.MimeType; | ||||||||
|
||||||||
dataSet = new string[1]; | ||||||||
dataSet[0] = dragData.Data; | ||||||||
} | ||||||||
|
||||||||
if (!Interop.DragAndDrop.StartDragAndDrop(SwigCPtr, View.getCPtr(sourceView), Window.getCPtr(mDragWindow), mimeTypes, mimeTypes.Length, dataSet, dataSet.Length, | ||||||||
new global::System.Runtime.InteropServices.HandleRef(this, Marshal.GetFunctionPointerForDelegate<Delegate>(sourceEventCb)))) | ||||||||
{ | ||||||||
throw new InvalidOperationException("Fail to StartDragAndDrop"); | ||||||||
} | ||||||||
|
||||||||
} | ||||||||
|
||||||||
initDrag = false; | ||||||||
} | ||||||||
} | ||||||||
|
||||||||
/// <summary> | ||||||||
|
@@ -184,42 +288,23 @@ public void StartDragAndDrop(View sourceView, View shadowView, DragData dragData | |||||||
/// <since_tizen> 10 </since_tizen> | ||||||||
public void AddListener(View targetView, DragAndDropEventHandler callback) | ||||||||
{ | ||||||||
InternalDragAndDropEventHandler cb = (dragEvent) => | ||||||||
{ | ||||||||
DragType type = (DragType)Interop.DragAndDrop.GetAction(dragEvent); | ||||||||
DragEvent ev = new DragEvent(); | ||||||||
global::System.IntPtr cPtr = Interop.DragAndDrop.GetPosition(dragEvent); | ||||||||
ev.Position = (cPtr == global::System.IntPtr.Zero) ? null : new Position(cPtr, true); | ||||||||
AddListener(targetView, "*/*", callback); | ||||||||
} | ||||||||
|
||||||||
if (type == DragType.Enter) | ||||||||
{ | ||||||||
ev.DragType = type; | ||||||||
ev.MimeType = Interop.DragAndDrop.GetMimeType(dragEvent); | ||||||||
callback(targetView, ev); | ||||||||
} | ||||||||
else if (type == DragType.Leave) | ||||||||
{ | ||||||||
ev.DragType = type; | ||||||||
callback(targetView, ev); | ||||||||
} | ||||||||
else if (type == DragType.Move) | ||||||||
{ | ||||||||
ev.DragType = type; | ||||||||
ev.MimeType = Interop.DragAndDrop.GetMimeType(dragEvent); | ||||||||
callback(targetView, ev); | ||||||||
} | ||||||||
else if (type == DragType.Drop) | ||||||||
{ | ||||||||
ev.DragType = type; | ||||||||
ev.MimeType = Interop.DragAndDrop.GetMimeType(dragEvent); | ||||||||
ev.Data = Interop.DragAndDrop.GetData(dragEvent); | ||||||||
callback(targetView, ev); | ||||||||
} | ||||||||
}; | ||||||||
/// <summary> | ||||||||
/// Adds listener for drop targets | ||||||||
/// </summary> | ||||||||
/// <param name="targetView">The target view</param> | ||||||||
/// <param name="mimeType">The mime type for target view</param> | ||||||||
/// <param name="callback">The callback function to get drag event when the drag source enters, moves, leaves and drops on the drop target</param> | ||||||||
[EditorBrowsable(EditorBrowsableState.Never)] | ||||||||
public void AddListener(View targetView, string mimeType, DragAndDropEventHandler callback) | ||||||||
{ | ||||||||
InternalDragAndDropEventHandler cb = (navtiveDragEvent) => ProcessDragEventTargetCallback(navtiveDragEvent, targetView, callback); | ||||||||
|
||||||||
targetEventDictionary.Add(targetView, cb); | ||||||||
|
||||||||
if (!Interop.DragAndDrop.AddListener(SwigCPtr, View.getCPtr(targetView), | ||||||||
if (!Interop.DragAndDrop.AddListener(SwigCPtr, View.getCPtr(targetView), mimeType, | ||||||||
new global::System.Runtime.InteropServices.HandleRef(this, Marshal.GetFunctionPointerForDelegate<Delegate>(cb)))) | ||||||||
{ | ||||||||
throw new InvalidOperationException("Fail to AddListener for View"); | ||||||||
|
@@ -256,40 +341,23 @@ public void RemoveListener(View targetView, DragAndDropEventHandler _) | |||||||
[EditorBrowsable(EditorBrowsableState.Never)] | ||||||||
public void AddListener(Window targetWindow, DragAndDropWindowEventHandler callback) | ||||||||
{ | ||||||||
InternalDragAndDropEventHandler cb = (dragEvent) => | ||||||||
{ | ||||||||
DragType type = (DragType)Interop.DragAndDrop.GetAction(dragEvent); | ||||||||
DragEvent ev = new DragEvent(); | ||||||||
global::System.IntPtr cPtr = Interop.DragAndDrop.GetPosition(dragEvent); | ||||||||
ev.Position = (cPtr == global::System.IntPtr.Zero) ? null : new Position(cPtr, false); | ||||||||
AddListener(targetWindow, "*/*", callback); | ||||||||
} | ||||||||
|
||||||||
if (type == DragType.Enter) | ||||||||
{ | ||||||||
ev.DragType = type; | ||||||||
callback(targetWindow, ev); | ||||||||
} | ||||||||
else if (type == DragType.Leave) | ||||||||
{ | ||||||||
ev.DragType = type; | ||||||||
callback(targetWindow, ev); | ||||||||
} | ||||||||
else if (type == DragType.Move) | ||||||||
{ | ||||||||
ev.DragType = type; | ||||||||
callback(targetWindow, ev); | ||||||||
} | ||||||||
else if (type == DragType.Drop) | ||||||||
{ | ||||||||
ev.DragType = type; | ||||||||
ev.MimeType = Interop.DragAndDrop.GetMimeType(dragEvent); | ||||||||
ev.Data = Interop.DragAndDrop.GetData(dragEvent); | ||||||||
callback(targetWindow, ev); | ||||||||
} | ||||||||
}; | ||||||||
/// <summary> | ||||||||
/// Adds listener for drop targets | ||||||||
/// </summary> | ||||||||
/// <param name="targetWindow">The target Window</param> | ||||||||
/// <param name="mimeType">The mime type for target view</param> | ||||||||
/// <param name="callback">The callback function to get drag event when the drag source enters, moves, leaves and drops on the drop target</param> | ||||||||
[EditorBrowsable(EditorBrowsableState.Never)] | ||||||||
public void AddListener(Window targetWindow, string mimeType, DragAndDropWindowEventHandler callback) | ||||||||
{ | ||||||||
InternalDragAndDropEventHandler cb = (navtiveDragEvent) => ProcessDragEventWindowCallback(navtiveDragEvent, targetWindow, callback); | ||||||||
|
||||||||
targetWindowEventDictionary.Add(targetWindow, cb); | ||||||||
|
||||||||
if (!Interop.DragAndDrop.WindowAddListener(SwigCPtr, Window.getCPtr(targetWindow), | ||||||||
if (!Interop.DragAndDrop.WindowAddListener(SwigCPtr, Window.getCPtr(targetWindow), mimeType, | ||||||||
new global::System.Runtime.InteropServices.HandleRef(this, Marshal.GetFunctionPointerForDelegate<Delegate>(cb)))) | ||||||||
{ | ||||||||
throw new InvalidOperationException("Fail to AddListener for Window"); | ||||||||
|
Original file line number | Diff line number | Diff line change | ||||||
---|---|---|---|---|---|---|---|---|
|
@@ -16,6 +16,7 @@ | |||||||
*/ | ||||||||
using System; | ||||||||
using System.ComponentModel; | ||||||||
using System.Collections.Generic; | ||||||||
using Tizen.NUI.Binding; | ||||||||
|
||||||||
namespace Tizen.NUI | ||||||||
|
@@ -60,6 +61,12 @@ public struct DragData | |||||||
/// The drag data to send | ||||||||
/// </summary> | ||||||||
public string Data { get; set; } | ||||||||
|
||||||||
/// <summary> | ||||||||
/// The mime types and drag data set | ||||||||
/// </summary> | ||||||||
[EditorBrowsable(EditorBrowsableState.Never)] | ||||||||
public Dictionary<string, string> DataMap; | ||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 감사합니다. ACR 안되도록 추가완료하였습니다 👍 |
||||||||
} | ||||||||
|
||||||||
/// <summary> | ||||||||
|
@@ -106,6 +113,13 @@ public struct DragEvent | |||||||
/// The mime type of drag object | ||||||||
/// </summary> | ||||||||
public string MimeType { get; set; } | ||||||||
|
||||||||
/// <summary> | ||||||||
/// The mime types of drag object | ||||||||
/// </summary> | ||||||||
[EditorBrowsable(EditorBrowsableState.Never)] | ||||||||
public string [] MimeTypes { get; set; } | ||||||||
taehyub marked this conversation as resolved.
Show resolved
Hide resolved
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||||||
|
||||||||
/// <summary> | ||||||||
/// The drag data to receive | ||||||||
/// </summary> | ||||||||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
감사합니다. ACR 안되도록 추가완료하였습니다 😄