raster pushed a commit to branch master.

http://git.enlightenment.org/core/elementary.git/commit/?id=91282a22cba66ee5e7799018d3abe8957fb1b1fa

commit 91282a22cba66ee5e7799018d3abe8957fb1b1fa
Author: Anand <anand...@samsung.com>
Date:   Tue Jul 22 15:56:16 2014 +0900

    genlist: Focus highlight when loop is enable
    
    Summary:
    This patch is dependent on D1193 and D1136.
    It will be pushed after D1193 and D1136 patch.
    
    Reviewers: singh.amitesh
    
    Differential Revision: https://phab.enlightenment.org/D1168
    
    Conflicts:
        src/lib/elm_genlist.c
---
 data/themes/edc/elm/focus.edc | 105 ++++++++++++++++++++++++++++++++++++------
 src/lib/elm_genlist.c         |  69 +++++++++++++++++++++------
 2 files changed, 145 insertions(+), 29 deletions(-)

diff --git a/data/themes/edc/elm/focus.edc b/data/themes/edc/elm/focus.edc
index 19d78cd..37a08b2 100644
--- a/data/themes/edc/elm/focus.edc
+++ b/data/themes/edc/elm/focus.edc
@@ -5,7 +5,7 @@ group { name: "elm/focus_highlight/top/default";
    script {
       public s_x, s_y, s_w, s_h; /* source */
       public difx, dify, difw, difh;
-      
+
       public animator1(val, Float:pos) {
          new x, y, w, h, dx, dy, dw, dh, Float:p;
          p = 1.0 - ((1.0 - pos) * (1.0 - pos) * (1.0 - pos));
@@ -19,16 +19,16 @@ group { name: "elm/focus_highlight/top/default";
          h = get_int(s_h) + dh;
          update_offset(x, y, w, h);
       }
-      
+
       public update_offset(x, y, w, h) {
          set_state_val(PART:"base", STATE_REL1_OFFSET, x, y);
          set_state_val(PART:"base", STATE_REL2_OFFSET, x + w, y + h);
       }
-      
+
       public message(Msg_Type:type, id, ...) {
          if ((type == MSG_INT_SET) && (id == 1)) {
             new x1, y1, w1, h1, x2, y2, w2, h2;
-            
+
             x1 = getarg(2);
             y1 = getarg(3);
             w1 = getarg(4);
@@ -37,7 +37,7 @@ group { name: "elm/focus_highlight/top/default";
             y2 = getarg(7);
             w2 = getarg(8);
             h2 = getarg(9);
-            
+
             set_int(s_x, x1);
             set_int(s_y, y1);
             set_int(s_w, w1);
@@ -46,31 +46,56 @@ group { name: "elm/focus_highlight/top/default";
             set_int(dify, y2 - y1);
             set_int(difw, w2 - w1);
             set_int(difh, h2 - h1);
-            
+
             custom_state(PART:"base", "default", 0.0);
             set_state_val(PART:"base", STATE_REL1, 0.0, 0.0);
             set_state_val(PART:"base", STATE_REL2, 0.0, 0.0);
             update_offset(x1, y1, w1, h1);
             set_state(PART:"base", "custom", 0.0);
-            
+
             anim(0.2, "animator1", 1);
          }
       }
    }
    parts {
-      part { name: "base"; type: SPACER;
+      part { name: "base"; type: RECT;
+         clip_to: "clip";
          description { state: "default" 0.0;
+            visible: 0;
+         }
+         description { state: "move_down" 0.0;
+            inherit: "default" 0.0;
+            rel1.relative: 0 1;
+            rel2.relative: 1 2;
+         }
+         description { state: "move_up" 0.0;
+            inherit: "default" 0.0;
+            rel1.relative: 0 -1;
+            rel2.relative: 1 0;
          }
       }
       part { name: "clip"; type: RECT;
-         description { state: "default" 0.0;
-            rel1.to: "glow";
-            rel2.to: "glow";
-            color: 255 255 255 0;
+         scale: 1;
+         description {
+            state: "default" 0.0;
+            color: 255 255 255 255;
+            rel1.relative: -1 -1;
+            rel2.relative: 2 2;
+         }
+         description { state: "move_down" 0.0;
+            inherit: "default" 0.0;
+            color: 0 0 0 0;
+         }
+         description { state: "move_up" 0.0;
+            inherit: "default" 0.0;
+            color: 0 0 0 0 ;
          }
          description { state: "visible" 0.0;
             inherit: "default" 0.0;
-            color: 255 255 255 255;
+         }
+         description { state: "invisible" 0.0;
+            inherit: "default" 0.0;
+            color: 255 255 255 0;
          }
       }
       part { name: "glow"; mouse_events: 0;
@@ -121,7 +146,7 @@ group { name: "elm/focus_highlight/top/default";
       }
       program {
          signal: "elm,action,focus,hide"; source: "elm";
-         action: STATE_SET "default" 0.0;
+         action: STATE_SET "invisible" 0.0;
          transition: DECELERATE 0.4;
          target: "clip";
          after: "stop2";
@@ -153,5 +178,57 @@ group { name: "elm/focus_highlight/top/default";
          action: STATE_SET "default" 0.0;
          target: "base";
       }
+      program { name: "move_down";
+         signal: "elm,action,focus,move,down";
+         source: "elm";
+         transition: LIN 0.3;
+         action: STATE_SET "move_down" 0.0;
+         target: "base";
+         target: "clip";
+         after: "move_down_end";
+      }
+      program { name: "move_down_end";
+         action: SIGNAL_EMIT "elm,focus,move,down,end" "elm";
+      }
+      program { name: "move_up";
+         signal: "elm,action,focus,move,up";
+         source: "elm";
+         transition: LIN 0.3;
+         action: STATE_SET "move_up" 0.0;
+         target: "base";
+         target: "clip";
+         after: "move_up_end";
+      }
+      program { name: "move_up_end";
+         action: SIGNAL_EMIT "elm,focus,move,up,end" "elm";
+      }
+      program { name: "move_home_from_up";
+         signal: "elm,action,focus,move,home,up";
+         source: "elm";
+         action: STATE_SET "move_up" 0.0;
+         target: "base";
+         target: "clip";
+         after: "move_home_from_up2";
+      }
+      program { name: "move_home_from_up2";
+         action: STATE_SET "default" 0.0;
+         transition: LIN 0.3;
+         target: "base";
+         target: "clip";
+      }
+      program { name: "move_home_from_down";
+         signal: "elm,action,focus,move,home,down";
+         source: "elm";
+         action: STATE_SET "move_down" 0.0;
+         target: "base";
+         target: "clip";
+         after: "move_home_from_down2";
+      }
+      program { name: "move_home_from_down2";
+         action: STATE_SET "default" 0.0;
+         transition: LIN 0.3;
+         target: "base";
+         target: "clip";
+      }
    }
 }
diff --git a/src/lib/elm_genlist.c b/src/lib/elm_genlist.c
index e874dc7..e33a8cf 100644
--- a/src/lib/elm_genlist.c
+++ b/src/lib/elm_genlist.c
@@ -2269,7 +2269,7 @@ _elm_genlist_pan_evas_object_smart_calculate(Eo *obj 
EINA_UNUSED, Elm_Genlist_Pa
    else if (sd->reorder_fast == -1)
       eo_do((sd)->obj, elm_interface_scrollable_content_region_show(vx, vy + 
10, vw, vh));
 
-   if (sd->focused_item)
+   if (sd->focused_item && !sd->item_loop_enable)
      _elm_widget_focus_highlight_start(psd->wobj);
 
    evas_event_thaw(evas_object_evas_get(obj));
@@ -5188,42 +5188,73 @@ _decorate_item_unset(Elm_Genlist_Data *sd)
 
 static void
 _elm_genlist_looping_up_cb(void *data,
-                          Evas_Object *obj EINA_UNUSED,
-                          const char *emission EINA_UNUSED,
-                          const char *source EINA_UNUSED)
+                           Evas_Object *obj EINA_UNUSED,
+                           const char *emission EINA_UNUSED,
+                           const char *source EINA_UNUSED)
 {
    Evas_Object *genlist = data;
 
    ELM_GENLIST_DATA_GET(genlist, sd);
 
    Elm_Object_Item *it = elm_genlist_last_item_get(genlist);
-   if (!_elm_config->item_select_on_focus_disable)
-     elm_genlist_item_selected_set(it, EINA_TRUE);
-   else
-     elm_object_item_focus_set(it, EINA_TRUE);
+
+   elm_genlist_item_show((Elm_Object_Item *)it, ELM_GENLIST_ITEM_SCROLLTO_IN);
+   _elm_widget_focus_highlight_signal_emit(genlist, 
"elm,action,focus,move,up", "elm");
    elm_layout_signal_emit(genlist, "elm,action,looping,up,end", "elm");
    sd->item_looping_on = EINA_FALSE;
 }
 
 static void
 _elm_genlist_looping_down_cb(void *data,
-                          Evas_Object *obj EINA_UNUSED,
-                          const char *emission EINA_UNUSED,
-                          const char *source EINA_UNUSED)
+                             Evas_Object *obj EINA_UNUSED,
+                             const char *emission EINA_UNUSED,
+                             const char *source EINA_UNUSED)
 {
    Evas_Object *genlist = data;
 
    ELM_GENLIST_DATA_GET(genlist, sd);
 
    Elm_Object_Item *it = elm_genlist_first_item_get(genlist);
-   if (!_elm_config->item_select_on_focus_disable)
-     elm_genlist_item_selected_set(it, EINA_TRUE);
-   else
-     elm_object_item_focus_set(it, EINA_TRUE);
+
+   elm_genlist_item_show((Elm_Object_Item *)it, ELM_GENLIST_ITEM_SCROLLTO_IN);
+   _elm_widget_focus_highlight_signal_emit(genlist, 
"elm,action,focus,move,down", "elm");
    elm_layout_signal_emit(genlist, "elm,action,looping,down,end", "elm");
    sd->item_looping_on = EINA_FALSE;
 }
 
+static void
+_elm_genlist_focus_highlight_move_down_end_cb(void *data,
+                                              Evas_Object *obj EINA_UNUSED,
+                                              const char *emission EINA_UNUSED,
+                                              const char *source EINA_UNUSED)
+{
+      Evas_Object *gl = data;
+      Elm_Gen_Item *it = (Elm_Gen_Item *)elm_genlist_first_item_get(gl);
+
+      if (!_elm_config->item_select_on_focus_disable)
+        elm_genlist_item_selected_set((Elm_Object_Item *)it, EINA_TRUE);
+      else
+        elm_object_item_focus_set((Elm_Object_Item *)it, EINA_TRUE);
+
+      _elm_widget_focus_highlight_signal_emit(gl, 
"elm,action,focus,move,home,up", "elm");
+}
+
+static void
+_elm_genlist_focus_highlight_move_up_end_cb(void *data,
+                                            Evas_Object *obj EINA_UNUSED,
+                                            const char *emission EINA_UNUSED,
+                                            const char *source EINA_UNUSED)
+{
+      Evas_Object *gl = data;
+      Elm_Gen_Item *it = (Elm_Gen_Item *)elm_genlist_last_item_get(gl);
+
+      if (!_elm_config->item_select_on_focus_disable)
+        elm_genlist_item_selected_set((Elm_Object_Item *)it, EINA_TRUE);
+      else
+        elm_object_item_focus_set((Elm_Object_Item *)it, EINA_TRUE);
+
+      _elm_widget_focus_highlight_signal_emit(gl, 
"elm,action,focus,move,home,down", "elm");
+}
 
 EOLIAN static void
 _elm_genlist_evas_object_smart_add(Eo *obj, Elm_Genlist_Data *priv)
@@ -7551,6 +7582,14 @@ _elm_genlist_elm_widget_focused_item_get(Eo *obj 
EINA_UNUSED, Elm_Genlist_Data *
 EOLIAN static void
 _elm_genlist_elm_widget_item_loop_enabled_set(Eo *obj EINA_UNUSED, 
Elm_Genlist_Data *sd, Eina_Bool enable)
 {
+   if (enable == EINA_TRUE)
+      {
+         _elm_widget_focus_highlight_signal_callback_add(obj, 
"elm,focus,move,down,end",
+                                                         "elm", 
_elm_genlist_focus_highlight_move_down_end_cb, obj);
+         _elm_widget_focus_highlight_signal_callback_add(obj, 
"elm,focus,move,up,end",
+                                                         "elm", 
_elm_genlist_focus_highlight_move_up_end_cb, obj);
+      }
+
    sd->item_loop_enable = !!enable;
 }
 

-- 


Reply via email to