forked from enlightenment/efl
elementary: welcome to group in gengrid. Still need some work with reorder...
SVN revision: 63306
This commit is contained in:
parent
783b313aba
commit
17748b5a0f
|
@ -1199,5 +1199,276 @@ group { name: "elm/gengrid/item/thumb/default";
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
group { name: "elm/gengrid/item/group_index/default";
|
||||
data.item: "selectraise" "on";
|
||||
data.item: "labels" "elm.text";
|
||||
data.item: "icons" "elm.swallow.icon elm.swallow.end";
|
||||
// data.item: "states" "";
|
||||
images {
|
||||
image: "bt_sm_base1.png" COMP;
|
||||
image: "bt_sm_shine.png" COMP;
|
||||
image: "bt_sm_hilight.png" COMP;
|
||||
image: "ilist_item_shadow.png" COMP;
|
||||
image: "group_index.png" COMP;
|
||||
}
|
||||
parts {
|
||||
part {
|
||||
name: "event";
|
||||
type: RECT;
|
||||
repeat_events: 0;
|
||||
description {
|
||||
state: "default" 0.0;
|
||||
color: 0 0 0 0;
|
||||
}
|
||||
}
|
||||
part {
|
||||
name: "base_sh";
|
||||
mouse_events: 0;
|
||||
description {
|
||||
state: "default" 0.0;
|
||||
align: 0.0 0.0;
|
||||
min: 0 10;
|
||||
fixed: 1 1;
|
||||
rel1 {
|
||||
to: "base";
|
||||
relative: 0.0 1.0;
|
||||
offset: 0 0;
|
||||
}
|
||||
rel2 {
|
||||
to: "base";
|
||||
relative: 1.0 1.0;
|
||||
offset: -1 0;
|
||||
}
|
||||
image {
|
||||
normal: "ilist_item_shadow.png";
|
||||
}
|
||||
fill.smooth: 0;
|
||||
}
|
||||
}
|
||||
part {
|
||||
name: "base";
|
||||
mouse_events: 0;
|
||||
description {
|
||||
state: "default" 0.0;
|
||||
image {
|
||||
normal: "group_index.png";
|
||||
border: 2 2 2 2;
|
||||
}
|
||||
fill.smooth: 0;
|
||||
}
|
||||
}
|
||||
part { name: "bg";
|
||||
clip_to: "disclip";
|
||||
mouse_events: 0;
|
||||
description { state: "default" 0.0;
|
||||
visible: 0;
|
||||
color: 255 255 255 0;
|
||||
rel1 {
|
||||
relative: 0.0 0.0;
|
||||
offset: -5 -5;
|
||||
}
|
||||
rel2 {
|
||||
relative: 1.0 1.0;
|
||||
offset: 4 4;
|
||||
}
|
||||
image {
|
||||
normal: "bt_sm_base1.png";
|
||||
border: 6 6 6 6;
|
||||
}
|
||||
image.middle: SOLID;
|
||||
}
|
||||
description { state: "selected" 0.0;
|
||||
inherit: "default" 0.0;
|
||||
visible: 1;
|
||||
color: 255 255 255 255;
|
||||
rel1 {
|
||||
relative: 0.0 0.0;
|
||||
offset: -2 -2;
|
||||
}
|
||||
rel2 {
|
||||
relative: 1.0 1.0;
|
||||
offset: 1 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
part { name: "elm.swallow.pad";
|
||||
type: SWALLOW;
|
||||
description { state: "default" 0.0;
|
||||
fixed: 1 0;
|
||||
align: 0.0 0.5;
|
||||
rel1 {
|
||||
relative: 0.0 0.0;
|
||||
offset: 4 4;
|
||||
}
|
||||
rel2 {
|
||||
relative: 0.0 1.0;
|
||||
offset: 4 -5;
|
||||
}
|
||||
}
|
||||
}
|
||||
part { name: "elm.swallow.icon";
|
||||
clip_to: "disclip";
|
||||
type: SWALLOW;
|
||||
description { state: "default" 0.0;
|
||||
fixed: 1 0;
|
||||
align: 0.0 0.5;
|
||||
rel1 {
|
||||
to_x: "elm.swallow.pad";
|
||||
relative: 1.0 0.0;
|
||||
offset: -1 4;
|
||||
}
|
||||
rel2 {
|
||||
to_x: "elm.swallow.pad";
|
||||
relative: 1.0 1.0;
|
||||
offset: -1 -5;
|
||||
}
|
||||
}
|
||||
}
|
||||
part { name: "elm.swallow.end";
|
||||
clip_to: "disclip";
|
||||
type: SWALLOW;
|
||||
description { state: "default" 0.0;
|
||||
fixed: 1 0;
|
||||
align: 1.0 0.5;
|
||||
aspect: 1.0 1.0;
|
||||
aspect_preference: VERTICAL;
|
||||
rel1 {
|
||||
relative: 1.0 0.0;
|
||||
offset: -5 4;
|
||||
}
|
||||
rel2 {
|
||||
relative: 1.0 1.0;
|
||||
offset: -5 -5;
|
||||
}
|
||||
}
|
||||
}
|
||||
part { name: "elm.text";
|
||||
clip_to: "disclip";
|
||||
type: TEXT;
|
||||
effect: SOFT_SHADOW;
|
||||
mouse_events: 0;
|
||||
scale: 1;
|
||||
description {
|
||||
state: "default" 0.0;
|
||||
// min: 16 16;
|
||||
rel1 {
|
||||
to_x: "elm.swallow.icon";
|
||||
relative: 1.0 0.0;
|
||||
offset: 0 4;
|
||||
}
|
||||
rel2 {
|
||||
to_x: "elm.swallow.end";
|
||||
relative: 0.0 1.0;
|
||||
offset: -1 -5;
|
||||
}
|
||||
color: 0 0 0 255;
|
||||
color3: 0 0 0 0;
|
||||
text {
|
||||
font: "Sans";
|
||||
size: 10;
|
||||
min: 1 1;
|
||||
// min: 0 1;
|
||||
align: -1.0 0.5;
|
||||
text_class: "list_item";
|
||||
}
|
||||
}
|
||||
description { state: "selected" 0.0;
|
||||
inherit: "default" 0.0;
|
||||
color: 224 224 224 255;
|
||||
color3: 0 0 0 64;
|
||||
}
|
||||
}
|
||||
part { name: "fg1";
|
||||
clip_to: "disclip";
|
||||
mouse_events: 0;
|
||||
description { state: "default" 0.0;
|
||||
visible: 0;
|
||||
color: 255 255 255 0;
|
||||
rel1.to: "bg";
|
||||
rel2.relative: 1.0 0.5;
|
||||
rel2.to: "bg";
|
||||
image {
|
||||
normal: "bt_sm_hilight.png";
|
||||
border: 6 6 6 0;
|
||||
}
|
||||
}
|
||||
description { state: "selected" 0.0;
|
||||
inherit: "default" 0.0;
|
||||
visible: 1;
|
||||
color: 255 255 255 255;
|
||||
}
|
||||
}
|
||||
part { name: "fg2";
|
||||
clip_to: "disclip";
|
||||
mouse_events: 0;
|
||||
description { state: "default" 0.0;
|
||||
visible: 0;
|
||||
color: 255 255 255 0;
|
||||
rel1.to: "bg";
|
||||
rel2.to: "bg";
|
||||
image {
|
||||
normal: "bt_sm_shine.png";
|
||||
border: 6 6 6 0;
|
||||
}
|
||||
}
|
||||
description { state: "selected" 0.0;
|
||||
inherit: "default" 0.0;
|
||||
visible: 1;
|
||||
color: 255 255 255 255;
|
||||
}
|
||||
}
|
||||
part { name: "disclip";
|
||||
type: RECT;
|
||||
description { state: "default" 0.0;
|
||||
rel1.to: "bg";
|
||||
rel2.to: "bg";
|
||||
}
|
||||
description { state: "disabled" 0.0;
|
||||
inherit: "default" 0.0;
|
||||
color: 255 255 255 64;
|
||||
}
|
||||
}
|
||||
}
|
||||
programs {
|
||||
// signal: elm,state,%s,active
|
||||
// a "check" item named %s went active
|
||||
// signal: elm,state,%s,passive
|
||||
// a "check" item named %s went passive
|
||||
// default is passive
|
||||
program {
|
||||
name: "go_active";
|
||||
signal: "elm,state,selected";
|
||||
source: "elm";
|
||||
action: STATE_SET "selected" 0.0;
|
||||
target: "bg";
|
||||
target: "fg1";
|
||||
target: "fg2";
|
||||
target: "elm.text";
|
||||
}
|
||||
program {
|
||||
name: "go_passive";
|
||||
signal: "elm,state,unselected";
|
||||
source: "elm";
|
||||
action: STATE_SET "default" 0.0;
|
||||
target: "bg";
|
||||
target: "fg1";
|
||||
target: "fg2";
|
||||
target: "elm.text";
|
||||
transition: LINEAR 0.1;
|
||||
}
|
||||
program {
|
||||
name: "go_disabled";
|
||||
signal: "elm,state,disabled";
|
||||
source: "elm";
|
||||
action: STATE_SET "disabled" 0.0;
|
||||
target: "disclip";
|
||||
}
|
||||
program {
|
||||
name: "go_enabled";
|
||||
signal: "elm,state,enabled";
|
||||
source: "elm";
|
||||
action: STATE_SET "default" 0.0;
|
||||
target: "disclip";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -24,7 +24,7 @@ static const char *img[9] =
|
|||
"wood_01.jpg",
|
||||
};
|
||||
|
||||
static Elm_Gengrid_Item_Class gic;
|
||||
static Elm_Gengrid_Item_Class gic, ggic;
|
||||
|
||||
static void
|
||||
_horizontal_grid(void *data, Evas_Object *obj, void *event_info __UNUSED__)
|
||||
|
@ -362,4 +362,76 @@ test_gengrid2(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_in
|
|||
evas_object_resize(win, 600, 600);
|
||||
evas_object_show(win);
|
||||
}
|
||||
|
||||
void
|
||||
test_gengrid3(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
|
||||
{
|
||||
Evas_Object *win, *bg, *grid;
|
||||
static Testitem ti[144];
|
||||
int i, n;
|
||||
char buf[PATH_MAX];
|
||||
|
||||
win = elm_win_add(NULL, "gengrid_group", ELM_WIN_BASIC);
|
||||
elm_win_title_set(win, "GenGrid Group");
|
||||
elm_win_autodel_set(win, EINA_TRUE);
|
||||
|
||||
bg = elm_bg_add(win);
|
||||
evas_object_size_hint_weight_set(bg, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
|
||||
elm_win_resize_object_add(win, bg);
|
||||
evas_object_show(bg);
|
||||
|
||||
grid = elm_gengrid_add(win);
|
||||
elm_gengrid_item_size_set(grid, 150, 150);
|
||||
elm_gengrid_group_item_size_set(grid, 31, 31);
|
||||
//elm_gengrid_horizontal_set(grid, EINA_TRUE);
|
||||
elm_gengrid_horizontal_set(grid, EINA_FALSE);
|
||||
elm_gengrid_multi_select_set(grid, EINA_TRUE);
|
||||
elm_gengrid_reorder_mode_set(grid, EINA_TRUE);
|
||||
evas_object_smart_callback_add(grid, "selected", grid_selected, NULL);
|
||||
evas_object_smart_callback_add(grid, "clicked,double", grid_double_clicked, NULL);
|
||||
evas_object_smart_callback_add(grid, "longpressed", grid_longpress, NULL);
|
||||
evas_object_smart_callback_add(grid, "moved", grid_moved, NULL);
|
||||
evas_object_smart_callback_add(grid, "drag,start,up", grid_drag_up, NULL);
|
||||
evas_object_smart_callback_add(grid, "drag,start,right", grid_drag_right, NULL);
|
||||
evas_object_smart_callback_add(grid, "drag,start,down", grid_drag_down, NULL);
|
||||
evas_object_smart_callback_add(grid, "drag,start,left", grid_drag_left, NULL);
|
||||
evas_object_smart_callback_add(grid, "drag,stop", grid_drag_stop, NULL);
|
||||
evas_object_size_hint_weight_set(grid, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
|
||||
|
||||
gic.item_style = "default";
|
||||
gic.func.label_get = grid_label_get;
|
||||
gic.func.icon_get = grid_icon_get;
|
||||
gic.func.state_get = grid_state_get;
|
||||
gic.func.del = grid_del;
|
||||
|
||||
ggic.item_style = "group_index";
|
||||
ggic.func.label_get = grid_label_get;
|
||||
ggic.func.icon_get = NULL;
|
||||
ggic.func.state_get = NULL;
|
||||
ggic.func.del = NULL;
|
||||
|
||||
|
||||
n = 0;
|
||||
for (i = 0; i < 12 * 12; i++)
|
||||
{
|
||||
snprintf(buf, sizeof(buf), "%s/images/%s", elm_app_data_dir_get(), img[n]);
|
||||
n = (n + 1) % 9;
|
||||
ti[i].mode = i;
|
||||
ti[i].path = eina_stringshare_add(buf);
|
||||
if (i == 0 || i == 18 || i == 53 || i == 100)
|
||||
//if (i == 0 || i == 18)
|
||||
ti[i].item = elm_gengrid_item_append(grid, &ggic, &(ti[i]), grid_sel, NULL);
|
||||
else
|
||||
ti[i].item = elm_gengrid_item_append(grid, &gic, &(ti[i]), grid_sel, NULL);
|
||||
if (!(i % 5))
|
||||
elm_gengrid_item_selected_set(ti[i].item, EINA_TRUE);
|
||||
}
|
||||
|
||||
evas_object_show(grid);
|
||||
elm_win_resize_object_add(win, grid);
|
||||
|
||||
evas_object_resize(win, 600, 600);
|
||||
evas_object_show(win);
|
||||
}
|
||||
|
||||
#endif
|
||||
|
|
|
@ -7907,6 +7907,7 @@ extern "C" {
|
|||
* This function inserts a new gengrid widget on the canvas.
|
||||
*
|
||||
* @see elm_gengrid_item_size_set()
|
||||
* @see elm_gengrid_group_item_size_set()
|
||||
* @see elm_gengrid_horizontal_set()
|
||||
* @see elm_gengrid_item_append()
|
||||
* @see elm_gengrid_item_del()
|
||||
|
@ -7951,6 +7952,41 @@ extern "C" {
|
|||
*/
|
||||
EAPI void elm_gengrid_item_size_get(const Evas_Object *obj, Evas_Coord *w, Evas_Coord *h) EINA_ARG_NONNULL(1);
|
||||
|
||||
/**
|
||||
* Set the size for the group items of a given gengrid widget
|
||||
*
|
||||
* @param obj The gengrid object.
|
||||
* @param w The group items' width.
|
||||
* @param h The group items' height;
|
||||
*
|
||||
* A gengrid, after creation, has still no information on the size
|
||||
* to give to each of its cells. So, you most probably will end up
|
||||
* with squares one @ref Fingers "finger" wide, the default
|
||||
* size. Use this function to force a custom size for you group items,
|
||||
* making them as big as you wish.
|
||||
*
|
||||
* @see elm_gengrid_group_item_size_get()
|
||||
*
|
||||
* @ingroup Gengrid
|
||||
*/
|
||||
EAPI void elm_gengrid_group_item_size_set(Evas_Object *obj, Evas_Coord w, Evas_Coord h) EINA_ARG_NONNULL(1);
|
||||
|
||||
/**
|
||||
* Get the size set for the group items of a given gengrid widget
|
||||
*
|
||||
* @param obj The gengrid object.
|
||||
* @param w Pointer to a variable where to store the group items' width.
|
||||
* @param h Pointer to a variable where to store the group items' height.
|
||||
*
|
||||
* @note Use @c NULL pointers on the size values you're not
|
||||
* interested in: they'll be ignored by the function.
|
||||
*
|
||||
* @see elm_gengrid_group_item_size_get() for more details
|
||||
*
|
||||
* @ingroup Gengrid
|
||||
*/
|
||||
EAPI void elm_gengrid_group_item_size_get(const Evas_Object *obj, Evas_Coord *w, Evas_Coord *h) EINA_ARG_NONNULL(1);
|
||||
|
||||
/**
|
||||
* Set the items grid's alignment within a given gengrid widget
|
||||
*
|
||||
|
|
|
@ -19,6 +19,7 @@
|
|||
EINA_INLIST;
|
||||
Evas_Object *spacer;
|
||||
const Elm_Gengrid_Item_Class *gic;
|
||||
Elm_Gengrid_Item *parent_group_item;
|
||||
Ecore_Timer *long_timer;
|
||||
Ecore_Animator *item_moving_effect_timer;
|
||||
Widget_Data *wd;
|
||||
|
@ -29,10 +30,11 @@
|
|||
const void *data;
|
||||
} func;
|
||||
|
||||
Evas_Coord x, y, dx, dy, ox, oy, tx, ty, rx, ry;
|
||||
Evas_Coord x, y, gx, gy, dx, dy, ox, oy, tx, ty, rx, ry;
|
||||
unsigned int moving_effect_start_time;
|
||||
int relcount;
|
||||
int walking;
|
||||
int prev_group;
|
||||
|
||||
struct
|
||||
{
|
||||
|
@ -45,7 +47,9 @@
|
|||
|
||||
const char *mouse_cursor;
|
||||
|
||||
Eina_Bool is_group : 1;
|
||||
Eina_Bool want_unrealize : 1;
|
||||
Eina_Bool group_realized : 1;
|
||||
Eina_Bool realized : 1;
|
||||
Eina_Bool dragging : 1;
|
||||
Eina_Bool down : 1;
|
||||
|
@ -64,6 +68,7 @@ struct _Widget_Data
|
|||
Evas_Object *pan_smart;
|
||||
Pan *pan;
|
||||
Eina_Inlist *items;
|
||||
Eina_List *group_items;
|
||||
Ecore_Job *calc_job;
|
||||
Eina_List *selected;
|
||||
Elm_Gengrid_Item *last_selected_item, *reorder_item;
|
||||
|
@ -71,10 +76,12 @@ struct _Widget_Data
|
|||
|
||||
Evas_Coord pan_x, pan_y, old_pan_x, old_pan_y;
|
||||
Evas_Coord item_width, item_height; /* Each item size */
|
||||
Evas_Coord group_item_width, group_item_height; /* Each group item size */
|
||||
Evas_Coord minw, minh; /* Total obj size */
|
||||
Evas_Coord reorder_item_x, reorder_item_y;
|
||||
unsigned int nmax;
|
||||
long count;
|
||||
long items_lost;
|
||||
int walking;
|
||||
|
||||
Eina_Bool horizontal : 1;
|
||||
|
@ -978,29 +985,42 @@ _item_realize(Elm_Gengrid_Item *item)
|
|||
}
|
||||
}
|
||||
|
||||
if ((!item->wd->item_width) && (!item->wd->item_height))
|
||||
if (item->is_group)
|
||||
{
|
||||
edje_object_size_min_restricted_calc(item->base.view,
|
||||
&item->wd->item_width,
|
||||
&item->wd->item_height,
|
||||
item->wd->item_width,
|
||||
item->wd->item_height);
|
||||
elm_coords_finger_size_adjust(1, &item->wd->item_width,
|
||||
1, &item->wd->item_height);
|
||||
if ((!item->wd->group_item_width) && (!item->wd->group_item_height))
|
||||
{
|
||||
edje_object_size_min_restricted_calc(item->base.view,
|
||||
&item->wd->group_item_width,
|
||||
&item->wd->group_item_height,
|
||||
item->wd->group_item_width,
|
||||
item->wd->group_item_height);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if ((!item->wd->item_width) && (!item->wd->item_height))
|
||||
{
|
||||
edje_object_size_min_restricted_calc(item->base.view,
|
||||
&item->wd->item_width,
|
||||
&item->wd->item_height,
|
||||
item->wd->item_width,
|
||||
item->wd->item_height);
|
||||
elm_coords_finger_size_adjust(1, &item->wd->item_width,
|
||||
1, &item->wd->item_height);
|
||||
}
|
||||
|
||||
evas_object_event_callback_add(item->base.view, EVAS_CALLBACK_MOUSE_DOWN,
|
||||
_mouse_down, item);
|
||||
evas_object_event_callback_add(item->base.view, EVAS_CALLBACK_MOUSE_UP,
|
||||
_mouse_up, item);
|
||||
evas_object_event_callback_add(item->base.view, EVAS_CALLBACK_MOUSE_MOVE,
|
||||
_mouse_move, item);
|
||||
|
||||
if (item->selected)
|
||||
edje_object_signal_emit(item->base.view, "elm,state,selected", "elm");
|
||||
if (item->disabled)
|
||||
edje_object_signal_emit(item->base.view, "elm,state,disabled", "elm");
|
||||
evas_object_event_callback_add(item->base.view, EVAS_CALLBACK_MOUSE_DOWN,
|
||||
_mouse_down, item);
|
||||
evas_object_event_callback_add(item->base.view, EVAS_CALLBACK_MOUSE_UP,
|
||||
_mouse_up, item);
|
||||
evas_object_event_callback_add(item->base.view, EVAS_CALLBACK_MOUSE_MOVE,
|
||||
_mouse_move, item);
|
||||
|
||||
if (item->selected)
|
||||
edje_object_signal_emit(item->base.view, "elm,state,selected", "elm");
|
||||
if (item->disabled)
|
||||
edje_object_signal_emit(item->base.view, "elm,state,disabled", "elm");
|
||||
}
|
||||
evas_object_show(item->base.view);
|
||||
|
||||
if (item->tooltip.content_cb)
|
||||
|
@ -1075,26 +1095,87 @@ _reorder_item_moving_effect_timer_cb(void *data)
|
|||
(((dy > 0) && (item->ry >= item->ty)) || ((dy <= 0) && (item->ry <= item->ty))))
|
||||
{
|
||||
evas_object_move(item->base.view, item->tx, item->ty);
|
||||
evas_object_resize(item->base.view, item->wd->item_width, item->wd->item_height);
|
||||
if (item->is_group)
|
||||
{
|
||||
Evas_Coord vw, vh;
|
||||
evas_object_geometry_get(item->wd->pan_smart, NULL, NULL, &vw, &vh);
|
||||
if (item->wd->horizontal)
|
||||
evas_object_resize(item->base.view, item->wd->group_item_width, vh);
|
||||
else
|
||||
evas_object_resize(item->base.view, vw, item->wd->group_item_height);
|
||||
}
|
||||
else
|
||||
evas_object_resize(item->base.view, item->wd->item_width, item->wd->item_height);
|
||||
item->moving = EINA_FALSE;
|
||||
item->item_moving_effect_timer = NULL;
|
||||
return ECORE_CALLBACK_CANCEL;
|
||||
}
|
||||
|
||||
evas_object_move(item->base.view, item->rx, item->ry);
|
||||
evas_object_resize(item->base.view, item->wd->item_width, item->wd->item_height);
|
||||
if (item->is_group)
|
||||
{
|
||||
Evas_Coord vw, vh;
|
||||
evas_object_geometry_get(item->wd->pan_smart, NULL, NULL, &vw, &vh);
|
||||
if (item->wd->horizontal)
|
||||
evas_object_resize(item->base.view, item->wd->group_item_width, vh);
|
||||
else
|
||||
evas_object_resize(item->base.view, vw, item->wd->group_item_height);
|
||||
}
|
||||
else
|
||||
evas_object_resize(item->base.view, item->wd->item_width, item->wd->item_height);
|
||||
|
||||
return ECORE_CALLBACK_RENEW;
|
||||
}
|
||||
|
||||
static void
|
||||
_group_item_place(Pan *sd)
|
||||
{
|
||||
Evas_Coord iw, ih, vw, vh;
|
||||
Eina_List *l;
|
||||
Eina_Bool was_realized;
|
||||
Elm_Gengrid_Item *it;
|
||||
evas_object_geometry_get(sd->wd->pan_smart, NULL, NULL, &vw, &vh);
|
||||
if (sd->wd->horizontal)
|
||||
{
|
||||
iw = sd->wd->group_item_width;
|
||||
ih = vh;
|
||||
}
|
||||
else
|
||||
{
|
||||
iw = vw;
|
||||
ih = sd->wd->group_item_height;
|
||||
}
|
||||
EINA_LIST_FOREACH(sd->wd->group_items, l, it)
|
||||
{
|
||||
was_realized = it->realized;
|
||||
if (it->group_realized)
|
||||
{
|
||||
_item_realize(it);
|
||||
if (!was_realized)
|
||||
evas_object_smart_callback_call(it->wd->self, SIG_REALIZED, it);
|
||||
evas_object_move(it->base.view, it->gx, it->gy);
|
||||
evas_object_resize(it->base.view, iw, ih);
|
||||
evas_object_raise(it->base.view);
|
||||
}
|
||||
else
|
||||
{
|
||||
_item_unrealize(it);
|
||||
if (was_realized)
|
||||
evas_object_smart_callback_call(it->wd->self, SIG_UNREALIZED, it);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
_item_place(Elm_Gengrid_Item *item,
|
||||
Evas_Coord cx,
|
||||
Evas_Coord cy)
|
||||
{
|
||||
Evas_Coord x, y, ox, oy, cvx, cvy, cvw, cvh;
|
||||
Evas_Coord x, y, ox, oy, cvx, cvy, cvw, cvh, iw, ih, ww;
|
||||
Evas_Coord tch, tcw, alignw = 0, alignh = 0, vw, vh;
|
||||
Eina_Bool reorder_item_move_forward = EINA_FALSE;
|
||||
long items_count;
|
||||
item->x = cx;
|
||||
item->y = cy;
|
||||
evas_object_geometry_get(item->wd->pan_smart, &ox, &oy, &vw, &vh);
|
||||
|
@ -1108,6 +1189,7 @@ _item_place(Elm_Gengrid_Item *item,
|
|||
alignh = 0;
|
||||
alignw = 0;
|
||||
|
||||
items_count = item->wd->count - eina_list_count(item->wd->group_items) + item->wd->items_lost;
|
||||
if (item->wd->horizontal)
|
||||
{
|
||||
int columns, items_visible = 0, items_row;
|
||||
|
@ -1117,11 +1199,11 @@ _item_place(Elm_Gengrid_Item *item,
|
|||
if (items_visible < 1)
|
||||
items_visible = 1;
|
||||
|
||||
columns = item->wd->count / items_visible;
|
||||
if (item->wd->count % items_visible)
|
||||
columns = items_count / items_visible;
|
||||
if (items_count % items_visible)
|
||||
columns++;
|
||||
|
||||
tcw = item->wd->item_width * columns;
|
||||
tcw = (item->wd->item_width * columns) + (item->wd->group_item_width * eina_list_count(item->wd->group_items));
|
||||
alignw = (vw - tcw) * item->wd->align_x;
|
||||
|
||||
items_row = items_visible;
|
||||
|
@ -1139,11 +1221,11 @@ _item_place(Elm_Gengrid_Item *item,
|
|||
if (items_visible < 1)
|
||||
items_visible = 1;
|
||||
|
||||
rows = item->wd->count / items_visible;
|
||||
if (item->wd->count % items_visible)
|
||||
rows = items_count / items_visible;
|
||||
if (items_count % items_visible)
|
||||
rows++;
|
||||
|
||||
tch = item->wd->item_height * rows;
|
||||
tch = (item->wd->item_height * rows) + (item->wd->group_item_height * eina_list_count(item->wd->group_items));
|
||||
alignh = (vh - tch) * item->wd->align_y;
|
||||
|
||||
items_col = items_visible;
|
||||
|
@ -1153,23 +1235,74 @@ _item_place(Elm_Gengrid_Item *item,
|
|||
alignw = (vw - tcw) * item->wd->align_x;
|
||||
}
|
||||
|
||||
x = cx * item->wd->item_width - item->wd->pan_x + ox + alignw;
|
||||
if (elm_widget_mirrored_get(item->wd->self))
|
||||
{ /* Switch items side and componsate for pan_x when in RTL mode */
|
||||
Evas_Coord ww;
|
||||
evas_object_geometry_get(item->wd->self, NULL, NULL, &ww, NULL);
|
||||
x = ww - x - item->wd->item_width - item->wd->pan_x - item->wd->pan_x;
|
||||
if (item->is_group)
|
||||
{
|
||||
if (item->wd->horizontal)
|
||||
{
|
||||
x = (((cx - item->prev_group) * item->wd->item_width) + (item->prev_group * item->wd->group_item_width)) - item->wd->pan_x + ox + alignw;
|
||||
y = 0;
|
||||
iw = item->wd->group_item_width;
|
||||
ih = vh;
|
||||
}
|
||||
else
|
||||
{
|
||||
x = 0;
|
||||
y = (((cy - item->prev_group) * item->wd->item_height) + (item->prev_group * item->wd->group_item_height)) - item->wd->pan_y + oy + alignh;
|
||||
iw = vw;
|
||||
ih = item->wd->group_item_height;
|
||||
}
|
||||
item->gx = x;
|
||||
item->gy = y;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (item->wd->horizontal)
|
||||
{
|
||||
x = (((cx - item->prev_group) * item->wd->item_width) + (item->prev_group * item->wd->group_item_width)) - item->wd->pan_x + ox + alignw;
|
||||
y = (cy * item->wd->item_height) - item->wd->pan_y + oy + alignh;
|
||||
}
|
||||
else
|
||||
{
|
||||
x = (cx * item->wd->item_height) - item->wd->pan_x + ox + alignw;
|
||||
y = (((cy - item->prev_group) * item->wd->item_height) + (item->prev_group * item->wd->group_item_height)) - item->wd->pan_y + oy + alignh;
|
||||
}
|
||||
if (elm_widget_mirrored_get(item->wd->self))
|
||||
{ /* Switch items side and componsate for pan_x when in RTL mode */
|
||||
evas_object_geometry_get(item->wd->self, NULL, NULL, &ww, NULL);
|
||||
x = ww - x - item->wd->item_width - item->wd->pan_x - item->wd->pan_x;
|
||||
}
|
||||
iw = item->wd->item_width;
|
||||
ih = item->wd->item_height;
|
||||
}
|
||||
|
||||
y = cy * item->wd->item_height - item->wd->pan_y + oy + alignh;
|
||||
|
||||
Eina_Bool was_realized = item->realized;
|
||||
if (ELM_RECTS_INTERSECT(x, y, item->wd->item_width, item->wd->item_height,
|
||||
cvx, cvy, cvw, cvh))
|
||||
if (ELM_RECTS_INTERSECT(x, y, iw, ih, cvx, cvy, cvw, cvh))
|
||||
{
|
||||
_item_realize(item);
|
||||
if (!was_realized)
|
||||
evas_object_smart_callback_call(item->wd->self, SIG_REALIZED, item);
|
||||
if (item->parent_group_item)
|
||||
{
|
||||
if (item->wd->horizontal)
|
||||
{
|
||||
if (item->parent_group_item->gx < 0)
|
||||
{
|
||||
item->parent_group_item->gx = x + item->wd->item_width - item->wd->group_item_width;
|
||||
if (item->parent_group_item->gx > 0)
|
||||
item->parent_group_item->gx = 0;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if (item->parent_group_item->gy < 0)
|
||||
{
|
||||
item->parent_group_item->gy = y + item->wd->item_height - item->wd->group_item_height;
|
||||
if (item->parent_group_item->gy > 0)
|
||||
item->parent_group_item->gy = 0;
|
||||
}
|
||||
item->parent_group_item->group_realized = EINA_TRUE;
|
||||
}
|
||||
}
|
||||
if ((item->wd->reorder_mode) && (item->wd->reorder_item))
|
||||
{
|
||||
if (item->moving) return;
|
||||
|
@ -1183,8 +1316,7 @@ _item_place(Elm_Gengrid_Item *item,
|
|||
{
|
||||
evas_object_move(item->base.view,
|
||||
item->wd->reorder_item_x, item->wd->reorder_item_y);
|
||||
evas_object_resize(item->base.view,
|
||||
item->wd->item_width, item->wd->item_height);
|
||||
evas_object_resize(item->base.view, iw, ih);
|
||||
return;
|
||||
}
|
||||
else
|
||||
|
@ -1209,10 +1341,36 @@ _item_place(Elm_Gengrid_Item *item,
|
|||
}
|
||||
}
|
||||
|
||||
if (ELM_RECTS_INTERSECT(item->wd->reorder_item_x, item->wd->reorder_item_y,
|
||||
item->wd->item_width, item->wd->item_height,
|
||||
x+(item->wd->item_width/2), y+(item->wd->item_height/2),
|
||||
1, 1))
|
||||
/* need fix here */
|
||||
Evas_Coord nx, ny, nw, nh;
|
||||
if (item->is_group)
|
||||
{
|
||||
if (item->wd->horizontal)
|
||||
{
|
||||
nx = x + (item->wd->group_item_width / 2);
|
||||
ny = y;
|
||||
nw = 1;
|
||||
nh = vh;
|
||||
}
|
||||
else
|
||||
{
|
||||
nx = x;
|
||||
ny = y + (item->wd->group_item_height / 2);
|
||||
nw = vw;
|
||||
nh = 1;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
nx = x + (item->wd->item_width / 2);
|
||||
ny = y + (item->wd->item_height / 2);
|
||||
nw = 1;
|
||||
nh = 1;
|
||||
}
|
||||
|
||||
if ( ELM_RECTS_INTERSECT(item->wd->reorder_item_x, item->wd->reorder_item_y,
|
||||
item->wd->item_width, item->wd->item_height,
|
||||
nx, ny, nw, nh))
|
||||
{
|
||||
if (item->wd->horizontal)
|
||||
{
|
||||
|
@ -1243,19 +1401,28 @@ _item_place(Elm_Gengrid_Item *item,
|
|||
if (item->wd->calc_job) ecore_job_del(item->wd->calc_job);
|
||||
item->wd->calc_job = ecore_job_add(_calc_job, item->wd);
|
||||
|
||||
return;
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
evas_object_move(item->base.view, x, y);
|
||||
evas_object_resize(item->base.view, item->wd->item_width,
|
||||
item->wd->item_height);
|
||||
if (!item->is_group)
|
||||
{
|
||||
evas_object_move(item->base.view, x, y);
|
||||
evas_object_resize(item->base.view, iw, ih);
|
||||
}
|
||||
else
|
||||
item->group_realized = EINA_TRUE;
|
||||
}
|
||||
else
|
||||
{
|
||||
_item_unrealize(item);
|
||||
if (was_realized)
|
||||
evas_object_smart_callback_call(item->wd->self, SIG_UNREALIZED, item);
|
||||
if (!item->is_group)
|
||||
{
|
||||
_item_unrealize(item);
|
||||
if (was_realized)
|
||||
evas_object_smart_callback_call(item->wd->self, SIG_UNREALIZED, item);
|
||||
}
|
||||
else
|
||||
item->group_realized = EINA_FALSE;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1284,7 +1451,9 @@ _item_create(Widget_Data *wd,
|
|||
item->func.func = func;
|
||||
item->func.data = func_data;
|
||||
item->mouse_cursor = NULL;
|
||||
item->is_group = !strcmp(item->gic->item_style, "group_index");
|
||||
elm_widget_item_text_get_hook_set(item, _item_label_hook);
|
||||
|
||||
return item;
|
||||
}
|
||||
|
||||
|
@ -1304,6 +1473,8 @@ _item_del(Elm_Gengrid_Item *item)
|
|||
item->tooltip.del_cb((void *)item->tooltip.data, item->base.widget, item);
|
||||
item->wd->walking -= item->walking;
|
||||
item->wd->count--;
|
||||
if (item->is_group)
|
||||
item->wd->group_items = eina_list_remove(item->wd->group_items, item);
|
||||
if (item->wd->calc_job) ecore_job_del(item->wd->calc_job);
|
||||
item->wd->calc_job = ecore_job_add(_calc_job, item->wd);
|
||||
elm_widget_item_del(item);
|
||||
|
@ -1358,7 +1529,10 @@ _calc_job(void *data)
|
|||
{
|
||||
Widget_Data *wd = data;
|
||||
Evas_Coord minw = 0, minh = 0, nmax = 0, cvw, cvh;
|
||||
int count;
|
||||
Elm_Gengrid_Item *item, *group_item = NULL;
|
||||
int count_group = 0;
|
||||
long count = 0;
|
||||
wd->items_lost = 0;
|
||||
|
||||
evas_object_geometry_get(wd->pan_smart, NULL, NULL, &cvw, &cvh);
|
||||
if ((cvw != 0) || (cvh != 0))
|
||||
|
@ -1371,16 +1545,37 @@ _calc_job(void *data)
|
|||
if (nmax < 1)
|
||||
nmax = 1;
|
||||
|
||||
count = wd->count;
|
||||
EINA_INLIST_FOREACH(wd->items, item)
|
||||
{
|
||||
if (item->prev_group != count_group)
|
||||
item->prev_group = count_group;
|
||||
if (item->is_group)
|
||||
{
|
||||
count = count % nmax;
|
||||
if (count)
|
||||
wd->items_lost += nmax - count;
|
||||
//printf("%d items and I lost %d\n", count, wd->items_lost);
|
||||
count_group++;
|
||||
if (count) count = 0;
|
||||
group_item = item;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (item->parent_group_item != group_item)
|
||||
item->parent_group_item = group_item;
|
||||
count++;
|
||||
}
|
||||
}
|
||||
count = wd->count + wd->items_lost - count_group;
|
||||
if (wd->horizontal)
|
||||
{
|
||||
minw = ceil(count / (float)nmax) * wd->item_width;
|
||||
minw = (ceil(count / (float)nmax) * wd->item_width) + (count_group * wd->group_item_height);
|
||||
minh = nmax * wd->item_height;
|
||||
}
|
||||
else
|
||||
{
|
||||
minw = nmax * wd->item_width;
|
||||
minh = ceil(count / (float)nmax) * wd->item_height;
|
||||
minh = (ceil(count / (float)nmax) * wd->item_height) + (count_group * wd->group_item_height);
|
||||
}
|
||||
|
||||
if ((minw != wd->minw) || (minh != wd->minh))
|
||||
|
@ -1512,19 +1707,56 @@ _pan_calculate(Evas_Object *obj)
|
|||
|
||||
EINA_INLIST_FOREACH(sd->wd->items, item)
|
||||
{
|
||||
if (item->is_group)
|
||||
{
|
||||
if (sd->wd->horizontal)
|
||||
{
|
||||
if (cy)
|
||||
{
|
||||
cx++;
|
||||
cy = 0;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if (cx)
|
||||
{
|
||||
cx = 0;
|
||||
cy++;
|
||||
}
|
||||
}
|
||||
}
|
||||
_item_place(item, cx, cy);
|
||||
if (sd->wd->reorder_item_changed) return;
|
||||
if (sd->wd->horizontal)
|
||||
if (item->is_group)
|
||||
{
|
||||
cy = (cy + 1) % sd->wd->nmax;
|
||||
if (!cy) cx++;
|
||||
if (sd->wd->horizontal)
|
||||
{
|
||||
cx++;
|
||||
cy = 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
cx = 0;
|
||||
cy++;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
cx = (cx + 1) % sd->wd->nmax;
|
||||
if (!cx) cy++;
|
||||
if (sd->wd->horizontal)
|
||||
{
|
||||
cy = (cy + 1) % sd->wd->nmax;
|
||||
if (!cy) cx++;
|
||||
}
|
||||
else
|
||||
{
|
||||
cx = (cx + 1) % sd->wd->nmax;
|
||||
if (!cx) cy++;
|
||||
}
|
||||
}
|
||||
}
|
||||
_group_item_place(sd);
|
||||
|
||||
|
||||
if ((sd->wd->reorder_mode) && (sd->wd->reorder_item))
|
||||
{
|
||||
|
@ -1755,6 +1987,33 @@ elm_gengrid_item_size_get(const Evas_Object *obj,
|
|||
if (h) *h = wd->item_height;
|
||||
}
|
||||
|
||||
EAPI void
|
||||
elm_gengrid_group_item_size_set(Evas_Object *obj,
|
||||
Evas_Coord w,
|
||||
Evas_Coord h)
|
||||
{
|
||||
ELM_CHECK_WIDTYPE(obj, widtype);
|
||||
Widget_Data *wd = elm_widget_data_get(obj);
|
||||
if (!wd) return;
|
||||
if ((wd->group_item_width == w) && (wd->group_item_height == h)) return;
|
||||
wd->group_item_width = w;
|
||||
wd->group_item_height = h;
|
||||
if (wd->calc_job) ecore_job_del(wd->calc_job);
|
||||
wd->calc_job = ecore_job_add(_calc_job, wd);
|
||||
}
|
||||
|
||||
EAPI void
|
||||
elm_gengrid_group_item_size_get(const Evas_Object *obj,
|
||||
Evas_Coord *w,
|
||||
Evas_Coord *h)
|
||||
{
|
||||
ELM_CHECK_WIDTYPE(obj, widtype);
|
||||
Widget_Data *wd = elm_widget_data_get(obj);
|
||||
if (!wd) return;
|
||||
if (w) *w = wd->group_item_width;
|
||||
if (h) *h = wd->group_item_height;
|
||||
}
|
||||
|
||||
EAPI void
|
||||
elm_gengrid_align_set(Evas_Object *obj,
|
||||
double align_x,
|
||||
|
@ -1808,6 +2067,9 @@ elm_gengrid_item_append(Evas_Object *obj,
|
|||
if (!item) return NULL;
|
||||
wd->items = eina_inlist_append(wd->items, EINA_INLIST_GET(item));
|
||||
|
||||
if (item->is_group)
|
||||
wd->group_items = eina_list_prepend(wd->group_items, item);
|
||||
|
||||
if (wd->calc_job) ecore_job_del(wd->calc_job);
|
||||
wd->calc_job = ecore_job_add(_calc_job, wd);
|
||||
|
||||
|
@ -1829,6 +2091,8 @@ elm_gengrid_item_prepend(Evas_Object *obj,
|
|||
item = _item_create(wd, gic, data, func, func_data);
|
||||
if (!item) return NULL;
|
||||
wd->items = eina_inlist_prepend(wd->items, EINA_INLIST_GET(item));
|
||||
if (item->is_group)
|
||||
wd->group_items = eina_list_append(wd->group_items, item);
|
||||
|
||||
if (wd->calc_job) ecore_job_del(wd->calc_job);
|
||||
wd->calc_job = ecore_job_add(_calc_job, wd);
|
||||
|
@ -1854,6 +2118,8 @@ elm_gengrid_item_insert_before(Evas_Object *obj,
|
|||
if (!item) return NULL;
|
||||
wd->items = eina_inlist_prepend_relative
|
||||
(wd->items, EINA_INLIST_GET(item), EINA_INLIST_GET(relative));
|
||||
if (item->is_group)
|
||||
wd->group_items = eina_list_append_relative(wd->group_items, item, relative->parent_group_item);
|
||||
|
||||
if (wd->calc_job) ecore_job_del(wd->calc_job);
|
||||
wd->calc_job = ecore_job_add(_calc_job, wd);
|
||||
|
@ -1879,6 +2145,8 @@ elm_gengrid_item_insert_after(Evas_Object *obj,
|
|||
if (!item) return NULL;
|
||||
wd->items = eina_inlist_append_relative
|
||||
(wd->items, EINA_INLIST_GET(item), EINA_INLIST_GET(relative));
|
||||
if (item->is_group)
|
||||
wd->group_items = eina_list_prepend_relative(wd->group_items, item, relative->parent_group_item);
|
||||
|
||||
if (wd->calc_job) ecore_job_del(wd->calc_job);
|
||||
wd->calc_job = ecore_job_add(_calc_job, wd);
|
||||
|
@ -2548,11 +2816,18 @@ elm_gengrid_item_show(Elm_Gengrid_Item *item)
|
|||
if ((!item) || (item->delete_me)) return;
|
||||
_pan_min_get(wd->pan_smart, &minx, &miny);
|
||||
|
||||
elm_smart_scroller_child_region_show(item->wd->scr,
|
||||
item->x * wd->item_width + minx,
|
||||
if (wd->horizontal)
|
||||
elm_smart_scroller_region_bring_in(item->wd->scr,
|
||||
((item->x - item->prev_group) * wd->item_width) + (item->prev_group * item->wd->group_item_width) + minx,
|
||||
item->y * wd->item_height + miny,
|
||||
item->wd->item_width,
|
||||
item->wd->item_height);
|
||||
else
|
||||
elm_smart_scroller_region_bring_in(item->wd->scr,
|
||||
item->x * wd->item_width + minx,
|
||||
((item->y - item->prev_group)* wd->item_height) + (item->prev_group * item->wd->group_item_height) + miny,
|
||||
item->wd->item_width,
|
||||
item->wd->item_height);
|
||||
}
|
||||
|
||||
EAPI void
|
||||
|
@ -2566,9 +2841,16 @@ elm_gengrid_item_bring_in(Elm_Gengrid_Item *item)
|
|||
if (!wd) return;
|
||||
_pan_min_get(wd->pan_smart, &minx, &miny);
|
||||
|
||||
elm_smart_scroller_region_bring_in(item->wd->scr,
|
||||
item->x * wd->item_width + minx,
|
||||
item->y * wd->item_height + miny,
|
||||
item->wd->item_width,
|
||||
item->wd->item_height);
|
||||
if (wd->horizontal)
|
||||
elm_smart_scroller_region_bring_in(item->wd->scr,
|
||||
((item->x - item->prev_group) * wd->item_width) + (item->prev_group * item->wd->group_item_width) + minx,
|
||||
item->y * wd->item_height + miny,
|
||||
item->wd->item_width,
|
||||
item->wd->item_height);
|
||||
else
|
||||
elm_smart_scroller_region_bring_in(item->wd->scr,
|
||||
item->x * wd->item_width + minx,
|
||||
((item->y - item->prev_group)* wd->item_height) + (item->prev_group * item->wd->group_item_height) + miny,
|
||||
item->wd->item_width,
|
||||
item->wd->item_height);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue