| Macros | |
| #define | ELM_HOVER_CLASS elm_hover_class_get() | 
| Elementary hover class. | |
| #define | ELM_HOVER_EVENT_SMART_CHANGED (&(_ELM_HOVER_EVENT_SMART_CHANGED)) | 
| Called when hover changed. | |
| #define | ELM_HOVER_EVENT_DISMISSED (&(_ELM_HOVER_EVENT_DISMISSED)) | 
| Called when hover was dismissed. | |
| Enumerations | |
| enum | Elm_Hover_Axis { ELM_HOVER_AXIS_NONE = 0, ELM_HOVER_AXIS_HORIZONTAL, ELM_HOVER_AXIS_VERTICAL, ELM_HOVER_AXIS_BOTH, ELM_HOVER_AXIS_NONE = 0, ELM_HOVER_AXIS_HORIZONTAL, ELM_HOVER_AXIS_VERTICAL, ELM_HOVER_AXIS_BOTH } | 
| The orientation axis for the hover object.  More... | |
| enum | Elm_Hover_Axis { ELM_HOVER_AXIS_NONE = 0, ELM_HOVER_AXIS_HORIZONTAL, ELM_HOVER_AXIS_VERTICAL, ELM_HOVER_AXIS_BOTH, ELM_HOVER_AXIS_NONE = 0, ELM_HOVER_AXIS_HORIZONTAL, ELM_HOVER_AXIS_VERTICAL, ELM_HOVER_AXIS_BOTH } | 
| The orientation axis for the hover object.  More... | |
| Functions | |
| EOAPI void | elm_obj_hover_target_set (Eo *obj, Efl_Canvas_Object *target) | 
| Sets the target object for the hover.  More... | |
| EOAPI Efl_Canvas_Object * | elm_obj_hover_target_get (const Eo *obj) | 
| Get the target object for the hover.  More... | |
| EOAPI const char * | elm_obj_hover_best_content_location_get (const Eo *obj, Elm_Hover_Axis pref_axis) | 
| Returns the best swallow location for content in the hover.  More... | |
| EOAPI void | elm_obj_hover_dismiss (Eo *obj) | 
| Dismiss a hover object. | |
| void | elm_hover_target_set (Elm_Hover *obj, Efl_Canvas_Object *target) | 
| Sets the target object for the hover.  More... | |
| Efl_Canvas_Object * | elm_hover_target_get (const Elm_Hover *obj) | 
| Get the target object for the hover.  More... | |
| const char * | elm_hover_best_content_location_get (const Elm_Hover *obj, Elm_Hover_Axis pref_axis) | 
| Returns the best swallow location for content in the hover.  More... | |
| void | elm_hover_dismiss (Elm_Hover *obj) | 
| Dismiss a hover object. | |
| Evas_Object * | elm_hover_add (Evas_Object *parent) | 
| Adds a hover object to parent.  More... | |
| void | elm_hover_parent_set (Evas_Object *obj, Evas_Object *parent) | 
| Sets the parent object for the hover.  More... | |
| Evas_Object * | elm_hover_parent_get (const Evas_Object *obj) | 
| Get the parent object for the hover.  More... | |
 
 
A Hover object will hover over its parent object at the target location. Anything in the background will be given a darker coloring to indicate that the hover object is on top (at the default theme). When the hover is clicked it is dismissed(hidden), if the contents of the hover are clicked that doesn't cause the hover to be dismissed.
A Hover object has two parents. One parent that owns it during creation and the other parent being the one over which the hover object spans.
target object.Elementary has the following styles for the hover widget:
This widget inherits from the Layout one, so that all the functions acting on it also work for hover objects.
This widget emits the following signals, besides the ones sent from Layout:
"clicked" - the user clicked the empty space in the hover to dismiss "dismissed" - the user clicked the empty space in the hover to dismiss (since 1.8) "smart,changed" - a content object placed under the "smart" policy was replaced to a new slot direction. "focused" - When the hover has received focus. (since 1.8) "unfocused" - When the hover has lost focus. (since 1.8)Default content parts of the hover widget that you can use for are:
"left" "top-left" "top" "top-right" "right" "bottom-right" "bottom" "bottom-left" "middle" "smart" All directions may have contents at the same time, except for "smart". This is a special placement hint and its use case depends of the calculations coming from elm_hover_best_content_location_get(). Its use is for cases when one desires only one hover content, but with a dynamic special placement within the hover area. The content's geometry, whenever it changes, will be used to decide on a best location, not extrapolating the hover's parent object view to show it in (still being the hover's target determinant of its medium part – move and resize it to simulate finger sizes, for example). If one of the directions other than "smart" are used, a previously content set using it will be deleted, and vice-versa.
Supported elm_object common APIs.
See tutorial_hover for more information.
| enum Elm_Hover_Axis | 
The orientation axis for the hover object.
| enum Elm_Hover_Axis | 
The orientation axis for the hover object.
| EOAPI void elm_obj_hover_target_set | ( | Eo * | obj, | 
| Efl_Canvas_Object * | target | ||
| ) | 
Sets the target object for the hover.
This function will cause the hover to be centered on the target object.
| [in] | target | The target object. | 
Referenced by elm_hover_target_set().
| EOAPI Efl_Canvas_Object* elm_obj_hover_target_get | ( | const Eo * | obj | ) | 
Get the target object for the hover.
Referenced by elm_hover_target_get().
| EOAPI const char* elm_obj_hover_best_content_location_get | ( | const Eo * | obj, | 
| Elm_Hover_Axis | pref_axis | ||
| ) | 
Returns the best swallow location for content in the hover.
Best is defined here as the location at which there is the most available space.
pref_axis may be either ELM_HOVER_AXIS_NONE (for no preferred orientation), ELM_HOVER_AXIS_HORIZONTAL, ELM_HOVER_AXIS_VERTICAL or ELM_HOVER_AXIS_BOTH.
If ELM_HOVER_AXIS_HORIZONTAL is chosen the returned position will necessarily be along the horizontal axis("left" or "right"). If ELM_HOVER_AXIS_VERTICAL is chosen the returned position will necessarily be along the vertical axis("top" or "bottom"). Choosing ELM_HOVER_AXIS_BOTH or ELM_HOVER_AXIS_NONE has the same effect and the returned position may be in either axis.
See also elm_object_part_content_set.
| [in] | pref_axis | The preferred orientation axis for the hover object to use | 
Referenced by elm_hover_best_content_location_get().
| void elm_hover_target_set | ( | Elm_Hover * | obj, | 
| Efl_Canvas_Object * | target | ||
| ) | 
Sets the target object for the hover.
This function will cause the hover to be centered on the target object.
| [in] | target | The target object. | 
References elm_obj_hover_target_set().
| Efl_Canvas_Object* elm_hover_target_get | ( | const Elm_Hover * | obj | ) | 
Get the target object for the hover.
References elm_obj_hover_target_get().
| const char* elm_hover_best_content_location_get | ( | const Elm_Hover * | obj, | 
| Elm_Hover_Axis | pref_axis | ||
| ) | 
Returns the best swallow location for content in the hover.
Best is defined here as the location at which there is the most available space.
pref_axis may be either ELM_HOVER_AXIS_NONE (for no preferred orientation), ELM_HOVER_AXIS_HORIZONTAL, ELM_HOVER_AXIS_VERTICAL or ELM_HOVER_AXIS_BOTH.
If ELM_HOVER_AXIS_HORIZONTAL is chosen the returned position will necessarily be along the horizontal axis("left" or "right"). If ELM_HOVER_AXIS_VERTICAL is chosen the returned position will necessarily be along the vertical axis("top" or "bottom"). Choosing ELM_HOVER_AXIS_BOTH or ELM_HOVER_AXIS_NONE has the same effect and the returned position may be in either axis.
See also elm_object_part_content_set.
| [in] | pref_axis | The preferred orientation axis for the hover object to use | 
References elm_obj_hover_best_content_location_get().
| Evas_Object* elm_hover_add | ( | Evas_Object * | parent | ) | 
Adds a hover object to parent. 
| parent | The parent object | 
| void elm_hover_parent_set | ( | Evas_Object * | obj, | 
| Evas_Object * | parent | ||
| ) | 
Sets the parent object for the hover.
| obj | The hover object | 
| parent | The object to locate the hover over. | 
This function will cause the hover to take up the entire space that the parent object fills.
References elm_layout_sizing_eval(), EVAS_CALLBACK_DEL, EVAS_CALLBACK_HIDE, EVAS_CALLBACK_MOVE, EVAS_CALLBACK_RESIZE, EVAS_CALLBACK_SHOW, and evas_object_event_callback_add().
Referenced by elm_menu_parent_set().
| Evas_Object* elm_hover_parent_get | ( | const Evas_Object * | obj | ) | 
Get the parent object for the hover.
| obj | The hover object | 
References EINA_TRUE, ELM_HOVER_AXIS_HORIZONTAL, ELM_HOVER_AXIS_VERTICAL, elm_layout_data_get(), elm_layout_signal_emit(), elm_obj_hover_dismiss(), and evas_smart_legacy_type_register().