seoz pushed a commit to branch master.

commit d82053bdf07e0037085e62a7d1fcd085ce258a37
Author: Daniel Juyung Seo <[email protected]>
Date:   Mon Aug 26 19:55:21 2013 +0900

    gengrid: implement selectraise feature.
    
    Gengrid item will be raised on selection. This was implemented in genlist, 
list, and index.
---
 ChangeLog                    |  4 ++++
 NEWS                         |  1 +
 src/lib/elm_gengrid.c        | 30 ++++++++++++++++++++++++------
 src/lib/elm_widget_gengrid.h |  1 +
 4 files changed, 30 insertions(+), 6 deletions(-)

diff --git a/ChangeLog b/ChangeLog
index b1986a4..55722ef 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1573,3 +1573,7 @@
         applying themes more strictly if it tries to apply same theme. This
         increases the performance hugely in case that user applies a specific
         theme to the window object.
+
+2013-08-26  Daniel Juyung Seo (SeoZ)
+
+        * Gengrid: implement selectraise feature.
diff --git a/NEWS b/NEWS
index 92f42cf..bc866e6 100644
--- a/NEWS
+++ b/NEWS
@@ -83,6 +83,7 @@ Additions:
    * File Selector : Support elm_object_part_text_set() for the ok, cancel 
part to change the OK, Cancel button label.
    * Add _elm_access_object_get, deprecate _elm_access_info_get
    * Add elm_win_focus_highlight_animate_set/get().
+   * Add selectraise feature to gengrid.
 
 Improvements:
 
diff --git a/src/lib/elm_gengrid.c b/src/lib/elm_gengrid.c
index f263d8a..286ba35 100644
--- a/src/lib/elm_gengrid.c
+++ b/src/lib/elm_gengrid.c
@@ -292,17 +292,21 @@ static void
 _item_unselect(Elm_Gen_Item *it)
 {
    Elm_Gen_Item_Type *item = GG_IT(it);
+   Elm_Gengrid_Smart_Data *sd = item->wsd;
 
-   if ((it->generation < item->wsd->generation) || (!it->highlighted))
+   if ((it->generation < sd->generation) || (!it->highlighted))
      return;
 
    edje_object_signal_emit(VIEW(it), "elm,state,unselected", "elm");
    evas_object_smart_callback_call(WIDGET(it), SIG_UNHIGHLIGHTED, it);
+
+   evas_object_stack_below(VIEW(it), sd->stack);
+
    it->highlighted = EINA_FALSE;
    if (it->selected)
      {
         it->selected = EINA_FALSE;
-        item->wsd->selected = eina_list_remove(item->wsd->selected, it);
+        sd->selected = eina_list_remove(sd->selected, it);
         evas_object_smart_callback_call(WIDGET(it), SIG_UNSELECTED, it);
      }
 }
@@ -465,13 +469,21 @@ _long_press_cb(void *data)
 static void
 _item_highlight(Elm_Gen_Item *it)
 {
-   if ((GG_IT(it)->wsd->select_mode == ELM_OBJECT_SELECT_MODE_NONE)
-       || (!GG_IT(it)->wsd->highlight) || (it->highlighted) ||
-       (it->generation < GG_IT(it)->wsd->generation))
+   const char *selectraise = NULL;
+   Elm_Gengrid_Smart_Data *sd = GG_IT(it)->wsd;
+
+   if ((sd->select_mode == ELM_OBJECT_SELECT_MODE_NONE)
+       || (!sd->highlight) || (it->highlighted) ||
+       (it->generation < sd->generation))
      return;
 
    edje_object_signal_emit(VIEW(it), "elm,state,selected", "elm");
    evas_object_smart_callback_call(WIDGET(it), SIG_HIGHLIGHTED, it);
+
+   selectraise = edje_object_data_get(VIEW(it), "selectraise");
+   if ((selectraise) && (!strcmp(selectraise, "on")))
+     evas_object_stack_above(VIEW(it), sd->stack);
+
    it->highlighted = EINA_TRUE;
 }
 
@@ -747,6 +759,8 @@ _item_realize(Elm_Gen_Item *it)
             it->itc->item_style ? it->itc->item_style : "default");
    elm_widget_theme_object_set(WIDGET(it), VIEW(it), "gengrid", style,
                                elm_widget_style_get(WIDGET(it)));
+   evas_object_stack_below(VIEW(it), GG_IT(it)->wsd->stack);
+
    it->spacer =
      evas_object_rectangle_add(evas_object_evas_get(WIDGET(it)));
    evas_object_color_set(it->spacer, 0, 0, 0, 0);
@@ -2377,7 +2391,6 @@ _elm_gengrid_smart_add(Eo *obj, void *_pd, va_list *list 
EINA_UNUSED)
 {
    Eina_Bool bounce = _elm_config->thumbscroll_bounce_enable;
    Elm_Gengrid_Pan_Smart_Data *pan_data;
-
    Elm_Gengrid_Smart_Data *priv = _pd;
    Elm_Widget_Smart_Data *wd = eo_data_scope_get(obj, ELM_OBJ_WIDGET_CLASS);
 
@@ -2432,6 +2445,10 @@ _elm_gengrid_smart_add(Eo *obj, void *_pd, va_list *list 
EINA_UNUSED)
    pan_data->wobj = obj;
    pan_data->wsd = priv;
 
+   priv->stack = evas_object_rectangle_add(evas_object_evas_get(obj));
+   evas_object_smart_member_add(priv->stack, priv->pan_obj);
+   evas_object_raise(priv->stack);
+
    eo_do(obj, elm_scrollable_interface_extern_pan_set(priv->pan_obj));
 }
 
@@ -2444,6 +2461,7 @@ _elm_gengrid_smart_del(Eo *obj, void *_pd, va_list *list 
EINA_UNUSED)
    eo_unref(sd->pan_obj);
    evas_object_del(sd->pan_obj);
    sd->pan_obj = NULL;
+   ELM_SAFE_FREE(sd->stack, evas_object_del);
 
    if (sd->calc_job) ecore_job_del(sd->calc_job);
 
diff --git a/src/lib/elm_widget_gengrid.h b/src/lib/elm_widget_gengrid.h
index 0b5d0b9..5460193 100644
--- a/src/lib/elm_widget_gengrid.h
+++ b/src/lib/elm_widget_gengrid.h
@@ -25,6 +25,7 @@ struct _Elm_Gengrid_Smart_Data
    Evas_Object                          *hit_rect;
    Evas_Object                          *pan_obj;
    Evas_Object                          *obj; // the object itself
+   Evas_Object                          *stack; // stacking markers in pan for 
selectraise feature
 
    Eina_List                            *selected; /* a list of
                                                     * selected

-- 

------------------------------------------------------------------------------
Introducing Performance Central, a new site from SourceForge and 
AppDynamics. Performance Central is your source for news, insights, 
analysis and resources for efficient Application Performance Management. 
Visit us today!
http://pubads.g.doubleclick.net/gampad/clk?id=48897511&iu=/4140/ostg.clktrk

Reply via email to