[factory, list, store] merge upstream
[framework/uifw/elementary.git] / src / lib / elm_imageslider.c
index 4bed454..3f22bc2 100644 (file)
@@ -1,37 +1,25 @@
-/* 
-* 
-* vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2 
-*/
 #include <stdio.h>
 #include <math.h>
 #include <Elementary.h>
 #include "elm_priv.h"
 
-/**
-* @defgroup Imageslider Imageslider
-* @ingroup Elementary
-*
-* By flicking images on the screen, 
-* you can see the images in specific path.
-*/
-
 typedef struct _Widget_Data Widget_Data;
 
-#define ANI_STEP                       (14 * elm_scale_get())
-#define ANI_TIME                       (0.005)
-#define ANI_TIME_MSEC          (12)
-#define CLICK_TIME_MAX         (180)
-#define CLICK_WIDTH_MIN                (elm_finger_size_get() >> 1)
-#define FLICK_TIME_MAX         (200)
-#define FLICK_WIDTH_MIN                (elm_finger_size_get() >> 2)
-#define MOVE_STEP                      (3)
-#define STEP_WEIGHT_DEF                (1)
-#define STEP_WEIGHT_MAX                (2)
-#define STEP_WEIGHT_MIN                (0)
-#define MOVING_IMAGE_SIZE      (128)
-#define MAX_ZOOM_SIZE          (6)
-#define INTERVAL_WIDTH         (15)
-#define MULTITOUCHDEVICE       (11)
+#define ANI_STEP (14 * elm_scale_get())
+#define ANI_TIME (0.005)
+#define ANI_TIME_MSEC (12)
+#define CLICK_TIME_MAX (180)
+#define CLICK_WIDTH_MIN (elm_finger_size_get() >> 1)
+#define FLICK_TIME_MAX (200)
+#define FLICK_WIDTH_MIN (elm_finger_size_get() >> 2)
+#define MOVE_STEP (3)
+#define STEP_WEIGHT_DEF (1)
+#define STEP_WEIGHT_MAX (2)
+#define STEP_WEIGHT_MIN (0)
+#define MOVING_IMAGE_SIZE (128)
+#define MAX_ZOOM_SIZE (6)
+#define INTERVAL_WIDTH (15)
+#define MULTITOUCHDEVICE (11)
 
 // Enumeration for layout.
 enum
@@ -49,9 +37,6 @@ struct _Imageslider_Item
    const char *photo_file;
    void (*func) (void *data, Evas_Object *obj, void *event_info);
    void *data;
-   Evas_Coord x, y, w, h;
-   Evas_Coord ox, oy, ow, oh;
-   int moving:1;
 };
 
 // Image Slider Widget Data.
@@ -76,45 +61,27 @@ struct _Widget_Data
    int move_cnt;
    int ani_lock:1;
    int moving:1;
-
-   Eina_Bool on_zoom:1;
-   Eina_Bool on_hold:1;
-   int dx, dy, mx, my;
-   int mdx, mdy, mmx, mmy;
-   int dratio;
-   int ratio;
 };
 
-// Global value definition.
+// Global value declaration.
 static const char *widtype = NULL;
 
 static const char SIG_CLICKED[] = "clicked";
 
-// Internal function definition.
+// Internal function declaration.
 static void _del_hook(Evas_Object *obj);
 
 static void _theme_hook(Evas_Object *obj);
 
 static void _sizing_eval(Evas_Object *obj);
 
-static void _imageslider_del_all(Widget_Data * wd);
-
-static void _imageslider_move(void *data, Evas * e, Evas_Object *obj,
-                             void *event_info);
-static void _imageslider_resize(void *data, Evas * e, Evas_Object *obj,
-                               void *event_info);
-static void _imageslider_show(void *data, Evas * e, Evas_Object *obj,
-                             void *event_info);
-static void _imageslider_hide(void *data, Evas * e, Evas_Object *obj,
-                             void *event_info);
+static void _imageslider_move(void *data, Evas * e, Evas_Object *obj, void *event_info);
+static void _imageslider_resize(void *data, Evas * e, Evas_Object *obj, void *event_info);
+static void _imageslider_show(void *data, Evas * e, Evas_Object *obj, void *event_info);
+static void _imageslider_hide(void *data, Evas * e, Evas_Object *obj, void *event_info);
 static void _imageslider_update(Widget_Data * wd);
 
-static void _imageslider_update_pos(Widget_Data * wd, Evas_Coord x,
-                                   Evas_Coord y, Evas_Coord w);
-static void _imageslider_update_center_pos(Widget_Data * wd, Evas_Coord x,
-                                          Evas_Coord my, Evas_Coord y,
-                                          Evas_Coord w);
-static Evas_Object *_imageslider_add_obj(Widget_Data * wd);
+static void _imageslider_update_pos(Widget_Data * wd, Evas_Coord x, Evas_Coord y, Evas_Coord w);
 
 static void _imageslider_obj_shift(Widget_Data * wd, Eina_Bool left);
 
@@ -124,84 +91,62 @@ static Eina_Bool _icon_to_image(void *data);
 
 static int _check_drag(int state, void *data);
 
-static void _check_zoom(void *data);
-
 static void _anim(Widget_Data * wd);
 
 static Eina_Bool _timer_cb(void *data);
 
-//static void _signal_clicked(void *data, Evas_Object *obj, const char *emission, const char *source);
-static void ev_imageslider_down_cb(void *data, Evas * e, Evas_Object *obj,
-                                  void *event_info);
-static void ev_imageslider_up_cb(void *data, Evas * e, Evas_Object *obj,
-                                void *event_info);
-static void ev_imageslider_move_cb(void *data, Evas * e, Evas_Object *obj,
-                                  void *event_info);
+static void _ev_imageslider_down_cb(void *data, Evas * e, Evas_Object *obj, void *event_info);
+static void _ev_imageslider_up_cb(void *data, Evas * e, Evas_Object *obj, void *event_info);
+static void _ev_imageslider_move_cb(void *data, Evas * e, Evas_Object *obj, void *event_info);
 
 // Whenever the Image Slider item is deleted, Call this funtion.
 static void
 _del_hook(Evas_Object *obj)
 {
-   int i;
-
    Widget_Data *wd;
 
    wd = elm_widget_data_get(obj);
 
-   if (!wd)
-      return;
-
-   for (i = 0; i < BLOCK_MAX; i++)
-     {
-       evas_object_del(wd->ly[i]);
-     }
+   if (!wd) return;
 
    if (wd->its)
      {
-       eina_list_free(wd->its);
-       wd->its = NULL;
+        eina_list_free(wd->its);
+        wd->its = NULL;
      }
 
    if (wd->queue_idler)
      {
-       ecore_idler_del(wd->queue_idler);
-       wd->queue_idler = NULL;
+        ecore_idler_del(wd->queue_idler);
+        wd->queue_idler = NULL;
      }
 
    if (wd->anim_timer)
      {
-       ecore_timer_del(wd->anim_timer);
-       wd->anim_timer = NULL;
+        ecore_timer_del(wd->anim_timer);
+        wd->anim_timer = NULL;
      }
 
-   if (wd)
-      free(wd);
-
+   if (wd) free(wd);
 }
 
 // Whenever require processing theme, Call this function
 static void
 _theme_hook(Evas_Object *obj)
 {
-   int i;
-
-   Widget_Data *wd;
-
-   wd = elm_widget_data_get(obj);
+   int i = 0;
+   Widget_Data *wd = elm_widget_data_get(obj);
 
-   if (!wd || !wd->ly)
-     {
-       return;
-     }
+   if (!wd) return;
 
    for (i = 0; i < BLOCK_MAX; i++)
      {
-       wd->ly[i] = elm_layout_add(obj);
-       _elm_theme_object_set(obj, wd->ly[i], "imageslider", "base", "default");
-       elm_widget_resize_object_set(obj, wd->ly[i]);
-       evas_object_show(wd->ly[i]);
+        if (wd->ly[i])
+           elm_layout_theme_set(wd->ly[i], "imageslider", "base",
+                                elm_object_style_get(obj));
+        evas_object_show(wd->ly[i]);
      }
-
+   _imageslider_update(wd);
    _sizing_eval(obj);
 }
 
@@ -214,48 +159,39 @@ _sizing_eval(Evas_Object *obj)
    Widget_Data *wd = elm_widget_data_get(obj);
 
    if (!wd)
-     {
-       return;
-     }
+     return;
 
    e = evas_object_evas_get(wd->obj);
 
    _imageslider_move(obj, e, obj, NULL);
    _imageslider_resize(obj, e, obj, NULL);
-
 }
 
 // Whenever MOVE event occurs, Call this function.
 static void
-_imageslider_move(void *data, Evas * e, Evas_Object *obj, void *event_info)
+_imageslider_move(void *data, Evas * e __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__)
 {
    Widget_Data *wd;
 
    Evas_Coord x, y;
 
    if (!data)
-     {
-       return;
-     }
+     return;
 
    wd = elm_widget_data_get((Evas_Object *) data);
    if (!wd)
-     {
-       return;
-     }
+     return;
 
    evas_object_geometry_get(obj, &x, &y, NULL, NULL);
    wd->x = x;
    wd->y = y;
-   evas_object_move(wd->clip, x, y);
 
    _imageslider_update_pos(wd, wd->x, wd->y, wd->w);
-
 }
 
 // Whenever RESIZE event occurs, Call this fucntion.
 static void
-_imageslider_resize(void *data, Evas * e, Evas_Object *obj, void *event_info)
+_imageslider_resize(void *data, Evas * e __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__)
 {
    int i;
 
@@ -264,147 +200,63 @@ _imageslider_resize(void *data, Evas * e, Evas_Object *obj, void *event_info)
    Evas_Coord w, h;
 
    if (!data)
-     {
-       return;
-     }
+     return;
 
    wd = elm_widget_data_get((Evas_Object *) data);
-   if (!wd || !wd->ly)
-     {
-       return;
-     }
+   if (!wd)
+     return;
 
    evas_object_geometry_get(obj, NULL, NULL, &w, &h);
-   fprintf(stderr, "%d %d -resize\n", w, h);
+   DBG("%d %d -resize\n", w, h);
    wd->w = w;
    wd->h = h;
 
    for (i = 0; i < BLOCK_MAX; i++)
      {
-       evas_object_resize(wd->ly[i], w, h);
+        evas_object_resize(wd->ly[i], w, h);
      }
 
-   evas_object_resize(wd->clip, w, h);
-
    _imageslider_update_pos(wd, wd->x, wd->y, wd->w);
 
 }
 
 // Whenever SHOW event occurs, Call this function.
 static void
-_imageslider_show(void *data, Evas * e, Evas_Object *obj, void *event_info)
+_imageslider_show(void *data, Evas * e __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
    Widget_Data *wd;
 
    if (!data)
      {
-       return;
+        return;
      }
 
    wd = elm_widget_data_get((Evas_Object *) data);
-   if (!wd)
-     {
-       return;
-     }
+   if (!wd) return;
 
    evas_object_show(wd->clip);
 }
 
 // Whenever HIDE event occurs, Call this function.
 static void
-_imageslider_hide(void *data, Evas * e, Evas_Object *obj, void *event_info)
+_imageslider_hide(void *data, Evas * e __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
    Widget_Data *wd;
 
-   if (!data)
-     {
-       return;
-     }
+   if (!data) return;
 
    wd = elm_widget_data_get((Evas_Object *) data);
-   if (!wd)
-     {
-       return;
-     }
+   if (!wd) return;
    evas_object_hide(wd->clip);
 }
 
-// Delete all Image Slider items.
-static void
-_imageslider_del_all(Widget_Data * wd)
-{
-
-   int i;
-
-   if (!wd)
-     {
-       return;
-     }
-
-   for (i = 0; i < BLOCK_MAX; i++)
-     {
-       evas_object_del(wd->ly[i]);
-     }
-}
-
 // Update Image Slider item position.
 static void
-_imageslider_update_pos(Widget_Data * wd, Evas_Coord x, Evas_Coord y,
-                       Evas_Coord w)
+_imageslider_update_pos(Widget_Data * wd, Evas_Coord x, Evas_Coord y, Evas_Coord w)
 {
    evas_object_move(wd->ly[BLOCK_LEFT], x - (w + INTERVAL_WIDTH), y);
    evas_object_move(wd->ly[BLOCK_CENTER], x, y);
    evas_object_move(wd->ly[BLOCK_RIGHT], x + (w + INTERVAL_WIDTH), y);
-   evas_render_idle_flush(evas_object_evas_get(wd->obj));
-}
-
-// Update the center position of Image Slider item.
-static void
-_imageslider_update_center_pos(Widget_Data * wd, Evas_Coord x, Evas_Coord my,
-                              Evas_Coord y, Evas_Coord w)
-{
-   Evas_Object *eo;
-
-   Evas_Coord ix, iy, iw, ih;
-
-   eo =
-      edje_object_part_swallow_get(elm_layout_edje_get(wd->ly[BLOCK_CENTER]),
-                                  "swl.photo");
-   evas_object_geometry_get(eo, &ix, &iy, &iw, &ih);
-
-   if ((ix > 0) || (ix + iw < wd->w))
-     {
-       edje_object_signal_emit(elm_layout_edje_get(wd->ly[BLOCK_CENTER]),
-                               "block.on", "block");
-       _imageslider_update_pos(wd, x, y, w);
-       wd->on_zoom = EINA_FALSE;
-     }
-}
-
-// Add previous/next Image Slider item.
-static Evas_Object *
-_imageslider_add_obj(Widget_Data * wd)
-{
-   Evas_Object *eo;
-
-   eo = elm_layout_add(wd->obj);
-   elm_layout_theme_set(eo, "imageslider", "base", "default");
-   elm_widget_resize_object_set(wd->obj, eo);
-   //evas_object_smart_member_add(eo, wd->obj);
-
-   //edje_object_signal_callback_add(elm_layout_edje_get(eo), "elm,photo,clicked", "", _signal_clicked, wd->obj);
-   evas_object_event_callback_add(eo, EVAS_CALLBACK_MOUSE_DOWN,
-                                 ev_imageslider_down_cb, wd);
-   evas_object_event_callback_add(eo, EVAS_CALLBACK_MOUSE_UP,
-                                 ev_imageslider_up_cb, wd);
-   evas_object_event_callback_add(eo, EVAS_CALLBACK_MOUSE_MOVE,
-                                 ev_imageslider_move_cb, wd);
-   evas_object_resize(eo, wd->w, wd->h);
-   evas_object_move(eo, wd->w + INTERVAL_WIDTH, wd->y);
-   evas_object_clip_set(eo, wd->clip);
-   evas_object_show(eo);
-
-   return eo;
 }
 
 // Shift next/previous Image Slider item in layouts.
@@ -413,27 +265,21 @@ _imageslider_obj_shift(Widget_Data * wd, Eina_Bool left)
 {
    if (!left)
      {
-       if (wd->ly[BLOCK_LEFT])
-         {
-            evas_object_del(wd->ly[BLOCK_LEFT]);
-            wd->ly[BLOCK_LEFT] = NULL;
-         }
-
-       wd->ly[BLOCK_LEFT] = wd->ly[BLOCK_CENTER];
-       wd->ly[BLOCK_CENTER] = wd->ly[BLOCK_RIGHT];
-       wd->ly[BLOCK_RIGHT] = _imageslider_add_obj(wd);
+        Evas_Object *ly_temp;
+        ly_temp = wd->ly[BLOCK_LEFT];
+        wd->ly[BLOCK_LEFT] = wd->ly[BLOCK_CENTER];
+        wd->ly[BLOCK_CENTER] = wd->ly[BLOCK_RIGHT];
+        wd->ly[BLOCK_RIGHT] = ly_temp;
+        elm_object_part_content_set(wd->ly[BLOCK_RIGHT], "swl.photo", NULL);
      }
    else
      {
-       if (wd->ly[BLOCK_RIGHT])
-         {
-            evas_object_del(wd->ly[BLOCK_RIGHT]);
-            wd->ly[BLOCK_RIGHT] = NULL;
-         }
-
-       wd->ly[BLOCK_RIGHT] = wd->ly[BLOCK_CENTER];
-       wd->ly[BLOCK_CENTER] = wd->ly[BLOCK_LEFT];
-       wd->ly[BLOCK_LEFT] = _imageslider_add_obj(wd);
+        Evas_Object *ly_temp;
+        ly_temp = wd->ly[BLOCK_RIGHT];
+        wd->ly[BLOCK_RIGHT] = wd->ly[BLOCK_CENTER];
+        wd->ly[BLOCK_CENTER] = wd->ly[BLOCK_LEFT];
+        wd->ly[BLOCK_LEFT] = ly_temp;
+        elm_object_part_content_set(wd->ly[BLOCK_LEFT], "swl.photo", NULL);
      }
 }
 
@@ -443,43 +289,43 @@ _imageslider_obj_move(Widget_Data * wd, Evas_Coord step)
 {
    if (step > 0)
      {
-       wd->cur = eina_list_next(wd->cur);
-       if (wd->cur == NULL)
-         {
-            wd->cur = eina_list_last(wd->its);
-            wd->step = ANI_STEP;
-         }
-       else
-         {
-            wd->step = -ANI_STEP;
-            wd->move_x += wd->w;
-            _imageslider_obj_shift(wd, 0);
-         }
-       wd->moving = 1;
+        wd->cur = eina_list_next(wd->cur);
+        if (wd->cur == NULL)
+          {
+             wd->cur = eina_list_last(wd->its);
+             wd->step = ANI_STEP;
+          }
+        else
+          {
+             wd->step = -ANI_STEP;
+             wd->move_x += wd->w;
+             _imageslider_obj_shift(wd, EINA_FALSE);
+          }
+        wd->moving = EINA_TRUE;
      }
    else if (step < 0)
      {
-       wd->cur = eina_list_prev(wd->cur);
-       if (wd->cur == NULL)
-         {
-            wd->cur = wd->its;
-            wd->step = -ANI_STEP;
-         }
-       else
-         {
-            wd->step = ANI_STEP;
-            wd->move_x -= wd->w;
-            _imageslider_obj_shift(wd, 1);
-         }
-       wd->moving = 1;
+        wd->cur = eina_list_prev(wd->cur);
+        if (wd->cur == NULL)
+          {
+             wd->cur = wd->its;
+             wd->step = -ANI_STEP;
+          }
+        else
+          {
+             wd->step = ANI_STEP;
+             wd->move_x -= wd->w;
+             _imageslider_obj_shift(wd, EINA_TRUE);
+          }
+        wd->moving = EINA_TRUE;
      }
    else
      {
-       if (wd->move_x < 0)
-          wd->step = ANI_STEP;
-       else
-          wd->step = -ANI_STEP;
-       wd->moving = 0;
+        if (wd->move_x < 0)
+          wd->step = ANI_STEP;
+        else
+          wd->step = -ANI_STEP;
+        wd->moving = EINA_FALSE;
      }
 
    _imageslider_update(wd);
@@ -487,49 +333,23 @@ _imageslider_obj_move(Widget_Data * wd, Evas_Coord step)
 
 // Whenever MOUSE DOWN event occurs, Call this function.
 static void
-ev_imageslider_down_cb(void *data, Evas * e, Evas_Object *obj,
-                      void *event_info)
+_ev_imageslider_down_cb(void *data, Evas * e __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info)
 {
    Widget_Data *wd = data;
-
    Evas_Event_Mouse_Down *ev = event_info;
 
-   Evas_Coord ix, iy, iw, ih;
-
-   Evas_Object *eo = NULL;
-
    if (wd->ani_lock)
       return;
 
    wd->down_pos = ev->canvas;
    wd->timestamp = ev->timestamp;
    wd->move_cnt = MOVE_STEP;
-
-   wd->dx = ev->canvas.x;
-   wd->dy = ev->canvas.y;
-   wd->mx = ev->canvas.x;
-   wd->my = ev->canvas.y;
-
-   wd->dratio = 1;
-   wd->ratio = 1;
-
-   eo = edje_object_part_swallow_get(elm_layout_edje_get(obj), "swl.photo");
-   if (eo)
-      evas_object_geometry_get(eo, &ix, &iy, &iw, &ih);
-
-   if (iw != wd->w)
-     {
-       wd->on_zoom = EINA_TRUE;
-       edje_object_signal_emit(elm_layout_edje_get(obj), "block.off", "block");
-//              edje_thaw();            
-     }
-
 }
 
 // Whenever MOUSE UP event occurs, Call this function.
 // And make Click Event also.
 static void
-ev_imageslider_up_cb(void *data, Evas * e, Evas_Object *obj, void *event_info)
+_ev_imageslider_up_cb(void *data, Evas * e __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info)
 {
    Widget_Data *wd = data;
 
@@ -539,171 +359,89 @@ ev_imageslider_up_cb(void *data, Evas * e, Evas_Object *obj, void *event_info)
 
    int interval;
 
-   if (wd->ani_lock)
-      return;
+   if (wd->ani_lock) return;
 
-   if (wd->on_zoom)
+   step = wd->down_pos.x - ev->canvas.x;
+   interval = ev->timestamp - wd->timestamp;
+   if (step == 0 || interval == 0)
      {
+        DBG("case1: emit CLICK event\n");
+        evas_object_smart_callback_call(wd->obj, SIG_CLICKED, NULL);
+        return;
      }
-   else
+   if (interval < CLICK_TIME_MAX)
      {
-       step = wd->down_pos.x - ev->canvas.x;
-       interval = ev->timestamp - wd->timestamp;
-       if (step == 0 || interval == 0)
-         {
-            fprintf(stderr, "[[[ DEBUG ]]]: case1: emit CLICK event\n");
-            evas_object_smart_callback_call(wd->obj, SIG_CLICKED, NULL);
-            return;
-         }
-       if (interval < CLICK_TIME_MAX)
-         {
-            if (step < CLICK_WIDTH_MIN && step > CLICK_WIDTH_MIN)
-              {
-                 fprintf(stderr, "[[[ DEBUG ]]]: case2: emit CLICK event\n");
-                 evas_object_smart_callback_call(wd->obj, SIG_CLICKED, NULL);
-                 return;
-              }
-         }
-
-       if (interval < FLICK_TIME_MAX)
-         {
-
-            if (step < FLICK_WIDTH_MIN && step > FLICK_WIDTH_MIN)
-              {
-                 fprintf(stderr,
-                         "[[[ DEBUG ]]]:ev_imageslider_up_cb-black zone (1)\n");
-
-                 _imageslider_obj_move(wd, 0);
-              }
-            else
-              {
-                 fprintf(stderr,
-                         "[[[ DEBUG ]]]:ev_imageslider_up_cb-black zone (2)\n");
-
-                 _imageslider_obj_move(wd, step);
-              }
-
-         }
-       else
-         {
-            step = (wd->x - wd->move_x) << 1;
-            if (step <= wd->w && step >= -(wd->w))
-              {
-                 fprintf(stderr,
-                         "[[[ DEBUG ]]]:ev_imageslider_up_cb-white zone (1)\n");
-
-                 _imageslider_obj_move(wd, 0);
-              }
-            else
-              {
-                 fprintf(stderr,
-                         "[[[ DEBUG ]]]:ev_imageslider_up_cb-white zone (2)\n");
-
-                 _imageslider_obj_move(wd, step);
-              }
-         }
+        if (step < CLICK_WIDTH_MIN && step > CLICK_WIDTH_MIN)
+          {
+             DBG("case2: emit CLICK event\n");
+             evas_object_smart_callback_call(wd->obj, SIG_CLICKED, NULL);
+             return;
+          }
      }
 
+   if (interval < FLICK_TIME_MAX)
+     {
+        if (step < FLICK_WIDTH_MIN && step > FLICK_WIDTH_MIN)
+          {
+             DBG("ev_imageslider_up_cb-black zone (1)\n");
+
+             _imageslider_obj_move(wd, 0);
+          }
+        else
+          {
+             DBG("ev_imageslider_up_cb-black zone (2)\n");
+
+             _imageslider_obj_move(wd, step);
+          }
+
+     }
+   else
+     {
+        step = (wd->x - wd->move_x) << 1;
+        if (step <= wd->w && step >= -(wd->w))
+          {
+             DBG("ev_imageslider_up_cb-white zone (1)\n");
+
+             _imageslider_obj_move(wd, 0);
+          }
+        else
+          {
+             DBG("ev_imageslider_up_cb-white zone (2)\n");
+
+             _imageslider_obj_move(wd, step);
+          }
+     }
 }
 
-// Whenever MOUSE MOVE event occurs, Call this API.
+// Whenever MOUSE MOVE event occurs, Call this
 static void
-ev_imageslider_move_cb(void *data, Evas * e, Evas_Object *obj,
-                      void *event_info)
+_ev_imageslider_move_cb(void *data, Evas * e __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info)
 {
-   int idx;
-
-   Evas_Object *eo;
-
+   int idx = 0;
    Evas_Coord step;
-
    Widget_Data *wd = data;
-
    Evas_Event_Mouse_Move *ev = event_info;
 
-   Elm_Imageslider_Item *it;
-
-   if (wd->ani_lock)
-      return;
-
+   if (wd->ani_lock) return;
    if (wd->move_cnt == MOVE_STEP)
      {
-       if (wd->on_hold == EINA_FALSE)
-         {
-            wd->move_cnt = 0;
-
-            if (ev->buttons)
-              {
-                 step = ev->cur.canvas.x - wd->down_pos.x;
-                 if (step > 0)
-                    idx = BLOCK_LEFT;
-                 else
-                    idx = BLOCK_RIGHT;
-
-                 wd->move_x = wd->x + ((ev->cur.canvas.x - wd->down_pos.x));
-                 wd->move_y = wd->y + ((ev->cur.canvas.y - wd->down_pos.y));
-
-                 if (wd->on_zoom)
-                   {
-                      _imageslider_update_center_pos(wd, wd->move_x,
-                                                     wd->move_y, wd->y, wd->w);
-                   }
-                 else
-                   {
-                      _imageslider_update_pos(wd, wd->move_x, wd->y, wd->w);
-                   }
-              }
-         }
-       else
-         {
-            wd->mx = ev->cur.canvas.x;
-            wd->my = ev->cur.canvas.y;
-
-            wd->ratio =
-               sqrt((wd->mx - wd->mmx) * (wd->mx - wd->mmx) +
-                    (wd->my - wd->mmy) * (wd->my - wd->mmy));
-
-            eo =
-               edje_object_part_swallow_get(elm_layout_edje_get(obj),
-                                            "swl.photo");
-            if (eo)
-              {
-                 it = eina_list_data_get(wd->cur);
-                 if (((it->w * wd->ratio / wd->dratio) / it->ow) <
-                     MAX_ZOOM_SIZE)
-                   {
-                      edje_object_part_unswallow(elm_layout_edje_get(obj), eo);
-                      evas_object_resize(eo, it->w * wd->ratio / wd->dratio,
-                                         it->h * wd->ratio / wd->dratio);
-                      evas_object_size_hint_min_set(eo,
-                                                    it->w * wd->ratio /
-                                                    wd->dratio,
-                                                    it->h * wd->ratio /
-                                                    wd->dratio);
-                      edje_object_part_swallow(elm_layout_edje_get(obj),
-                                               "swl.photo", eo);
-                   }
-              }
-         }
-     }
+        wd->move_cnt = 0;
 
+        if (ev->buttons)
+          {
+             step = ev->cur.canvas.x - wd->down_pos.x;
+             if (step > 0)
+               idx = BLOCK_LEFT;
+             else
+               idx = BLOCK_RIGHT;
+             wd->move_x = wd->x + ((ev->cur.canvas.x - wd->down_pos.x));
+             wd->move_y = wd->y + ((ev->cur.canvas.y - wd->down_pos.y));
+             _imageslider_update_pos(wd, wd->move_x, wd->y, wd->w);
+          }
+     }
    wd->move_cnt++;
-
 }
 
-#if 0
-// Whenever CLICK event occurs, Call this API
-// But, DONOT emit CLICK event.
-// DO NOT use this callback function. Remove later.
-static void
-_signal_clicked(void *data, Evas_Object *obj, const char *emission,
-               const char *source)
-{
-   fprintf(stderr,
-          "[[[ DEBUG ]]]: Call the callback function about Click event!, But DONOT emit CLICK event in the callback function!\n");
-}
-#endif
-
 static inline double
 time_get(Evas_Coord x, Evas_Coord w)
 {
@@ -726,10 +464,7 @@ _icon_to_image(void *data)
    _imageslider_update(wd);
 
    if (wd->queue_idler)
-     {
-       ecore_idler_del(wd->queue_idler);
-       wd->queue_idler = NULL;
-     }
+     wd->queue_idler = NULL;
    return ECORE_CALLBACK_CANCEL;
 }
 
@@ -740,9 +475,9 @@ _check_drag(int state, void *data)
 
    Elm_Imageslider_Item *it;
 
-   Evas_Coord ix, iy, iw, ih;
+   Evas_Coord ix = 0, iy = 0, iw = 0, ih = 0;
 
-   double dx, dy = 0;
+   double dx = 0, dy = 0;
 
    Eina_List *l[BLOCK_MAX];
 
@@ -754,72 +489,21 @@ _check_drag(int state, void *data)
 
    it = eina_list_data_get(l[state]);
 
-   eo =
-      edje_object_part_swallow_get(elm_layout_edje_get(wd->ly[state]),
-                                  "swl.photo");
+   eo = elm_object_part_content_get(wd->ly[state], "swl.photo");
    if (eo)
-      evas_object_geometry_get(eo, &ix, &iy, &iw, &ih);
-   evas_object_geometry_get(eo, &ix, &iy, &iw, &ih);
-   edje_object_part_drag_value_get(elm_layout_edje_get(wd->ly[state]),
-                                  "swl.photo", &dx, &dy);
+     evas_object_geometry_get(eo, &ix, &iy, &iw, &ih);
+   edje_object_part_drag_value_get(elm_layout_edje_get(wd->ly[state]), "swl.photo", &dx, &dy);
 
    if ((iw != wd->w) || ((dx != 0) || (dy != 0)))
      {
-       if (wd->ly[state])
-         {
-            evas_object_del(wd->ly[state]);
-            wd->ly[state] = NULL;
-         }
-       wd->ly[state] = _imageslider_add_obj(wd);
+        elm_object_part_content_set(wd->ly[state], "swl.photo", NULL);
      }
    else
-     {
-       return 1;
-     }
+     return 1;
 
    return 0;
 }
 
-static void
-_check_zoom(void *data)
-{
-   Widget_Data *wd = data;
-
-   Elm_Imageslider_Item *it;
-
-   Evas_Coord ix, iy, iw, ih;
-
-   double dx, dy = 0;
-
-   Evas_Object *eo = NULL;
-
-   it = eina_list_data_get(wd->cur);
-
-   eo =
-      edje_object_part_swallow_get(elm_layout_edje_get(wd->ly[BLOCK_CENTER]),
-                                  "swl.photo");
-   if (eo)
-      evas_object_geometry_get(eo, &ix, &iy, &iw, &ih);
-   evas_object_geometry_get(eo, &ix, &iy, &iw, &ih);
-   edje_object_part_drag_value_get(elm_layout_edje_get(wd->ly[BLOCK_CENTER]),
-                                  "swl.photo", &dx, &dy);
-
-   if ((iw != wd->w) || ((dx != 0) || (dy != 0)))
-     {
-       wd->on_zoom = EINA_TRUE;
-       edje_object_signal_emit(elm_layout_edje_get(wd->ly[BLOCK_CENTER]),
-                               "block.off", "block");
-//              edje_thaw();
-     }
-   else
-     {
-       wd->on_zoom = EINA_FALSE;
-       edje_object_signal_emit(elm_layout_edje_get(wd->ly[BLOCK_CENTER]),
-                               "block.on", "block");
-//              edje_freeze();
-     }
-}
-
 static Eina_Bool
 _timer_cb(void *data)
 {
@@ -829,64 +513,61 @@ _timer_cb(void *data)
 
    struct timeval tv;
 
-   int t;
-
-   int ret;
+   int t = 0;
+   int ret = 0;
 
    wd = data;
-   if (wd->ani_lock == 0)
-      return 0;
-
+   if (!wd->ani_lock)
+     {
+        if (wd->anim_timer)
+          wd->anim_timer = NULL;
+        return ECORE_CALLBACK_CANCEL;
+     }
    gettimeofday(&tv, NULL);
 
-   t = (tv.tv_sec - wd->tv.tv_sec) * 1000 + (tv.tv_usec -
-                                            wd->tv.tv_usec) / 1000;
+   t = (tv.tv_sec - wd->tv.tv_sec) * 1000 + (tv.tv_usec - wd->tv.tv_usec) / 1000;
    gettimeofday(&wd->tv, NULL);
 
    t = t / ANI_TIME_MSEC;
    if (t <= STEP_WEIGHT_MIN)
-      t = STEP_WEIGHT_DEF;
+     t = STEP_WEIGHT_DEF;
    else if (t > STEP_WEIGHT_MAX)
-      t = STEP_WEIGHT_MAX;
+     t = STEP_WEIGHT_MAX;
 
    wd->move_x += (wd->step) * t;
 
    if (wd->step < 0 && wd->move_x < wd->x)
-      wd->move_x = wd->x;
+     wd->move_x = wd->x;
    else if (wd->step > 0 && wd->move_x > wd->x)
-      wd->move_x = wd->x;
+     wd->move_x = wd->x;
 
    _imageslider_update_pos(wd, wd->move_x, wd->y, wd->w);
 
    if (wd->move_x == wd->x)
      {
-       wd->ani_lock = 0;
-       if (wd->cur)
-         {
-            it = eina_list_data_get(wd->cur);
-            if (it->func)
-               it->func(it->data, wd->obj, it);
-         }
-       if (wd->cur)
-         {
-            it = eina_list_data_get(wd->cur);
-            evas_object_smart_callback_call(wd->obj, "changed", it);
-         }
-
-       ret = _check_drag(BLOCK_LEFT, wd);
-       ret = _check_drag(BLOCK_RIGHT, wd);
-       _check_zoom(wd);
-
-       if (!wd->queue_idler)
-          wd->queue_idler = ecore_idler_add(_icon_to_image, wd);
-
-       if (wd->anim_timer)
-         {
-            ecore_timer_del(wd->anim_timer);
-            wd->anim_timer = NULL;
-         }
-
-       return ECORE_CALLBACK_CANCEL;
+        wd->ani_lock = EINA_FALSE;
+        if (wd->cur)
+          {
+             it = eina_list_data_get(wd->cur);
+             if (it->func)
+               it->func(it->data, wd->obj, it);
+          }
+        if (wd->cur)
+          {
+             it = eina_list_data_get(wd->cur);
+             evas_object_smart_callback_call(wd->obj, "changed", it);
+          }
+
+        ret = _check_drag(BLOCK_LEFT, wd);
+        ret = _check_drag(BLOCK_RIGHT, wd);
+
+        if (!wd->queue_idler)
+          wd->queue_idler = ecore_idler_add(_icon_to_image, wd);
+
+        if (wd->anim_timer)
+          wd->anim_timer = NULL;
+
+        return ECORE_CALLBACK_CANCEL;
      }
 
    return ECORE_CALLBACK_RENEW;
@@ -899,19 +580,17 @@ _anim(Widget_Data * wd)
 
    if (wd->x == wd->move_x)
      {
-       _imageslider_update_pos(wd, wd->move_x, wd->y, wd->w);
-       return;
+        _imageslider_update_pos(wd, wd->move_x, wd->y, wd->w);
+        return;
      }
 
-   wd->ani_lock = 1;
+   wd->ani_lock = EINA_TRUE;
 
    w = wd->move_x;
    gettimeofday(&wd->tv, NULL);
 
    if (!wd->anim_timer)
-     {
-       wd->anim_timer = ecore_timer_add(ANI_TIME, _timer_cb, wd);
-     }
+     wd->anim_timer = ecore_timer_add(ANI_TIME, _timer_cb, wd);
 }
 
 // Update Image Slider Items.
@@ -926,16 +605,9 @@ _imageslider_update(Widget_Data * wd)
 
    Evas_Object *eo;
 
-   if (!wd)
-     {
-       return;
-     }
+   if (!wd) return;
 
-   if (!wd->cur)
-     {
-       _imageslider_del_all(wd);
-       return;
-     }
+   if (!wd->cur) return;
 
    l[BLOCK_LEFT] = eina_list_prev(wd->cur);
    l[BLOCK_CENTER] = wd->cur;
@@ -943,143 +615,77 @@ _imageslider_update(Widget_Data * wd)
 
    for (i = 0; i < BLOCK_MAX; i++)
      {
-       eo =
-          edje_object_part_swallow_get(elm_layout_edje_get(wd->ly[i]),
-                                       "swl.photo");
-       if (!l[i])
-         {
-            elm_layout_content_set(wd->ly[i], "swl.photo", NULL);
-            evas_object_del(eo);
-         }
-       else
-         {
-            it = eina_list_data_get(l[i]);
-            if (!it)
-               return;
-
-            if (!eo)
-              {
-                 eo = elm_image_add(wd->obj);
-                 elm_layout_content_set(wd->ly[i], "swl.photo", eo);
-                 elm_image_prescale_set(eo, wd->w);
-                 elm_image_file_set(eo, it->photo_file, NULL);
-                 elm_image_object_size_get(eo, &it->w, &it->h);
-                 evas_object_geometry_get(eo, &it->ox, &it->oy, &it->ow,
-                                          &it->oh);
-                 it->ow = it->w;
-                 it->oh = it->h;
-              }
-
-            if (wd->moving != it->moving)
-              {
-                 it->moving = wd->moving;
-                 if (wd->moving)
-                   {
-                      elm_image_prescale_set(eo, MOVING_IMAGE_SIZE);
-                   }
-                 else
-                   {
-                      elm_image_prescale_set(eo,
-                                             it->w > it->h ? it->w : it->h);
-                   }
-              }
-         }
+        eo = elm_object_part_content_get((const Evas_Object*)wd->ly[i], "swl.photo");
+        if (!l[i])
+          {
+             elm_object_part_content_set(wd->ly[i], "swl.photo", NULL);
+          }
+        else
+          {
+             it = eina_list_data_get(l[i]);
+             if (!it)
+               return;
+
+             if (!eo)
+               {
+                  eo = elm_image_add(wd->obj);
+                  //elm_image_prescale_set(eo, wd->w);
+                  elm_image_file_set(eo, it->photo_file, NULL);
+                  elm_object_part_content_set(wd->ly[i], "swl.photo", eo);
+               }
+          }
      }
-
    _anim(wd);
-
 }
 
-/** 
-* Add an Image Slider widget 
-* 
-* @param       parent  The parent object 
-* @return      The new Image slider object or NULL if it cannot be created 
-* 
-* @ingroup Imageslider 
-*/
 EAPI Evas_Object *
 elm_imageslider_add(Evas_Object *parent)
 {
    int i;
 
-   Evas_Object *obj = NULL;
-
-   Widget_Data *wd = NULL;
-
+   Evas_Object *obj;
    Evas *e;
+   Widget_Data *wd;
 
-   if (!parent)
-     {
-       return NULL;
-     }
-
-   wd = ELM_NEW(Widget_Data);
-   e = evas_object_evas_get(parent);
-   if (e == NULL)
-     {
-       return NULL;
-     }
+   ELM_WIDGET_STANDARD_SETUP(wd, Widget_Data, parent, e, obj, NULL);
 
-   obj = elm_widget_add(e);
    ELM_SET_WIDTYPE(widtype, "imageslider");
    elm_widget_type_set(obj, "imageslider");
    elm_widget_sub_object_add(parent, obj);
    elm_widget_data_set(obj, wd);
-   //wd->parent = parent;
    elm_widget_del_hook_set(obj, _del_hook);
    elm_widget_theme_hook_set(obj, _theme_hook);
 
    wd->clip = evas_object_rectangle_add(e);
+   elm_widget_sub_object_add(obj, wd->clip);
+   elm_widget_resize_object_set(obj, wd->clip);
 
    for (i = 0; i < BLOCK_MAX; i++)
      {
-       wd->ly[i] = elm_layout_add(obj);
-       elm_layout_theme_set(wd->ly[i], "imageslider", "base", "default");
-       elm_widget_resize_object_set(obj, wd->ly[i]);
-       evas_object_smart_member_add(wd->ly[i], obj);
-
-       //edje_object_signal_callback_add(elm_layout_edje_get(wd->ly[i]), "elm,photo,clicked", "", _signal_clicked, obj);
-       evas_object_event_callback_add(wd->ly[i], EVAS_CALLBACK_MOUSE_DOWN,
-                                      ev_imageslider_down_cb, wd);
-       evas_object_event_callback_add(wd->ly[i], EVAS_CALLBACK_MOUSE_UP,
-                                      ev_imageslider_up_cb, wd);
-       evas_object_event_callback_add(wd->ly[i], EVAS_CALLBACK_MOUSE_MOVE,
-                                      ev_imageslider_move_cb, wd);
-       evas_object_clip_set(wd->ly[i], wd->clip);
-       evas_object_show(wd->ly[i]);
+        wd->ly[i] = elm_layout_add(obj);
+        elm_layout_theme_set(wd->ly[i], "imageslider", "base", "default");
+        elm_widget_sub_object_add(obj, wd->ly[i]);
+        evas_object_smart_member_add(wd->ly[i], obj);
+
+        evas_object_event_callback_add(wd->ly[i], EVAS_CALLBACK_MOUSE_DOWN, _ev_imageslider_down_cb, wd);
+        evas_object_event_callback_add(wd->ly[i], EVAS_CALLBACK_MOUSE_UP, _ev_imageslider_up_cb, wd);
+        evas_object_event_callback_add(wd->ly[i], EVAS_CALLBACK_MOUSE_MOVE, _ev_imageslider_move_cb, wd);
+        evas_object_clip_set(wd->ly[i], wd->clip);
+        evas_object_show(wd->ly[i]);
      }
 
    wd->obj = obj;
-
-   evas_object_event_callback_add(obj, EVAS_CALLBACK_RESIZE,
-                                 _imageslider_resize, obj);
-   evas_object_event_callback_add(obj, EVAS_CALLBACK_MOVE, _imageslider_move,
-                                 obj);
-   evas_object_event_callback_add(obj, EVAS_CALLBACK_SHOW, _imageslider_show,
-                                 obj);
-   evas_object_event_callback_add(obj, EVAS_CALLBACK_HIDE, _imageslider_hide,
-                                 obj);
+   evas_object_event_callback_add(obj, EVAS_CALLBACK_RESIZE, _imageslider_resize, obj);
+   evas_object_event_callback_add(obj, EVAS_CALLBACK_MOVE, _imageslider_move, obj);
+   evas_object_event_callback_add(obj, EVAS_CALLBACK_SHOW, _imageslider_show, obj);
+   evas_object_event_callback_add(obj, EVAS_CALLBACK_HIDE, _imageslider_hide, obj);
 
    _sizing_eval(obj);
-
    return obj;
 }
 
-/** 
-* Append an Image Slider item 
-* 
-* @param       obj          The Image Slider object 
-* @param       photo_file   photo file path 
-* @param       func         callback function 
-* @param       data         callback data 
-* @return      The Image Slider item handle or NULL 
-* 
-* @ingroup Imageslider 
-*/
 EAPI Elm_Imageslider_Item *
-elm_imageslider_item_append(Evas_Object *obj, const char *photo_file,
-                           Elm_Imageslider_Cb func, void *data)
+elm_imageslider_item_append(Evas_Object *obj, const char *photo_file, Elm_Imageslider_Cb func, void *data)
 {
    ELM_CHECK_WIDTYPE(obj, widtype) NULL;
    Widget_Data *wd;
@@ -1087,9 +693,7 @@ elm_imageslider_item_append(Evas_Object *obj, const char *photo_file,
    Elm_Imageslider_Item *it;
 
    if (!obj || !(wd = elm_widget_data_get(obj)))
-     {
-       return NULL;
-     }
+     return NULL;
 
    it = (Elm_Imageslider_Item *) calloc(1, sizeof(Elm_Imageslider_Item));
    if (!it)
@@ -1102,41 +706,22 @@ elm_imageslider_item_append(Evas_Object *obj, const char *photo_file,
 
    if (!wd->cur)
       wd->cur = wd->its;
-
    _imageslider_update(wd);
-
    return it;
 }
 
-/**
-* Insert an Image Slider item into the Image Slider Widget by using the given index.
-*
-* @param       obj                     The Image Slider object
-* @param       photo_file      photo file path
-* @param       func            callback function
-* @param       index           required position
-* @param       data            callback data
-* @return      The Image Slider item handle or NULL
-*
-* @ingroup     Imageslider
-*/
 EAPI Elm_Imageslider_Item *
-elm_imageslider_item_append_relative(Evas_Object *obj, const char *photo_file,
-                                    Elm_Imageslider_Cb func,
-                                    unsigned int index, void *data)
+elm_imageslider_item_append_relative(Evas_Object *obj, const char *photo_file, Elm_Imageslider_Cb func, unsigned int index, void *data)
 {
    ELM_CHECK_WIDTYPE(obj, widtype) NULL;
    Widget_Data *wd;
 
    Elm_Imageslider_Item *it;
 
-   fprintf(stderr,
-          "[[[ DEBUG ]]]:: New elm_imageslider_item_append_relative()\n");
+   DBG("New elm_imageslider_item_append_relative()\n");
 
    if (!obj || !(wd = elm_widget_data_get(obj)))
-     {
-       return NULL;
-     }
+     return NULL;
 
    it = (Elm_Imageslider_Item *) calloc(1, sizeof(Elm_Imageslider_Item));
    if (!it)
@@ -1147,31 +732,17 @@ elm_imageslider_item_append_relative(Evas_Object *obj, const char *photo_file,
    it->func = func;
    it->data = data;
 
-   wd->its =
-      eina_list_append_relative(wd->its, it, eina_list_nth(wd->its, index - 2));
+   wd->its = eina_list_append_relative(wd->its, it, eina_list_nth(wd->its,
+                                                                  index - 2));
 
    if (!wd->cur)
       wd->cur = wd->its;
-
    _imageslider_update(wd);
-
    return it;
 }
 
-/** 
-* Prepend Image Slider item 
-* 
-* @param       obj          The Image Slider object 
-* @param       photo_file   photo file path 
-* @param       func         callback function 
-* @param       data         callback data 
-* @return      The imageslider item handle or NULL 
-* 
-* @ingroup Imageslider 
-*/
 EAPI Elm_Imageslider_Item *
-elm_imageslider_item_prepend(Evas_Object *obj, const char *photo_file,
-                            Elm_Imageslider_Cb func, void *data)
+elm_imageslider_item_prepend(Evas_Object *obj, const char *photo_file, Elm_Imageslider_Cb func, void *data)
 {
    ELM_CHECK_WIDTYPE(obj, widtype) NULL;
    Widget_Data *wd;
@@ -1179,9 +750,7 @@ elm_imageslider_item_prepend(Evas_Object *obj, const char *photo_file,
    Elm_Imageslider_Item *it;
 
    if (!obj || !(wd = elm_widget_data_get(obj)))
-     {
-       return NULL;
-     }
+     return NULL;
 
    it = (Elm_Imageslider_Item *) calloc(1, sizeof(Elm_Imageslider_Item));
    it->photo_file = eina_stringshare_add(photo_file);
@@ -1189,22 +758,12 @@ elm_imageslider_item_prepend(Evas_Object *obj, const char *photo_file,
    it->data = data;
    it->obj = obj;
    wd->its = eina_list_prepend(wd->its, it);
-
    if (!wd->cur)
       wd->cur = wd->its;
-
    _imageslider_update(wd);
-
    return it;
 }
 
-/**
-* Delete the selected Image Slider item
-*
-* @param it            The selected Image Slider item handle
-*
-* @ingroup Imageslider
-*/
 EAPI void
 elm_imageslider_item_del(Elm_Imageslider_Item * it)
 {
@@ -1215,35 +774,23 @@ elm_imageslider_item_del(Elm_Imageslider_Item * it)
    Eina_List *l;
 
    if (!it || !(wd = elm_widget_data_get(it->obj)))
-     {
-       return;
-     }
+     return;
 
    EINA_LIST_FOREACH(wd->its, l, _it)
-   {
-      if (_it == it)
-       {
-          if (l == wd->cur)
-             wd->cur = eina_list_prev(wd->cur);
-          wd->its = eina_list_remove(wd->its, it);
-          if (!wd->cur)
-             wd->cur = wd->its;
-          break;
-       }
-   }
-
+     {
+        if (_it == it)
+          {
+             if (l == wd->cur)
+                wd->cur = eina_list_prev(wd->cur);
+             wd->its = eina_list_remove(wd->its, it);
+             if (!wd->cur)
+                wd->cur = wd->its;
+             break;
+          }
+     }
    _imageslider_update(wd);
-
 }
 
-/**
-* Get the selected Image Slider item
-*
-* @param obj           The Image Slider object
-* @return The selected Image Slider item or NULL
-*
-* @ingroup Imageslider
-*/
 EAPI Elm_Imageslider_Item *
 elm_imageslider_selected_item_get(Evas_Object *obj)
 {
@@ -1251,9 +798,7 @@ elm_imageslider_selected_item_get(Evas_Object *obj)
    Widget_Data *wd;
 
    if (!obj || (!(wd = elm_widget_data_get(obj))))
-     {
-       return NULL;
-     }
+     return NULL;
 
    if (!wd->cur)
       return NULL;
@@ -1261,23 +806,13 @@ elm_imageslider_selected_item_get(Evas_Object *obj)
    return eina_list_data_get(wd->cur);
 }
 
-/**
-* Get whether an Image Slider item is selected or not
-*
-* @param it             the selected Image Slider item
-* @return EINA_TRUE or EINA_FALSE
-*
-* @ingroup Imageslider
-*/
 EAPI Eina_Bool
 elm_imageslider_item_selected_get(Elm_Imageslider_Item * it)
 {
    Widget_Data *wd;
 
    if (!it || !it->obj || (!(wd = elm_widget_data_get(it->obj))))
-     {
-       return EINA_FALSE;
-     }
+     return EINA_FALSE;
 
    if (!wd->cur)
       return EINA_FALSE;
@@ -1286,16 +821,8 @@ elm_imageslider_item_selected_get(Elm_Imageslider_Item * it)
       return EINA_TRUE;
    else
       return EINA_FALSE;
-
 }
 
-/**
-* Set the selected Image Slider item
-*
-* @param it            The Imaga Slider item
-*
-* @ingroup Imageslider
-*/
 EAPI void
 elm_imageslider_item_selected_set(Elm_Imageslider_Item * it)
 {
@@ -1310,61 +837,44 @@ elm_imageslider_item_selected_set(Elm_Imageslider_Item * it)
    Evas_Object *eo;
 
    if (!it || !it->obj || (!(wd = elm_widget_data_get(it->obj))))
-     {
-       return;
-     }
+     return;
 
    EINA_LIST_FOREACH(wd->its, l, _it)
-   {
-      if (_it == it)
-       {
-          wd->cur = l;
-       }
-   }
+     {
+        if (_it == it)
+          wd->cur = l;
+     }
 
    for (i = 0; i < BLOCK_MAX; i++)
      {
-       eo =
-          edje_object_part_swallow_get(elm_layout_edje_get(wd->ly[i]),
-                                       "swl.photo");
-       if (eo)
-         {
-            elm_layout_content_set(wd->ly[i], "swl.photo", NULL);
-            evas_object_del(eo);
-         }
+       eo = elm_object_part_content_get(wd->ly[i], "swl.photo");
+       if (eo)
+         elm_object_part_content_set(wd->ly[i], "swl.photo", NULL);
      }
-
    _imageslider_update(wd);
-
 }
 
-/**
-* Get the photo file path of given Image Slider item
-*
-* @param it            The Image Slider item
-* @return The photo file path or NULL;
-*
-* @ingroup Imageslider
-*/
 EAPI const char *
 elm_imageslider_item_photo_file_get(Elm_Imageslider_Item * it)
 {
-   if (!it)
-     {
-       return NULL;
-     }
+   if (!it) return NULL;
 
    return it->photo_file;
 }
 
-/**
-* Get the previous Image Slider item
-*
-* @param it            The Image Slider item
-* @return The previous Image Slider item or NULL
-*
-* @ingroup Imageslider
-*/
+EAPI void
+elm_imageslider_item_photo_file_set(Elm_Imageslider_Item *it, const char *photo_file)
+{
+   if (!it) return;
+   ELM_CHECK_WIDTYPE(it->obj, widtype);
+
+   if (photo_file)
+     {
+        eina_stringshare_replace(&(it->photo_file), photo_file);
+        elm_imageslider_item_update(it);
+     }
+}
+
 EAPI Elm_Imageslider_Item *
 elm_imageslider_item_prev(Elm_Imageslider_Item * it)
 {
@@ -1375,32 +885,21 @@ elm_imageslider_item_prev(Elm_Imageslider_Item * it)
    Eina_List *l;
 
    if (!it || (!(wd = elm_widget_data_get(it->obj))))
-     {
-       return NULL;
-     }
+     return NULL;
 
    EINA_LIST_FOREACH(wd->its, l, _it)
-   {
-      if (_it == it)
-       {
-          l = eina_list_prev(l);
-          if (!l)
-             break;
-          return eina_list_data_get(l);
-       }
-   }
-
+     {
+        if (_it == it)
+          {
+             l = eina_list_prev(l);
+             if (!l)
+               break;
+             return eina_list_data_get(l);
+          }
+     }
    return NULL;
 }
 
-/**
-* Get the next Image Slider item
-*
-* @param it            The Image Slider item
-* @return The next Image Slider item or NULL
-*
-* @ingroup Imageslider
-*/
 EAPI Elm_Imageslider_Item *
 elm_imageslider_item_next(Elm_Imageslider_Item * it)
 {
@@ -1411,31 +910,21 @@ elm_imageslider_item_next(Elm_Imageslider_Item * it)
    Eina_List *l;
 
    if (!it || (!(wd = elm_widget_data_get(it->obj))))
-     {
-       return NULL;
-     }
+     return NULL;
 
    EINA_LIST_FOREACH(wd->its, l, _it)
-   {
-      if (_it == it)
-       {
-          l = eina_list_next(l);
-          if (!l)
-             break;
-          return eina_list_data_get(l);
-       }
-   }
-
+     {
+        if (_it == it)
+          {
+             l = eina_list_next(l);
+             if (!l)
+               break;
+             return eina_list_data_get(l);
+          }
+     }
    return NULL;
 }
 
-/**
-* Move to the previous Image Slider item
-*
-* @param obj   The Image Slider object
-*
-* @ingroup Imageslider
-*/
 EAPI void
 elm_imageslider_prev(Evas_Object *obj)
 {
@@ -1443,23 +932,12 @@ elm_imageslider_prev(Evas_Object *obj)
    Widget_Data *wd;
 
    if (!obj || (!(wd = elm_widget_data_get(obj))))
-     {
-       return;
-     }
-
+     return;
    if (wd->ani_lock)
-      return;
-
+     return;
    _imageslider_obj_move(wd, -1);
 }
 
-/**
-* Move to the next Image Slider item
-*
-* @param obj The Image Slider object
-*
-* @ingroup Imageslider
-*/
 EAPI void
 elm_imageslider_next(Evas_Object * obj)
 {
@@ -1467,13 +945,26 @@ elm_imageslider_next(Evas_Object * obj)
    Widget_Data *wd;
 
    if (!obj || (!(wd = elm_widget_data_get(obj))))
-     {
-       return;
-     }
-
+     return;
    if (wd->ani_lock)
-      return;
-
+     return;
    _imageslider_obj_move(wd, 1);
+}
 
+EAPI void
+elm_imageslider_item_update(Elm_Imageslider_Item *it)
+{
+   Widget_Data *wd;
+
+   if (!it || (!(wd = elm_widget_data_get(it->obj)))) return;
+   ELM_CHECK_WIDTYPE(it->obj, widtype);
+
+   if (wd->ani_lock) return;
+   if (it == eina_list_data_get(eina_list_prev(wd->cur)))
+     elm_object_part_content_set(wd->ly[BLOCK_LEFT], "swl.photo", NULL);
+   else if (it == eina_list_data_get(wd->cur))
+     elm_object_part_content_set(wd->ly[BLOCK_CENTER], "swl.photo", NULL);
+   else if (it == eina_list_data_get(eina_list_next(wd->cur)))
+     elm_object_part_content_set(wd->ly[BLOCK_RIGHT], "swl.photo", NULL);
+   _imageslider_update(wd);
 }