1 #include <Elementary.h>
6 #define NON_EXISTING (void *)-1
7 static const char *icon_theme = NULL;
10 typedef struct _Widget_Data Widget_Data;
16 Elm_Icon_Lookup_Order lookup_order;
18 #ifdef HAVE_ELEMENTARY_ETHUMB
27 Ethumb_Exists *exists;
29 Ecore_Event_Handler *eeh;
31 Ethumb_Thumb_Format format;
43 Eina_Bool scale_up : 1;
44 Eina_Bool scale_down : 1;
46 Eina_Bool fill_outside : 1;
47 Eina_Bool no_scale : 1;
49 /* for animation feature */
59 #ifdef HAVE_ELEMENTARY_ETHUMB
60 static Eina_List *_elm_icon_retry = NULL;
61 static int _icon_pending_request = 0;
63 static void _icon_thumb_exists(Ethumb_Client *client __UNUSED__, Ethumb_Exists *thread, Eina_Bool exists, void *data);
66 static const char *widtype = NULL;
67 static void _del_hook(Evas_Object *obj);
68 static void _theme_hook(Evas_Object *obj);
69 static void _sizing_eval(Evas_Object *obj);
70 static void _mouse_up(void *data, Evas *e, Evas_Object *obj, void *event_info);
72 static Eina_Bool _icon_standard_set(Widget_Data *wd, Evas_Object *obj, const char *name);
73 static Eina_Bool _icon_freedesktop_set(Widget_Data *wd, Evas_Object *obj, const char *name, int size);
75 static const char SIG_CLICKED[] = "clicked";
77 static const Evas_Smart_Cb_Description _signals[] = {
83 //FIXME: move this code to ecore
86 _path_is_absolute(const char *path)
88 //TODO: Check if this works with all absolute paths in windows
89 return ((isalpha (*path)) && (*(path + 1) == ':') && ((*(path + 2) == '\\') || (*(path + 2) == '/')));
93 _path_is_absolute(const char *path)
95 return (*path == '/');
100 _icon_size_min_get(Evas_Object *icon)
103 _els_smart_icon_size_get(icon, &size, NULL);
104 return (size < 32) ? 32 : size;
107 #ifdef HAVE_ELEMENTARY_ETHUMB
109 _icon_thumb_stop(Widget_Data *wd, void *ethumbd)
111 if (wd->thumb.id >= 0)
113 ethumb_client_generate_cancel(ethumbd, wd->thumb.id, NULL, NULL, NULL);
115 _icon_pending_request--;
118 if (wd->thumb.exists)
120 ethumb_client_thumb_exists_cancel(wd->thumb.exists, _icon_thumb_exists, wd);
121 wd->thumb.exists = NULL;
122 _icon_pending_request--;
127 _elm_icon_retry = eina_list_remove(_elm_icon_retry, wd);
128 wd->thumb.retry = EINA_FALSE;
133 _icon_thumb_display(Widget_Data *wd)
135 Eina_Bool ret = EINA_FALSE;
137 if (wd->thumb.format == ETHUMB_THUMB_EET)
139 static const char *extensions[] = {
140 ".avi", ".mp4", ".ogv", ".mov", ".mpg", ".wmv", NULL
142 const char **ext, *ptr;
144 Eina_Bool video = EINA_FALSE;
146 prefix_size = eina_stringshare_strlen(wd->thumb.file.path) - 4;
147 if (prefix_size >= 0)
149 ptr = wd->thumb.file.path + prefix_size;
150 for (ext = extensions; *ext; ++ext)
151 if (!strcasecmp(ptr, *ext))
159 ret = _els_smart_icon_file_edje_set(wd->img, wd->thumb.thumb.path, wd->thumb.thumb.key);
163 ret = _els_smart_icon_file_key_set(wd->img, wd->thumb.thumb.path, wd->thumb.thumb.key);
169 _icon_thumb_retry(Widget_Data *wd)
171 return _icon_thumb_display(wd);
175 _icon_thumb_cleanup(Ethumb_Client *ethumbd)
180 EINA_LIST_FOREACH_SAFE(_elm_icon_retry, l, ll, wd)
181 if (_icon_thumb_retry(wd))
183 _elm_icon_retry = eina_list_remove_list(_elm_icon_retry, l);
184 wd->thumb.retry = EINA_FALSE;
187 if (_icon_pending_request == 0)
188 EINA_LIST_FREE(_elm_icon_retry, wd)
189 _icon_thumb_stop(wd, ethumbd);
193 _icon_thumb_finish(Widget_Data *wd, Ethumb_Client *ethumbd)
195 const char *file = NULL, *group = NULL;
198 _els_smart_icon_file_get(wd->img, &file, &group);
199 file = eina_stringshare_ref(file);
200 group = eina_stringshare_ref(group);
202 ret = _icon_thumb_display(wd);
208 if (!wd->thumb.retry)
210 _elm_icon_retry = eina_list_append(_elm_icon_retry, wd);
211 wd->thumb.retry = EINA_TRUE;
214 /* Back to previous image */
215 if (((p = strrchr(file, '.'))) && (!strcasecmp(p, ".edj")))
216 _els_smart_icon_file_edje_set(wd->img, file, group);
218 _els_smart_icon_file_key_set(wd->img, file, group);
221 _icon_thumb_cleanup(ethumbd);
223 eina_stringshare_del(file);
224 eina_stringshare_del(group);
228 _icon_thumb_cb(void *data,
229 Ethumb_Client *ethumbd,
231 const char *file __UNUSED__,
232 const char *key __UNUSED__,
233 const char *thumb_path,
234 const char *thumb_key,
237 Widget_Data *wd = data;
239 EINA_SAFETY_ON_FALSE_RETURN(wd->thumb.id == id);
242 _icon_pending_request--;
246 eina_stringshare_replace(&wd->thumb.thumb.path, thumb_path);
247 eina_stringshare_replace(&wd->thumb.thumb.key, thumb_key);
248 wd->thumb.format = ethumb_client_format_get(ethumbd);
250 _icon_thumb_finish(wd, ethumbd);
254 ERR("could not generate thumbnail for %s (key: %s)", file, key);
255 _icon_thumb_cleanup(ethumbd);
260 _icon_thumb_exists(Ethumb_Client *client __UNUSED__, Ethumb_Exists *thread, Eina_Bool exists, void *data)
262 Widget_Data *wd = data;
263 Ethumb_Client *ethumbd;
265 if (ethumb_client_thumb_exists_check(thread))
268 wd->thumb.exists = NULL;
270 ethumbd = elm_thumb_ethumb_client_get();
274 const char *thumb_path, *thumb_key;
276 _icon_pending_request--;
277 ethumb_client_thumb_path_get(ethumbd, &thumb_path, &thumb_key);
278 eina_stringshare_replace(&wd->thumb.thumb.path, thumb_path);
279 eina_stringshare_replace(&wd->thumb.thumb.key, thumb_key);
280 wd->thumb.format = ethumb_client_format_get(ethumbd);
282 _icon_thumb_finish(wd, ethumbd);
284 else if ((wd->thumb.id = ethumb_client_generate(ethumbd, _icon_thumb_cb, wd, NULL)) == -1)
286 ERR("Generate was unable to start !");
287 /* Failed to generate thumbnail */
288 _icon_pending_request--;
293 _icon_thumb_apply(Widget_Data *wd)
295 Ethumb_Client *ethumbd;
297 ethumbd = elm_thumb_ethumb_client_get();
299 _icon_thumb_stop(wd, ethumbd);
301 if (!wd->thumb.file.path) return ;
303 _icon_pending_request++;
304 if (!ethumb_client_file_set(ethumbd, wd->thumb.file.path, wd->thumb.file.key)) return ;
305 ethumb_client_size_set(ethumbd, _icon_size_min_get(wd->img), _icon_size_min_get(wd->img));
306 wd->thumb.exists = ethumb_client_thumb_exists(ethumbd, _icon_thumb_exists, wd);
310 _icon_thumb_apply_cb(void *data, int type __UNUSED__, void *ev __UNUSED__)
312 Widget_Data *wd = data;
314 _icon_thumb_apply(wd);
315 return ECORE_CALLBACK_RENEW;
320 _del_hook(Evas_Object *obj)
322 Widget_Data *wd = elm_widget_data_get(obj);
324 #ifdef HAVE_ELEMENTARY_ETHUMB
325 Ethumb_Client *ethumbd;
329 if (wd->stdicon) eina_stringshare_del(wd->stdicon);
331 #ifdef HAVE_ELEMENTARY_ETHUMB
332 ethumbd = elm_thumb_ethumb_client_get();
333 _icon_thumb_stop(wd, ethumbd);
335 eina_stringshare_del(wd->thumb.file.path);
336 eina_stringshare_del(wd->thumb.file.key);
337 eina_stringshare_del(wd->thumb.thumb.path);
338 eina_stringshare_del(wd->thumb.thumb.key);
341 ecore_event_handler_del(wd->thumb.eeh);
345 ecore_timer_del(wd->timer);
350 _theme_hook(Evas_Object *obj)
352 Widget_Data *wd = elm_widget_data_get(obj);
355 _elm_theme_object_icon_set(obj, wd->img, wd->stdicon, elm_widget_style_get(obj));
360 _signal_emit_hook(Evas_Object *obj, const char *emission, const char *source)
362 Widget_Data *wd = elm_widget_data_get(obj);
364 Evas_Object *icon_edje;
365 icon_edje = _els_smart_icon_edje_get(wd->img);
366 if (!icon_edje) return;
367 edje_object_signal_emit(icon_edje, emission, source);
371 _signal_callback_add_hook(Evas_Object *obj, const char *emission, const char *source, Edje_Signal_Cb func_cb, void *data)
373 Widget_Data *wd = elm_widget_data_get(obj);
375 Evas_Object *icon_edje;
376 icon_edje = _els_smart_icon_edje_get(wd->img);
377 if (!icon_edje) return;
378 edje_object_signal_callback_add(icon_edje, emission, source, func_cb, data);
382 _signal_callback_del_hook(Evas_Object *obj, const char *emission, const char *source, Edje_Signal_Cb func_cb, void *data)
384 Widget_Data *wd = elm_widget_data_get(obj);
386 Evas_Object *icon_edje;
387 icon_edje = _els_smart_icon_edje_get(wd->img);
388 if (!icon_edje) return;
389 edje_object_signal_callback_del_full(icon_edje, emission, source, func_cb,
394 _sizing_eval(Evas_Object *obj)
396 Widget_Data *wd = elm_widget_data_get(obj);
398 Evas_Coord minw = -1, minh = -1, maxw = -1, maxh = -1;
401 _els_smart_icon_size_get(wd->img, &w, &h);
403 if ((wd->freedesktop.use) && (!((w - wd->freedesktop.requested_size) % 16)))
405 /* This icon has been set to a freedesktop icon, and the requested
406 appears to have a different size than the requested size, so try to
407 request another, higher resolution, icon.
408 FIXME: Find a better heuristic to determine if there should be
409 an icon with a different resolution. */
410 _icon_freedesktop_set(wd, obj, wd->stdicon, w);
413 _els_smart_icon_scale_up_set(wd->img, wd->scale_up);
414 _els_smart_icon_scale_down_set(wd->img, wd->scale_down);
415 _els_smart_icon_smooth_scale_set(wd->img, wd->smooth);
416 _els_smart_icon_fill_inside_set(wd->img, !(wd->fill_outside));
417 if (wd->no_scale) _els_smart_icon_scale_set(wd->img, 1.0);
420 _els_smart_icon_scale_set(wd->img, elm_widget_scale_get(obj) *
422 _els_smart_icon_size_get(wd->img, &w, &h);
434 evas_object_size_hint_min_set(obj, minw, minh);
435 evas_object_size_hint_max_set(obj, maxw, maxh);
439 _mouse_up(void *data, Evas *e __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info)
441 Evas_Event_Mouse_Up *ev = event_info;
442 if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD) return;
443 evas_object_smart_callback_call(data, SIG_CLICKED, event_info);
447 _elm_icon_animate_cb(void *data)
449 Widget_Data *wd = data;
450 Evas_Object *img_obj;
452 if (!wd) return ECORE_CALLBACK_CANCEL;
453 if (!wd->anim) return ECORE_CALLBACK_CANCEL;
455 img_obj = _els_smart_icon_object_get(wd->img);
457 if (wd->cur_frame > wd->frame_count)
458 wd->cur_frame = wd->cur_frame % wd->frame_count;
459 evas_object_image_animated_frame_set(img_obj, wd->cur_frame);
461 wd->duration = evas_object_image_animated_frame_duration_get(img_obj, wd->cur_frame, 0);
463 if (wd->duration > 0)
464 ecore_timer_interval_set(wd->timer, wd->duration);
465 return ECORE_CALLBACK_RENEW;
469 elm_icon_add(Evas_Object *parent)
475 ELM_WIDGET_STANDARD_SETUP(wd, Widget_Data, parent, e, obj, NULL);
477 ELM_SET_WIDTYPE(widtype, "icon");
478 elm_widget_type_set(obj, "icon");
479 elm_widget_can_focus_set(obj, EINA_FALSE);
480 elm_widget_sub_object_add(parent, obj);
481 elm_widget_data_set(obj, wd);
482 elm_widget_del_hook_set(obj, _del_hook);
483 elm_widget_theme_hook_set(obj, _theme_hook);
484 elm_widget_signal_emit_hook_set(obj, _signal_emit_hook);
485 elm_widget_signal_callback_add_hook_set(obj, _signal_callback_add_hook);
486 elm_widget_signal_callback_del_hook_set(obj, _signal_callback_del_hook);
488 wd->lookup_order = ELM_ICON_LOOKUP_THEME_FDO;
489 wd->img = _els_smart_icon_add(e);
490 evas_object_event_callback_add(wd->img, EVAS_CALLBACK_MOUSE_UP,
492 evas_object_repeat_events_set(wd->img, EINA_TRUE);
493 elm_widget_resize_object_set(obj, wd->img);
495 evas_object_smart_callbacks_descriptions_set(obj, _signals);
497 #ifdef HAVE_ELEMENTARY_ETHUMB
501 wd->smooth = EINA_TRUE;
502 wd->scale_up = EINA_TRUE;
503 wd->scale_down = EINA_TRUE;
510 elm_icon_memfile_set(Evas_Object *obj, const void *img, size_t size, const char *format, const char *key)
512 ELM_CHECK_WIDTYPE(obj, widtype) EINA_FALSE;
513 Widget_Data *wd = elm_widget_data_get(obj);
516 if (!wd) return EINA_FALSE;
517 EINA_SAFETY_ON_NULL_RETURN_VAL(img, EINA_FALSE);
518 EINA_SAFETY_ON_TRUE_RETURN_VAL(!size, EINA_FALSE);
519 eina_stringshare_del(wd->stdicon);
521 ret = _els_smart_icon_memfile_set(wd->img, img, size, format, key);
527 elm_icon_file_set(Evas_Object *obj, const char *file, const char *group)
529 ELM_CHECK_WIDTYPE(obj, widtype) EINA_FALSE;
530 Widget_Data *wd = elm_widget_data_get(obj);
534 if (!wd) return EINA_FALSE;
535 EINA_SAFETY_ON_NULL_RETURN_VAL(file, EINA_FALSE);
536 if (wd->stdicon) eina_stringshare_del(wd->stdicon);
538 if (((p = strrchr(file, '.'))) && (!strcasecmp(p, ".edj")))
539 ret = _els_smart_icon_file_edje_set(wd->img, file, group);
541 ret = _els_smart_icon_file_key_set(wd->img, file, group);
547 elm_icon_file_get(const Evas_Object *obj, const char **file, const char **group)
549 ELM_CHECK_WIDTYPE(obj, widtype);
550 Widget_Data *wd = elm_widget_data_get(obj);
552 _els_smart_icon_file_get(wd->img, file, group);
556 elm_icon_thumb_set(Evas_Object *obj, const char *file, const char *group)
558 ELM_CHECK_WIDTYPE(obj, widtype);
559 Widget_Data *wd = elm_widget_data_get(obj);
562 #ifdef HAVE_ELEMENTARY_ETHUMB
563 eina_stringshare_replace(&wd->thumb.file.path, file);
564 eina_stringshare_replace(&wd->thumb.file.key, group);
566 if (elm_thumb_ethumb_client_connected())
568 _icon_thumb_apply(wd);
574 wd->thumb.eeh = ecore_event_handler_add(ELM_ECORE_EVENT_ETHUMB_CONNECT, _icon_thumb_apply_cb, wd);
584 elm_icon_animated_available_get(const Evas_Object *obj)
586 ELM_CHECK_WIDTYPE(obj, widtype) EINA_FALSE;
587 Evas_Object *img_obj ;
588 Widget_Data *wd = elm_widget_data_get(obj);
589 if (!wd) return EINA_FALSE;
591 img_obj = _els_smart_icon_object_get(wd->img);
593 return evas_object_image_animated_get(img_obj);
597 elm_icon_animated_set(Evas_Object *obj, Eina_Bool anim)
599 ELM_CHECK_WIDTYPE(obj, widtype);
600 Evas_Object *img_obj ;
601 Widget_Data *wd = elm_widget_data_get(obj);
603 if (wd->anim == anim) return;
605 img_obj = _els_smart_icon_object_get(wd->img);
606 if (!evas_object_image_animated_get(img_obj)) return;
609 wd->frame_count = evas_object_image_animated_frame_count_get(img_obj);
611 wd->duration = evas_object_image_animated_frame_duration_get(img_obj, wd->cur_frame, 0);
612 evas_object_image_animated_frame_set(img_obj, wd->cur_frame);
616 wd->frame_count = -1;
625 elm_icon_animated_get(const Evas_Object *obj)
627 ELM_CHECK_WIDTYPE(obj, widtype) EINA_FALSE;
628 Widget_Data *wd = elm_widget_data_get(obj);
629 if (!wd) return EINA_FALSE;
634 elm_icon_animated_play_set(Evas_Object *obj, Eina_Bool play)
636 ELM_CHECK_WIDTYPE(obj, widtype);
637 Widget_Data *wd = elm_widget_data_get(obj);
639 if (!wd->anim) return;
640 if (wd->play == play) return;
644 wd->timer = ecore_timer_add(wd->duration, _elm_icon_animate_cb, wd);
650 ecore_timer_del(wd->timer);
659 elm_icon_animated_play_get(const Evas_Object *obj)
661 ELM_CHECK_WIDTYPE(obj, widtype) EINA_FALSE;
662 Widget_Data *wd = elm_widget_data_get(obj);
663 if (!wd) return EINA_FALSE;
668 _icon_standard_set(Widget_Data *wd, Evas_Object *obj, const char *name)
670 if (_elm_theme_object_icon_set(obj, wd->img, name, "default"))
673 /* TODO: elm_unneed_efreet() */
674 wd->freedesktop.use = EINA_FALSE;
682 _icon_file_set(Widget_Data *wd, Evas_Object *obj, const char *path)
684 if (elm_icon_file_set(obj, path, NULL))
687 /* TODO: elm_unneed_efreet() */
688 wd->freedesktop.use = EINA_FALSE;
696 _icon_freedesktop_set(Widget_Data *wd, Evas_Object *obj, const char *name, int size)
702 if (icon_theme == NON_EXISTING) return EINA_FALSE;
705 Efreet_Icon_Theme *theme;
706 /* TODO: Listen for EFREET_EVENT_ICON_CACHE_UPDATE */
707 theme = efreet_icon_theme_find(getenv("E_ICON_THEME"));
711 static const char *themes[] = {
712 "gnome", "Human", "oxygen", "hicolor", NULL
714 for (itr = themes; *itr; itr++)
716 theme = efreet_icon_theme_find(*itr);
723 icon_theme = NON_EXISTING;
727 icon_theme = eina_stringshare_add(theme->name.internal);
729 path = efreet_icon_path_find(icon_theme, name, size);
730 wd->freedesktop.use = !!path;
731 if (wd->freedesktop.use)
733 wd->freedesktop.requested_size = size;
734 elm_icon_file_set(obj, path, NULL);
742 _elm_icon_standard_set(Widget_Data *wd, Evas_Object *obj, const char *name, Eina_Bool *fdo)
747 /* try locating the icon using the specified lookup order */
748 switch (wd->lookup_order)
750 case ELM_ICON_LOOKUP_FDO:
751 ret = _icon_freedesktop_set(wd, obj, name, _icon_size_min_get(wd->img));
752 if (ret && fdo) *fdo = EINA_TRUE;
754 case ELM_ICON_LOOKUP_THEME:
755 ret = _icon_standard_set(wd, obj, name);
757 case ELM_ICON_LOOKUP_THEME_FDO:
758 ret = _icon_standard_set(wd, obj, name);
761 ret = _icon_freedesktop_set(wd, obj, name, _icon_size_min_get(wd->img));
762 if (ret && fdo) *fdo = EINA_TRUE;
765 case ELM_ICON_LOOKUP_FDO_THEME:
767 ret = _icon_freedesktop_set(wd, obj, name, _icon_size_min_get(wd->img));
769 ret = _icon_standard_set(wd, obj, name);
777 eina_stringshare_replace(&wd->stdicon, name);
782 if (_path_is_absolute(name))
783 return _icon_file_set(wd, obj, name);
785 /* if that fails, see if icon name is in the format size/name. if so,
786 try locating a fallback without the size specification */
787 if (!(tmp = strchr(name, '/'))) return EINA_FALSE;
789 if (*tmp) return elm_icon_standard_set(obj, tmp);
795 _elm_icon_standard_resize(void *data,
798 void *event_info __UNUSED__)
800 Widget_Data *wd = data;
801 const char *refup = eina_stringshare_ref(wd->stdicon);
802 Eina_Bool fdo = EINA_FALSE;
804 if (!_elm_icon_standard_set(wd, obj, wd->stdicon, &fdo) || (!fdo))
805 evas_object_event_callback_del_full(obj, EVAS_CALLBACK_RESIZE,
806 _elm_icon_standard_resize, wd);
807 #ifdef HAVE_ELEMENTARY_ETHUMB
808 if (wd->thumb.file.path)
809 elm_icon_thumb_set(obj, wd->thumb.file.path, wd->thumb.file.key);
812 eina_stringshare_del(refup);
816 elm_icon_standard_set(Evas_Object *obj, const char *name)
818 ELM_CHECK_WIDTYPE(obj, widtype) EINA_FALSE;
819 Widget_Data *wd = elm_widget_data_get(obj);
820 Eina_Bool fdo = EINA_FALSE;
823 if ((!wd) || (!name)) return EINA_FALSE;
825 evas_object_event_callback_del_full(obj, EVAS_CALLBACK_RESIZE,
826 _elm_icon_standard_resize, wd);
828 ret = _elm_icon_standard_set(wd, obj, name, &fdo);
831 evas_object_event_callback_add(obj, EVAS_CALLBACK_RESIZE,
832 _elm_icon_standard_resize, wd);
838 elm_icon_standard_get(const Evas_Object *obj)
840 ELM_CHECK_WIDTYPE(obj, widtype) NULL;
841 Widget_Data *wd = elm_widget_data_get(obj);
842 if (!wd) return NULL;
847 elm_icon_order_lookup_set(Evas_Object *obj, Elm_Icon_Lookup_Order order)
849 ELM_CHECK_WIDTYPE(obj, widtype);
850 Widget_Data *wd = elm_widget_data_get(obj);
851 if (wd) wd->lookup_order = order;
854 EAPI Elm_Icon_Lookup_Order
855 elm_icon_order_lookup_get(const Evas_Object *obj)
857 ELM_CHECK_WIDTYPE(obj, widtype) ELM_ICON_LOOKUP_THEME_FDO;
858 Widget_Data *wd = elm_widget_data_get(obj);
859 if (!wd) return ELM_ICON_LOOKUP_THEME_FDO;
860 return wd->lookup_order;
864 elm_icon_smooth_set(Evas_Object *obj, Eina_Bool smooth)
866 ELM_CHECK_WIDTYPE(obj, widtype);
867 Widget_Data *wd = elm_widget_data_get(obj);
875 elm_icon_smooth_get(const Evas_Object *obj)
877 ELM_CHECK_WIDTYPE(obj, widtype) EINA_FALSE;
878 Widget_Data *wd = elm_widget_data_get(obj);
880 if (!wd) return EINA_FALSE;
885 elm_icon_no_scale_set(Evas_Object *obj, Eina_Bool no_scale)
887 ELM_CHECK_WIDTYPE(obj, widtype);
888 Widget_Data *wd = elm_widget_data_get(obj);
891 wd->no_scale = no_scale;
896 elm_icon_no_scale_get(const Evas_Object *obj)
898 ELM_CHECK_WIDTYPE(obj, widtype) EINA_FALSE;
899 Widget_Data *wd = elm_widget_data_get(obj);
900 if (!wd) return EINA_FALSE;
905 elm_icon_scale_set(Evas_Object *obj, Eina_Bool scale_up, Eina_Bool scale_down)
907 ELM_CHECK_WIDTYPE(obj, widtype);
908 Widget_Data *wd = elm_widget_data_get(obj);
911 wd->scale_up = scale_up;
912 wd->scale_down = scale_down;
917 elm_icon_scale_get(const Evas_Object *obj, Eina_Bool *scale_up, Eina_Bool *scale_down)
919 ELM_CHECK_WIDTYPE(obj, widtype);
920 Widget_Data *wd = elm_widget_data_get(obj);
922 if (scale_up) *scale_up = wd->scale_up;
923 if (scale_down) *scale_down = wd->scale_down;
927 elm_icon_fill_outside_set(Evas_Object *obj, Eina_Bool fill_outside)
929 ELM_CHECK_WIDTYPE(obj, widtype);
930 Widget_Data *wd = elm_widget_data_get(obj);
933 wd->fill_outside = fill_outside;
938 elm_icon_fill_outside_get(const Evas_Object *obj)
940 ELM_CHECK_WIDTYPE(obj, widtype) EINA_FALSE;
941 Widget_Data *wd = elm_widget_data_get(obj);
943 if (!wd) return EINA_FALSE;
944 return wd->fill_outside;
948 elm_icon_prescale_set(Evas_Object *obj, int size)
950 ELM_CHECK_WIDTYPE(obj, widtype);
951 Widget_Data *wd = elm_widget_data_get(obj);
954 _els_smart_icon_scale_size_set(wd->img, size);
958 elm_icon_prescale_get(const Evas_Object *obj)
960 ELM_CHECK_WIDTYPE(obj, widtype) 0;
961 Widget_Data *wd = elm_widget_data_get(obj);
964 return _els_smart_icon_scale_size_get(wd->img);
968 elm_icon_object_get(Evas_Object *obj)
970 ELM_CHECK_WIDTYPE(obj, widtype) 0;
971 Widget_Data *wd = elm_widget_data_get(obj);
973 if (!wd) return NULL;
978 elm_icon_preload_set(Evas_Object *obj, Eina_Bool disable)
980 ELM_CHECK_WIDTYPE(obj, widtype);
981 Widget_Data *wd = elm_widget_data_get(obj);
984 _els_smart_icon_preload_set(wd->img, disable);