2012-07-31 15:07:07 -07:00
# ifndef ELM_WIDGET_GENGRID_H
# define ELM_WIDGET_GENGRID_H
# include "elm_gen_common.h"
2012-11-25 22:32:53 -08:00
# include "Elementary.h"
2012-07-31 15:07:07 -07:00
/**
* @ addtogroup Widget
* @ {
*
* @ section elm - gengrid - class The Elementary Gengrid Class
*
* Elementary , besides having the @ ref Gengrid widget , exposes its
* foundation - - the Elementary Gengrid Class - - in order to create
* other widgets which are a gengrid with some more logic on top .
*/
/**
* Base widget smart data extended with gengrid instance data .
*/
2014-04-01 04:50:40 -07:00
typedef struct _Elm_Gengrid_Data Elm_Gengrid_Data ;
struct _Elm_Gengrid_Data
2012-07-31 15:07:07 -07:00
{
Eina_Inlist_Sorted_State * state ;
Evas_Object * hit_rect ;
Evas_Object * pan_obj ;
2012-11-25 22:32:53 -08:00
Evas_Object * obj ; // the object itself
2013-08-26 03:55:21 -07:00
Evas_Object * stack ; // stacking markers in pan for selectraise feature
2012-07-31 15:07:07 -07:00
Eina_List * selected ; /* a list of
* selected
* items */
Eina_List * group_items ; /* a list of
* groups index
* items */
Eina_Inlist * items ; /* an inlist of all items */
Elm_Gen_Item * reorder_it ; /* item currently
* being
* repositioned */
Elm_Object_Item * last_selected_item ;
2014-03-21 01:00:46 -07:00
Elm_Object_Item * focused_item ; /**< a focused item by keypad arrow or mouse. This is set to NULL if widget looses focus. */
Elm_Object_Item * last_focused_item ; /**< This records the last focused item when widget looses focus. This is required to set the focus on last focused item when widgets gets focus. */
2013-01-03 04:03:55 -08:00
Elm_Gen_Item * show_it ;
Elm_Gen_Item * bring_in_it ;
2014-01-20 23:54:59 -08:00
Elm_Gengrid_Item_Scrollto_Type scroll_to_type ;
2012-07-31 15:07:07 -07:00
Ecore_Job * calc_job ;
int walking ;
int item_width , item_height ;
int group_item_width , group_item_height ;
int minw , minh ;
unsigned int item_count ;
Evas_Coord pan_x , pan_y ;
Elm_Object_Select_Mode select_mode ;
2013-11-03 06:58:57 -08:00
Elm_Object_Multi_Select_Mode multi_select_mode ; /**< select mode for multiple selection */
2012-07-31 15:07:07 -07:00
Ecore_Cb calc_cb ;
Ecore_Cb clear_cb ;
/* longpress timeout. this value comes from _elm_config by
* default . this can be changed by
2012-11-07 19:58:48 -08:00
* elm_config_longpress_timeout_set ( ) */
2012-07-31 15:07:07 -07:00
double longpress_timeout ;
/* a generation of gengrid. when gengrid is cleared, this value
* will be increased and a new generation will start */
int generation ;
Eina_Compare_Cb item_compare_cb ;
/* The stuff below directly come from gengrid without any thinking */
unsigned int nmax ;
Evas_Coord reorder_item_x , reorder_item_y ;
Evas_Coord old_pan_x , old_pan_y ;
long items_lost ;
double align_x , align_y ;
2014-04-23 05:13:57 -07:00
struct
{
Elm_Gen_Item * it1 , * it2 ; /**< The items which are getting swapped */
2014-07-08 23:09:43 -07:00
void * data ; /**< This is the data used to store information related to animation */
2014-04-23 05:13:57 -07:00
Elm_Focus_Direction dir ; /**< focus key direction */
Ecore_Pos_Map tween_mode ; /**< Position mappings for animation */
Evas_Coord x1 , y1 , x2 , y2 ; /**< Coordinates of it1 and it2 */
2014-07-08 23:09:43 -07:00
Elm_Gengrid_Reorder_Type type ; /**< Reorder type */
2014-04-23 05:13:57 -07:00
Eina_Bool running : 1 ; /**< animation is happening */
} reorder ;
2012-07-31 15:07:07 -07:00
Eina_Bool reorder_item_changed : 1 ;
Eina_Bool move_effect_enabled : 1 ;
Eina_Bool old_h_bounce ;
Eina_Bool old_v_bounce ;
/* a flag for reorder mode enable/disable */
Eina_Bool reorder_mode : 1 ;
Eina_Bool was_selected : 1 ;
Eina_Bool longpressed : 1 ;
Eina_Bool pan_changed : 1 ;
Eina_Bool horizontal : 1 ;
/* a flag for items can be highlighted or not. by default this flag
* is true . */
Eina_Bool highlight : 1 ;
Eina_Bool clear_me : 1 ; /**< a flag whether
* gengrid is marked
* as to be cleared or
* not . if this flag
* is true , gengrid
* clear was already
* deferred . */
Eina_Bool on_hold : 1 ;
Eina_Bool filled : 1 ;
Eina_Bool multi : 1 ; /* a flag for item
* multi
* selection */
2013-01-03 04:03:55 -08:00
Eina_Bool show_region : 1 ;
Eina_Bool bring_in : 1 ;
2014-03-22 07:51:52 -07:00
Eina_Bool mouse_down : 1 ; /**< a flag that mouse is down on the list at the moment. this flag is set to true on mouse and reset to false on mouse up */
2014-04-26 21:43:37 -07:00
Eina_Bool wheel_disabled : 1 ; /**< a flag that shows mouse wheel is disabled or not. */
2014-06-09 22:55:56 -07:00
/**< value whether item loop feature is enabled or not. */
Eina_Bool item_loop_enable : 1 ;
2012-07-31 15:07:07 -07:00
} ;
struct Elm_Gen_Item_Type
{
Elm_Gen_Item * it ;
2014-04-01 04:50:40 -07:00
Elm_Gengrid_Data * wsd ;
2012-07-31 15:07:07 -07:00
Ecore_Animator * item_reorder_move_animator ;
Evas_Coord gx , gy , ox , oy , tx , ty , rx , ry ;
unsigned int moving_effect_start_time ;
int prev_group ;
Eina_Bool group_realized : 1 ;
Eina_Bool moving : 1 ;
} ;
2014-04-01 04:50:40 -07:00
typedef struct _Elm_Gengrid_Pan_Data Elm_Gengrid_Pan_Data ;
struct _Elm_Gengrid_Pan_Data
2012-07-31 15:07:07 -07:00
{
2012-11-25 22:32:53 -08:00
Evas_Object * wobj ;
2014-04-01 04:50:40 -07:00
Elm_Gengrid_Data * wsd ;
2012-07-31 15:07:07 -07:00
Ecore_Job * resize_job ;
} ;
/**
* @ }
*/
# define ELM_GENGRID_DATA_GET(o, sd) \
2014-06-03 03:35:28 -07:00
Elm_Gengrid_Data * sd = eo_data_scope_get ( o , ELM_GENGRID_CLASS )
2012-07-31 15:07:07 -07:00
# define ELM_GENGRID_PAN_DATA_GET(o, sd) \
2014-06-03 03:35:28 -07:00
Elm_Gengrid_Pan_Data * sd = eo_data_scope_get ( o , ELM_GENGRID_PAN_CLASS )
2012-07-31 15:07:07 -07:00
# define ELM_GENGRID_DATA_GET_OR_RETURN(o, ptr) \
ELM_GENGRID_DATA_GET ( o , ptr ) ; \
2014-01-15 10:33:40 -08:00
if ( EINA_UNLIKELY ( ! ptr ) ) \
2012-07-31 15:07:07 -07:00
{ \
2014-01-15 10:33:40 -08:00
CRI ( " No widget data for object %p (%s) " , \
o , evas_object_type_get ( o ) ) ; \
2012-07-31 15:07:07 -07:00
return ; \
}
# define ELM_GENGRID_DATA_GET_OR_RETURN_VAL(o, ptr, val) \
ELM_GENGRID_DATA_GET ( o , ptr ) ; \
2014-01-15 10:33:40 -08:00
if ( EINA_UNLIKELY ( ! ptr ) ) \
2012-07-31 15:07:07 -07:00
{ \
2014-01-15 10:33:40 -08:00
CRI ( " No widget data for object %p (%s) " , \
o , evas_object_type_get ( o ) ) ; \
2012-07-31 15:07:07 -07:00
return val ; \
}
2014-01-15 10:33:40 -08:00
# define ELM_GENGRID_CHECK(obj) \
2014-06-03 03:35:28 -07:00
if ( EINA_UNLIKELY ( ! eo_isa ( ( obj ) , ELM_GENGRID_CLASS ) ) ) \
2012-07-31 15:07:07 -07:00
return
# define ELM_GENGRID_ITEM_CHECK(it) \
ELM_WIDGET_ITEM_CHECK_OR_RETURN ( ( Elm_Widget_Item * ) it , ) ; \
ELM_GENGRID_CHECK ( it - > base . widget ) ;
# define ELM_GENGRID_ITEM_CHECK_OR_RETURN(it, ...) \
ELM_WIDGET_ITEM_CHECK_OR_RETURN ( ( Elm_Widget_Item * ) it , __VA_ARGS__ ) ; \
ELM_GENGRID_CHECK ( it - > base . widget ) __VA_ARGS__ ;
# define ELM_GENGRID_ITEM_CHECK_OR_GOTO(it, label) \
ELM_WIDGET_ITEM_CHECK_OR_GOTO ( ( Elm_Widget_Item * ) it , label ) ; \
2012-11-25 22:32:53 -08:00
if ( ! it - > base . widget | | ! eo_isa \
2014-06-03 03:35:28 -07:00
( ( it - > base . widget ) , ELM_GENGRID_CLASS ) ) goto label ;
2012-07-31 15:07:07 -07:00
# endif