summaryrefslogtreecommitdiff
path: root/dali
diff options
context:
space:
mode:
authorTaehyub Kim <taehyub.kim@samsung.com>2023-10-11 06:50:22 +0000
committerGerrit Code Review <gerrit@review>2023-10-11 06:50:22 +0000
commit110747416c935235c15dde293fa91bca0d8e63b0 (patch)
tree1dc73c31780039b3d9bddc5901b87aa23e1c2a4c /dali
parentefc7fc493b65bada3643ac00f9e297ff643054cd (diff)
parentdd9cd8e0688bd99b40b15959c6f6fb2121babdc5 (diff)
downloaddali-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
Diffstat (limited to 'dali')
-rw-r--r--dali/internal/drag-and-drop/tizen-wayland/drag-and-drop-impl-ecore-wl2.cpp22
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)