Enlightenment CVS committal Author : jlzapata Project : e17 Module : apps/e
Dir : e17/apps/e/src/bin Modified Files: e_fileman_smart.c Log Message: efm: - xdnd / internal dnd works - new signals for drag/drop of icons ---------------------------------------------------------------------- =================================================================== RCS file: /cvsroot/enlightenment/e17/apps/e/src/bin/e_fileman_smart.c,v retrieving revision 1.125 retrieving revision 1.126 diff -u -3 -r1.125 -r1.126 --- e_fileman_smart.c 9 Feb 2006 04:04:53 -0000 1.125 +++ e_fileman_smart.c 9 Feb 2006 18:31:14 -0000 1.126 @@ -2435,6 +2435,8 @@ char *data; char **drop_types; + e_fm_icon_signal_emit(icon->icon_obj, "dragged", ""); + drop_types = calloc(1, sizeof(char*)); drop_types[0] = strdup("text/uri-list"); @@ -2445,18 +2447,22 @@ evas_object_geometry_get(icon->icon_obj, &x, &y, &w, &h); - if(!sd->drag.ecore_evas) - sd->drag.ecore_evas = ecore_evas_software_x11_new(NULL, 0, cx + x, cy + y, w, h); + if(sd->drag.ecore_evas) + ecore_evas_free(sd->drag.ecore_evas); + + sd->drag.dx = ev->cur.canvas.x; sd->drag.dy = ev->cur.canvas.y; + sd->drag.ecore_evas = ecore_evas_software_x11_new(NULL, 0, cx + x, cy + y, w, h); sd->drag.evas = ecore_evas_get(sd->drag.ecore_evas); sd->drag.win = ecore_evas_software_x11_window_get(sd->drag.ecore_evas); - + ecore_evas_shaped_set(sd->drag.ecore_evas, 1); ecore_evas_borderless_set(sd->drag.ecore_evas, 1); ecore_evas_name_class_set(sd->drag.ecore_evas, "E", "_e_drag_window"); ecore_evas_title_set(sd->drag.ecore_evas, "E Drag"); ecore_evas_ignore_events_set(sd->drag.ecore_evas, 1); + ecore_evas_show(sd->drag.ecore_evas); sd->drag.image_object = e_fm_icon_add(sd->drag.evas); e_fm_icon_file_set(sd->drag.image_object, icon->file); @@ -2472,7 +2478,7 @@ - evas_event_feed_mouse_up(sd->evas, 1, EVAS_BUTTON_NONE, ev->timestamp, NULL); + //evas_event_feed_mouse_up(sd->evas, 1, EVAS_BUTTON_NONE, ev->timestamp, NULL); e_fm_mouse_move_handler = ecore_event_handler_add(ECORE_X_EVENT_MOUSE_MOVE, _e_fm_win_mouse_move_cb, sd); @@ -2505,9 +2511,7 @@ evas_object_geometry_get(sd->drag.icon_obj->icon_obj, &x, &y, NULL, NULL); ecore_evas_move(sd->drag.ecore_evas, cx + x + ev->x - sd->drag.dx, cy + y + ev->y - sd->drag.dy); - if(!ecore_evas_visibility_get(sd->drag.ecore_evas)) - ecore_evas_show(sd->drag.ecore_evas); - + return 1; } @@ -2518,6 +2522,8 @@ E_Fm_Smart_Data *sd; sd = data; + + e_fm_icon_signal_emit(sd->drag.icon_obj->icon_obj, "dropped", ""); ecore_x_dnd_drop(); @@ -2527,8 +2533,7 @@ ecore_event_handler_del(e_fm_mouse_move_handler); e_fm_mouse_move_handler = NULL; - ecore_evas_free(sd->drag.ecore_evas); - sd->drag.ecore_evas = NULL; + ecore_evas_hide(sd->drag.ecore_evas); sd->drag.start = 0; @@ -3229,8 +3234,13 @@ if (ev->win != sd->win->evas_win) return 1; printf("enter\n"); - if(evas_object_visible_get(sd->drag.icon_obj->icon_obj)) - evas_object_hide(sd->drag.icon_obj->icon_obj); + /*if (ev->win == sd->drag->evas_win) + { + + e_fm_icon_signal_emit(icon->icon_obj, "default", ""); + }*/ + /*if(evas_object_visible_get(sd->drag.icon_obj->icon_obj)) + evas_object_hide(sd->drag.icon_obj->icon_obj);*/ return 1; } @@ -3294,9 +3304,13 @@ ev = event; sd = data; - evas_object_show(sd->drag.icon_obj->icon_obj); + //evas_object_show(sd->drag.icon_obj->icon_obj); - if (ev->win != sd->win->evas_win) return 1; + if (ev->win != sd->win->evas_win) + { + printf("drop different\n"); + return 1; + } printf("drop same\n"); ------------------------------------------------------- This SF.net email is sponsored by: Splunk Inc. Do you grep through log files for problems? Stop! Download the new AJAX search engine that makes searching your log files as easy as surfing the web. DOWNLOAD SPLUNK! http://sel.as-us.falkag.net/sel?cmd=lnk&kid=103432&bid=230486&dat=121642 _______________________________________________ enlightenment-cvs mailing list enlightenment-cvs@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/enlightenment-cvs