diff options
author | Taehyub Kim <taehyub.kim@samsung.com> | 2023-10-11 06:50:22 +0000 |
---|---|---|
committer | Gerrit Code Review <gerrit@review> | 2023-10-11 06:50:22 +0000 |
commit | 110747416c935235c15dde293fa91bca0d8e63b0 (patch) | |
tree | 1dc73c31780039b3d9bddc5901b87aa23e1c2a4c | |
parent | efc7fc493b65bada3643ac00f9e297ff643054cd (diff) | |
parent | dd9cd8e0688bd99b40b15959c6f6fb2121babdc5 (diff) | |
download | dali-adaptor-110747416c935235c15dde293fa91bca0d8e63b0.tar.gz dali-adaptor-110747416c935235c15dde293fa91bca0d8e63b0.tar.bz2 dali-adaptor-110747416c935235c15dde293fa91bca0d8e63b0.zip |
Merge "DragAndDrop : make window's callback function called by window id" into devel/master
-rw-r--r-- | dali/internal/drag-and-drop/tizen-wayland/drag-and-drop-impl-ecore-wl2.cpp | 22 |
1 files changed, 16 insertions, 6 deletions
diff --git a/dali/internal/drag-and-drop/tizen-wayland/drag-and-drop-impl-ecore-wl2.cpp b/dali/internal/drag-and-drop/tizen-wayland/drag-and-drop-impl-ecore-wl2.cpp index 49c45ffd8..52f3bd00c 100644 --- a/dali/internal/drag-and-drop/tizen-wayland/drag-and-drop-impl-ecore-wl2.cpp +++ b/dali/internal/drag-and-drop/tizen-wayland/drag-and-drop-impl-ecore-wl2.cpp @@ -397,11 +397,6 @@ void DragAndDropEcoreWl::SendData(void* event) close(ev->fd); - if(mDragWindow) - { - mDragWindow.Hide(); - } - delete[] buffer; } @@ -417,14 +412,29 @@ void DragAndDropEcoreWl::ReceiveData(void* event) } mTargetIndex = -1; + Ecore_Wl2_Display* display = ecore_wl2_connected_display_get(NULL); + Ecore_Wl2_Input* input = ecore_wl2_input_default_input_get(display); + if(mWindowTargetIndex != -1) { Dali::DragAndDrop::DragEvent dragEvent(Dali::DragAndDrop::DragType::DROP, mWindowPosition, ev->mimetype, ev->data); mDropWindowTargets[mWindowTargetIndex].callback(dragEvent); mDropWindowTargets[mWindowTargetIndex].inside = false; } - mWindowTargetIndex = -1; + else if(ev->offer != ecore_wl2_dnd_selection_get(input)) + { + for (std::size_t i = 0; i< mDropWindowTargets.size(); i++) + { + if (ev->win == mDropWindowTargets[i].windowId) + { + Dali::DragAndDrop::DragEvent dragEvent(Dali::DragAndDrop::DragType::DROP, mWindowPosition, ev->mimetype, ev->data); + mDropWindowTargets[i].callback(dragEvent); + break; + } + } + } + mWindowTargetIndex = -1; } Vector2 DragAndDropEcoreWl::RecalculatePositionByOrientation(int x, int y, Dali::Window window) |