#ifndef ELM_WIDGET_PHOTO_H #define ELM_WIDGET_PHOTO_H #include "Elementary.h" /** * @addtogroup Widget * @{ * * @section elm-photo-class The Elementary Photo Class * * Elementary, besides having the @ref Photo widget, exposes its * foundation -- the Elementary Photo Class -- in order to create * other widgets which are a photo with some more logic on top. */ /** * Base widget smart data extended with photo instance data. */ typedef struct _Elm_Photo_Smart_Data Elm_Photo_Smart_Data; struct _Elm_Photo_Smart_Data { Evas_Object *icon; int size; Eina_Bool fill_inside; Ecore_Timer *long_press_timer; #ifdef HAVE_ELEMENTARY_ETHUMB struct { struct { const char *path; const char *key; } file, thumb; } thumb; #endif }; /** * @} */ #define ELM_PHOTO_DATA_GET(o, sd) \ Elm_Photo_Smart_Data * sd = eo_data_scope_get(o, ELM_OBJ_PHOTO_CLASS) #define ELM_PHOTO_DATA_GET_OR_RETURN(o, ptr) \ ELM_PHOTO_DATA_GET(o, ptr); \ if (!ptr) \ { \ CRITICAL("No widget data for object %p (%s)", \ o, evas_object_type_get(o)); \ return; \ } #define ELM_PHOTO_DATA_GET_OR_RETURN_VAL(o, ptr, val) \ ELM_PHOTO_DATA_GET(o, ptr); \ if (!ptr) \ { \ CRITICAL("No widget data for object %p (%s)", \ o, evas_object_type_get(o)); \ return val; \ } #define ELM_PHOTO_CHECK(obj) \ if (!eo_isa((obj), ELM_OBJ_PHOTO_CLASS)) \ return #endif