forked from enlightenment/efl
Fix slideshow smart events event_info
Changed all the callback_call to pass the correct Elm_Object_Item (Eo) pointer, was passing Elm_Slideshow_Item_Data instead. @fix Also updated the test
This commit is contained in:
parent
058fbcca59
commit
b25a0a3ea3
|
@ -80,6 +80,7 @@ _get(void *data, Evas_Object *obj)
|
||||||
//elm_photocam_file_set(photo, data);
|
//elm_photocam_file_set(photo, data);
|
||||||
//elm_photocam_zoom_mode_set(photo, ELM_PHOTOCAM_ZOOM_MODE_AUTO_FIT);
|
//elm_photocam_zoom_mode_set(photo, ELM_PHOTOCAM_ZOOM_MODE_AUTO_FIT);
|
||||||
|
|
||||||
|
printf("_get (item data: '%s')\n", (char*)data);
|
||||||
Evas_Object *photo = elm_image_add(obj);
|
Evas_Object *photo = elm_image_add(obj);
|
||||||
elm_image_file_set(photo, data, NULL);
|
elm_image_file_set(photo, data, NULL);
|
||||||
elm_image_fill_outside_set(photo, EINA_FALSE);
|
elm_image_fill_outside_set(photo, EINA_FALSE);
|
||||||
|
@ -88,9 +89,26 @@ _get(void *data, Evas_Object *obj)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_slide_transition(void *data, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
|
_del(void *data, Evas_Object *obj EINA_UNUSED)
|
||||||
|
{
|
||||||
|
printf("_del (item data: '%s')\n", (char*)data);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
_changed_cb(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info)
|
||||||
{
|
{
|
||||||
Elm_Object_Item *slide_it = (Elm_Object_Item *) event_info;
|
Elm_Object_Item *slide_it = (Elm_Object_Item *) event_info;
|
||||||
|
printf("CHANGED (item data: '%s')\n",
|
||||||
|
(char*)elm_object_item_data_get(slide_it));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
_transition_end_cb(void *data, Evas_Object *obj EINA_UNUSED, void *event_info)
|
||||||
|
{
|
||||||
|
Elm_Object_Item *slide_it = (Elm_Object_Item *) event_info;
|
||||||
|
printf("TRANSITION,END (item data: '%s')\n",
|
||||||
|
(char*)elm_object_item_data_get(slide_it));
|
||||||
if (data == slide_it)
|
if (data == slide_it)
|
||||||
printf("Reaches to End of slides\n");
|
printf("Reaches to End of slides\n");
|
||||||
}
|
}
|
||||||
|
@ -123,20 +141,21 @@ test_slideshow(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event
|
||||||
slideshow = elm_slideshow_add(win);
|
slideshow = elm_slideshow_add(win);
|
||||||
elm_slideshow_loop_set(slideshow, EINA_TRUE);
|
elm_slideshow_loop_set(slideshow, EINA_TRUE);
|
||||||
evas_object_size_hint_weight_set(slideshow, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
|
evas_object_size_hint_weight_set(slideshow, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
|
||||||
|
evas_object_smart_callback_add(slideshow, "changed", _changed_cb, NULL);
|
||||||
elm_win_resize_object_add(win, slideshow);
|
elm_win_resize_object_add(win, slideshow);
|
||||||
evas_object_show(slideshow);
|
evas_object_show(slideshow);
|
||||||
|
|
||||||
itc.func.get = _get;
|
itc.func.get = _get;
|
||||||
itc.func.del = NULL;
|
itc.func.del = _del;
|
||||||
|
|
||||||
for (i = 0; imgs[i]; i++)
|
for (i = 0; imgs[i]; i++)
|
||||||
{
|
{
|
||||||
const char *img = eina_stringshare_printf("%s/images/%s", elm_app_data_dir_get(), imgs[i]);
|
const char *img = eina_stringshare_printf("%s/images/%s", elm_app_data_dir_get(), imgs[i]);
|
||||||
printf("Img : %s\n", img);
|
|
||||||
slide_last_it = elm_slideshow_item_add(slideshow, &itc, img);
|
slide_last_it = elm_slideshow_item_add(slideshow, &itc, img);
|
||||||
}
|
}
|
||||||
|
|
||||||
evas_object_smart_callback_add(slideshow, "transition,end", _slide_transition, slide_last_it);
|
evas_object_smart_callback_add(slideshow, "transition,end",
|
||||||
|
_transition_end_cb, slide_last_it);
|
||||||
|
|
||||||
notify = elm_notify_add(win);
|
notify = elm_notify_add(win);
|
||||||
elm_notify_align_set(notify, 0.5, 1.0);
|
elm_notify_align_set(notify, 0.5, 1.0);
|
||||||
|
|
|
@ -270,7 +270,7 @@ _on_slideshow_end(void *data,
|
||||||
elm_layout_signal_emit(data, "anim,end", "slideshow");
|
elm_layout_signal_emit(data, "anim,end", "slideshow");
|
||||||
|
|
||||||
if (emission != NULL)
|
if (emission != NULL)
|
||||||
evas_object_smart_callback_call(data, SIG_TRANSITION_END, sd->current);
|
evas_object_smart_callback_call(data, SIG_TRANSITION_END, EO_OBJ(sd->current));
|
||||||
}
|
}
|
||||||
|
|
||||||
static Eina_Bool
|
static Eina_Bool
|
||||||
|
@ -475,7 +475,7 @@ _elm_slideshow_item_show(Eo *eo_item EINA_UNUSED, Elm_Slideshow_Item_Data *item)
|
||||||
|
|
||||||
sd->previous = sd->current;
|
sd->previous = sd->current;
|
||||||
sd->current = next;
|
sd->current = next;
|
||||||
evas_object_smart_callback_call(WIDGET(item), SIG_CHANGED, sd->current);
|
evas_object_smart_callback_call(WIDGET(item), SIG_CHANGED, EO_OBJ(sd->current));
|
||||||
}
|
}
|
||||||
|
|
||||||
EOLIAN static void
|
EOLIAN static void
|
||||||
|
@ -512,7 +512,7 @@ _elm_slideshow_next(Eo *obj, Elm_Slideshow_Data *sd)
|
||||||
|
|
||||||
sd->previous = sd->current;
|
sd->previous = sd->current;
|
||||||
sd->current = next;
|
sd->current = next;
|
||||||
evas_object_smart_callback_call(obj, SIG_CHANGED, sd->current);
|
evas_object_smart_callback_call(obj, SIG_CHANGED, EO_OBJ(sd->current));
|
||||||
}
|
}
|
||||||
|
|
||||||
EOLIAN static void
|
EOLIAN static void
|
||||||
|
@ -549,7 +549,7 @@ _elm_slideshow_previous(Eo *obj, Elm_Slideshow_Data *sd)
|
||||||
|
|
||||||
sd->previous = sd->current;
|
sd->previous = sd->current;
|
||||||
sd->current = prev;
|
sd->current = prev;
|
||||||
evas_object_smart_callback_call(obj, SIG_CHANGED, sd->current);
|
evas_object_smart_callback_call(obj, SIG_CHANGED, EO_OBJ(sd->current));
|
||||||
}
|
}
|
||||||
|
|
||||||
EOLIAN static const Eina_List*
|
EOLIAN static const Eina_List*
|
||||||
|
|
Loading…
Reference in New Issue