[Gengrid] Fix gengrid item position update bug, when item is reordered or deleted.
authorSangHyeon Lee <sh10233.lee@samsung.com>
Thu, 15 May 2014 03:13:23 +0000 (12:13 +0900)
committerCarsten Haitzler (Rasterman) <raster@rasterman.com>
Thu, 15 May 2014 03:13:23 +0000 (12:13 +0900)
Summary:
When gengrid item is reordered or deleted, gengrid didn't update item's position.
         This Patch update item's position when item is placed. if middle of item deleted,
         every item after the deleted one, will re-postion on _item_place function, so they
         will be update there position well.

Test Plan:
modify test_gengrid grid_sel fuction to print there position. so when item selected,
           they print there position and it works fine both horizontal and vertical.

Reviewers: bluezery, seoz, raster

Reviewed By: raster

CC: Hermet, chinmaya061
Differential Revision: https://phab.enlightenment.org/D855

src/bin/test_gengrid.c
src/lib/elm_gengrid.c

index 5d58b5b..e34b42e 100644 (file)
@@ -275,7 +275,7 @@ grid_del(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED)
 static void
 grid_sel(void *data, Evas_Object *obj, void *event_info)
 {
-   printf("sel item data [%p] on grid obj [%p], pointer [%p]\n", data, obj, event_info);
+   printf("sel item data [%p] on grid obj [%p], pointer [%p], position [%d]\n", data, obj, event_info, elm_gengrid_item_index_get(event_info));
 }
 
 static void
index 8638a53..87e5005 100644 (file)
@@ -998,6 +998,7 @@ _item_place(Elm_Gen_Item *it,
    Eina_Bool was_realized;
    Elm_Gen_Item_Type *item;
    long items_count;
+   int item_pos;
 
    item = GG_IT(it);
    wsd = GG_IT(it)->wsd;
@@ -1040,6 +1041,12 @@ _item_place(Elm_Gen_Item *it,
         else
           tch = items_row * wsd->item_height;
         alignh = (vh - tch) * wsd->align_y;
+        item_pos = items_row * cx + cy + 1;
+        if (item_pos != it->position)
+          {
+             it->position = item_pos;
+             it->position_update = EINA_TRUE;
+          }
      }
    else
      {
@@ -1067,6 +1074,12 @@ _item_place(Elm_Gen_Item *it,
         else
           tcw = items_col * wsd->item_width;
         alignw = (vw - tcw) * wsd->align_x;
+        item_pos = cx + items_col * cy + 1;
+        if (item_pos != it->position)
+          {
+             it->position = item_pos;
+             it->position_update = EINA_TRUE;
+          }
      }
 
    if (it->group)