From 5a5f65374b9798576eda2690880a3259bfa5e1db Mon Sep 17 00:00:00 2001 From: Stephen Houston Date: Tue, 6 Jan 2015 13:34:18 -0600 Subject: [PATCH] Ephoto: Better handling of bad images. --- src/bin/ephoto_main.c | 8 +++++++ src/bin/ephoto_single_browser.c | 40 ++++++++++++++++++++++++--------- 2 files changed, 38 insertions(+), 10 deletions(-) diff --git a/src/bin/ephoto_main.c b/src/bin/ephoto_main.c index d1d42e3..f78661a 100644 --- a/src/bin/ephoto_main.c +++ b/src/bin/ephoto_main.c @@ -449,6 +449,13 @@ _thumb_del(void *data, Evas *e __UNUSED__, Evas_Object *o, void *event_info __UN ephoto->thumbs = eina_list_remove(ephoto->thumbs, o); } +static void +_load_error(void *data , Evas_Object *obj __UNUSED__, void *event_info __UNUSED__) +{ + const char *path = data; + ERR("Error loading thumbnail: %s\n", path); +} + Evas_Object * ephoto_thumb_add(Ephoto *ephoto, Evas_Object *parent, const char *path) { @@ -477,6 +484,7 @@ ephoto_thumb_add(Ephoto *ephoto, Evas_Object *parent, const char *path) elm_object_style_set(o, "noframe"); ephoto->thumbs = eina_list_append(ephoto->thumbs, o); evas_object_event_callback_add(o, EVAS_CALLBACK_DEL, _thumb_del, ephoto); + evas_object_smart_callback_add(o, "generate,error", _load_error, path); return o; } diff --git a/src/bin/ephoto_single_browser.c b/src/bin/ephoto_single_browser.c index 0e7ce60..9e7c314 100644 --- a/src/bin/ephoto_single_browser.c +++ b/src/bin/ephoto_single_browser.c @@ -13,6 +13,7 @@ struct _Ephoto_Single_Browser Evas_Object *table; Evas_Object *panel; Evas_Object *viewer; + Evas_Object *nolabel; const char *pending_path; Ephoto_Entry *entry; Ephoto_Orient orient; @@ -81,7 +82,7 @@ _viewer_add(Evas_Object *parent, const char *path) evas_object_show(v->table); v->image = elm_image_add(v->table); - elm_image_preload_disabled_set(v->image, EINA_FALSE); + elm_image_preload_disabled_set(v->image, EINA_TRUE); elm_image_file_set(v->image, path, group); err = evas_object_image_load_error_get(elm_image_object_get(v->image)); if (err != EVAS_LOAD_ERROR_NONE) goto load_error; @@ -95,8 +96,9 @@ _viewer_add(Evas_Object *parent, const char *path) load_error: ERR("could not load image '%s': %s", path, evas_load_error_str(err)); - evas_object_del(obj); error: + evas_object_event_callback_del(obj, EVAS_CALLBACK_DEL, _viewer_del); + evas_object_data_del(obj, "viewer"); free(v); return NULL; } @@ -291,7 +293,11 @@ _ephoto_single_browser_recalc(Ephoto_Single_Browser *sb) evas_object_del(sb->viewer); sb->viewer = NULL; } - + if (sb->nolabel) + { + evas_object_del(sb->nolabel); + sb->nolabel = NULL; + } if (sb->entry) { const char *bname = ecore_file_file_get(sb->entry->path); @@ -299,12 +305,25 @@ _ephoto_single_browser_recalc(Ephoto_Single_Browser *sb) elm_table_clear(sb->table, EINA_FALSE); sb->viewer = _viewer_add(sb->main, sb->entry->path); - elm_table_pack(sb->table, sb->viewer, 0, 0, 4, 1); - evas_object_show(sb->viewer); - evas_object_event_callback_add - (sb->viewer, EVAS_CALLBACK_MOUSE_WHEEL, _mouse_wheel, sb); - ephoto_title_set(sb->ephoto, bname); - + if (sb->viewer) + { + elm_table_pack(sb->table, sb->viewer, 0, 0, 4, 1); + evas_object_show(sb->viewer); + evas_object_event_callback_add + (sb->viewer, EVAS_CALLBACK_MOUSE_WHEEL, _mouse_wheel, sb); + ephoto_title_set(sb->ephoto, bname); + } + else + { + sb->nolabel = elm_label_add(sb->table); + elm_label_line_wrap_set(sb->nolabel, ELM_WRAP_WORD); + elm_object_text_set(sb->nolabel, "This image does not exist or is corrupted"); + evas_object_size_hint_weight_set(sb->nolabel, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND); + evas_object_size_hint_align_set(sb->nolabel, EVAS_HINT_FILL, EVAS_HINT_FILL); + elm_table_pack(sb->table, sb->nolabel, 0, 0, 4, 1); + evas_object_show(sb->nolabel); + ephoto_title_set(sb->ephoto, "Bad Image"); + } elm_table_pack(sb->table, sb->panel, 0, 0, 1, 1); } @@ -762,7 +781,8 @@ ephoto_single_browser_entry_set(Evas_Object *obj, Ephoto_Entry *entry) if (entry) ephoto_entry_free_listener_add(entry, _entry_free, sb); _ephoto_single_browser_recalc(sb); - _zoom_fit(sb); + if (sb->viewer) + _zoom_fit(sb); } void