forked from enlightenment/efl
efl_ui_panel: remove dependency with elm_interface_scrollable
`elm_interface_scrollable` is replaced with `efl_ui_scrollable_interative`. Legacy code related to `SCROLL` event is removed because eo `SCROLL` event have `void` event info. ``` in lib/efl/inferfaces/efl_ui_scrollable.eo scroll: void; [[Called when scrolling]] ``` I think we need to add new `PANEL_SCROLL` event that have `Efl_Ui_Panel_Scroll_Info` Reviewed-by: Marcel Hollerbach <mail@marcel-hollerbach.de> Differential Revision: https://phab.enlightenment.org/D9637
This commit is contained in:
parent
e7986cc646
commit
1c1382e09b
|
@ -6,6 +6,7 @@
|
||||||
#define EFL_ACCESS_WIDGET_ACTION_PROTECTED
|
#define EFL_ACCESS_WIDGET_ACTION_PROTECTED
|
||||||
#define EFL_UI_FOCUS_LAYER_PROTECTED
|
#define EFL_UI_FOCUS_LAYER_PROTECTED
|
||||||
#define EFL_PART_PROTECTED
|
#define EFL_PART_PROTECTED
|
||||||
|
#define EFL_UI_SCROLL_MANAGER_PROTECTED
|
||||||
|
|
||||||
#include <Elementary.h>
|
#include <Elementary.h>
|
||||||
|
|
||||||
|
@ -254,20 +255,20 @@ _handler_open(Evas_Object *obj, Evas_Coord w, Evas_Coord h)
|
||||||
switch (sd->orient)
|
switch (sd->orient)
|
||||||
{
|
{
|
||||||
case EFL_UI_PANEL_ORIENT_TOP:
|
case EFL_UI_PANEL_ORIENT_TOP:
|
||||||
elm_interface_scrollable_region_bring_in
|
efl_ui_scrollable_scroll
|
||||||
(obj, 0, (h * sd->content_size_ratio) - sd->handler_size, w, h);
|
(obj, EINA_RECT(0, (h * sd->content_size_ratio) - sd->handler_size, w, h), EINA_TRUE);
|
||||||
break;
|
break;
|
||||||
case EFL_UI_PANEL_ORIENT_BOTTOM:
|
case EFL_UI_PANEL_ORIENT_BOTTOM:
|
||||||
elm_interface_scrollable_region_bring_in
|
efl_ui_scrollable_scroll
|
||||||
(obj, 0, sd->handler_size, w, h);
|
(obj, EINA_RECT(0, sd->handler_size, w, h), EINA_TRUE);
|
||||||
break;
|
break;
|
||||||
case EFL_UI_PANEL_ORIENT_LEFT:
|
case EFL_UI_PANEL_ORIENT_LEFT:
|
||||||
elm_interface_scrollable_region_bring_in
|
efl_ui_scrollable_scroll
|
||||||
(obj, (w * sd->content_size_ratio) - sd->handler_size, 0, w, h);
|
(obj, EINA_RECT((w * sd->content_size_ratio) - sd->handler_size, 0, w, h), EINA_TRUE);
|
||||||
break;
|
break;
|
||||||
case EFL_UI_PANEL_ORIENT_RIGHT:
|
case EFL_UI_PANEL_ORIENT_RIGHT:
|
||||||
elm_interface_scrollable_region_bring_in
|
efl_ui_scrollable_scroll
|
||||||
(obj, sd->handler_size, 0, w, h);
|
(obj, EINA_RECT(sd->handler_size, 0, w, h), EINA_TRUE);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -280,8 +281,7 @@ _drawer_open(Evas_Object *obj, Evas_Coord w, Evas_Coord h, Eina_Bool anim)
|
||||||
|
|
||||||
if (sd->freeze)
|
if (sd->freeze)
|
||||||
{
|
{
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
|
||||||
sd->freeze = EINA_FALSE;
|
sd->freeze = EINA_FALSE;
|
||||||
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
||||||
}
|
}
|
||||||
|
@ -304,21 +304,16 @@ _drawer_open(Evas_Object *obj, Evas_Coord w, Evas_Coord h, Eina_Bool anim)
|
||||||
x = w * sd->content_size_ratio;
|
x = w * sd->content_size_ratio;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
efl_ui_scrollable_scroll(obj, EINA_RECT(x, y, w, h), anim);
|
||||||
if (anim)
|
|
||||||
elm_interface_scrollable_region_bring_in
|
|
||||||
(obj, x, y, w, h);
|
|
||||||
else
|
|
||||||
elm_interface_scrollable_content_region_show
|
|
||||||
(obj, x, y, w, h);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_drawer_close(Evas_Object *obj, Evas_Coord w, Evas_Coord h, Eina_Bool anim)
|
_drawer_close(Evas_Object *obj, Evas_Coord w, Evas_Coord h, Eina_Bool anim)
|
||||||
{
|
{
|
||||||
EFL_UI_PANEL_DATA_GET(obj, sd);
|
EFL_UI_PANEL_DATA_GET(obj, sd);
|
||||||
int x = 0, y = 0, cx, cy;
|
int x = 0, y = 0;
|
||||||
Eina_Bool horizontal = EINA_FALSE;
|
Eina_Bool horizontal = EINA_FALSE;
|
||||||
|
Eina_Position2D c;
|
||||||
|
|
||||||
elm_widget_tree_unfocusable_set(obj, EINA_TRUE);
|
elm_widget_tree_unfocusable_set(obj, EINA_TRUE);
|
||||||
switch (sd->orient)
|
switch (sd->orient)
|
||||||
|
@ -343,17 +338,17 @@ _drawer_close(Evas_Object *obj, Evas_Coord w, Evas_Coord h, Eina_Bool anim)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
elm_interface_scrollable_content_pos_get(obj, &cx, &cy);
|
c = efl_ui_scrollable_content_pos_get(obj);
|
||||||
|
|
||||||
if ((x == cx) && (y == cy))
|
if ((x == c.x) && (y == c.y))
|
||||||
{
|
{
|
||||||
if (!sd->freeze)
|
if (!sd->freeze)
|
||||||
{
|
{
|
||||||
if (horizontal)
|
if (horizontal)
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
||||||
else
|
else
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
||||||
sd->freeze = EINA_TRUE;
|
sd->freeze = EINA_TRUE;
|
||||||
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,hidden", "efl");
|
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,hidden", "efl");
|
||||||
|
@ -366,23 +361,23 @@ _drawer_close(Evas_Object *obj, Evas_Coord w, Evas_Coord h, Eina_Bool anim)
|
||||||
{
|
{
|
||||||
if (sd->freeze)
|
if (sd->freeze)
|
||||||
{
|
{
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
||||||
sd->freeze = EINA_FALSE;
|
sd->freeze = EINA_FALSE;
|
||||||
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
||||||
}
|
}
|
||||||
elm_interface_scrollable_region_bring_in(obj, x, y, w, h);
|
efl_ui_scrollable_scroll(obj, EINA_RECT(x, y, w, h), anim);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
elm_interface_scrollable_content_region_show(obj, x, y, w, h);
|
efl_ui_scrollable_scroll(obj, EINA_RECT(x, y, w, h), anim);
|
||||||
if (!sd->freeze)
|
if (!sd->freeze)
|
||||||
{
|
{
|
||||||
if (horizontal)
|
if (horizontal)
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
||||||
else
|
else
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
||||||
sd->freeze = EINA_TRUE;
|
sd->freeze = EINA_TRUE;
|
||||||
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,hidden", "efl");
|
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,hidden", "efl");
|
||||||
|
@ -446,6 +441,7 @@ _state_sync(Evas_Object *obj)
|
||||||
EFL_UI_PANEL_DATA_GET(obj, sd);
|
EFL_UI_PANEL_DATA_GET(obj, sd);
|
||||||
Evas_Coord pos, panel_size, w, h, threshold;
|
Evas_Coord pos, panel_size, w, h, threshold;
|
||||||
Eina_Bool horizontal = EINA_FALSE, reverse = EINA_FALSE;
|
Eina_Bool horizontal = EINA_FALSE, reverse = EINA_FALSE;
|
||||||
|
Eina_Position2D c;
|
||||||
|
|
||||||
evas_object_geometry_get(obj, NULL, NULL, &w, &h);
|
evas_object_geometry_get(obj, NULL, NULL, &w, &h);
|
||||||
|
|
||||||
|
@ -466,12 +462,13 @@ _state_sync(Evas_Object *obj)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
c = efl_ui_scrollable_content_pos_get(obj);
|
||||||
if (horizontal)
|
if (horizontal)
|
||||||
{
|
{
|
||||||
if (w <= 0) return EINA_TRUE;
|
if (w <= 0) return EINA_TRUE;
|
||||||
|
|
||||||
panel_size = w * sd->content_size_ratio;
|
panel_size = w * sd->content_size_ratio;
|
||||||
elm_interface_scrollable_content_pos_get(obj, &pos, NULL);
|
pos = c.x;
|
||||||
reverse ^= efl_ui_mirrored_get(obj);
|
reverse ^= efl_ui_mirrored_get(obj);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -479,7 +476,7 @@ _state_sync(Evas_Object *obj)
|
||||||
if (h <= 0) return EINA_TRUE;
|
if (h <= 0) return EINA_TRUE;
|
||||||
|
|
||||||
panel_size = h * sd->content_size_ratio;
|
panel_size = h * sd->content_size_ratio;
|
||||||
elm_interface_scrollable_content_pos_get(obj, NULL, &pos);
|
pos = c.y;
|
||||||
}
|
}
|
||||||
threshold = (sd->hidden) ? panel_size - (panel_size / 4) : (panel_size / 4);
|
threshold = (sd->hidden) ? panel_size - (panel_size / 4) : (panel_size / 4);
|
||||||
|
|
||||||
|
@ -508,7 +505,7 @@ _timer_cb(void *data)
|
||||||
|
|
||||||
if (sd->freeze)
|
if (sd->freeze)
|
||||||
{
|
{
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
||||||
sd->freeze = EINA_FALSE;
|
sd->freeze = EINA_FALSE;
|
||||||
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
||||||
|
@ -616,7 +613,7 @@ _on_mouse_move(void *data,
|
||||||
case EFL_UI_PANEL_ORIENT_TOP:
|
case EFL_UI_PANEL_ORIENT_TOP:
|
||||||
if (sd->timer && ((cur_y - sd->down_y) > finger_size))
|
if (sd->timer && ((cur_y - sd->down_y) > finger_size))
|
||||||
{
|
{
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
||||||
sd->freeze = EINA_FALSE;
|
sd->freeze = EINA_FALSE;
|
||||||
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
||||||
|
@ -625,7 +622,7 @@ _on_mouse_move(void *data,
|
||||||
case EFL_UI_PANEL_ORIENT_BOTTOM:
|
case EFL_UI_PANEL_ORIENT_BOTTOM:
|
||||||
if (sd->timer && ((sd->down_y - cur_y) > finger_size))
|
if (sd->timer && ((sd->down_y - cur_y) > finger_size))
|
||||||
{
|
{
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
||||||
sd->freeze = EINA_FALSE;
|
sd->freeze = EINA_FALSE;
|
||||||
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
||||||
|
@ -635,7 +632,7 @@ _on_mouse_move(void *data,
|
||||||
if ((!is_mirrored && (sd->timer) && ((cur_x - sd->down_x) > finger_size)) ||
|
if ((!is_mirrored && (sd->timer) && ((cur_x - sd->down_x) > finger_size)) ||
|
||||||
((is_mirrored) && (sd->timer) && ((sd->down_x - cur_x) > finger_size)))
|
((is_mirrored) && (sd->timer) && ((sd->down_x - cur_x) > finger_size)))
|
||||||
{
|
{
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
||||||
sd->freeze = EINA_FALSE;
|
sd->freeze = EINA_FALSE;
|
||||||
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
||||||
|
@ -645,7 +642,7 @@ _on_mouse_move(void *data,
|
||||||
if ((is_mirrored && (sd->timer) && ((cur_x - sd->down_x) > finger_size)) ||
|
if ((is_mirrored && (sd->timer) && ((cur_x - sd->down_x) > finger_size)) ||
|
||||||
(!is_mirrored && (sd->timer) && ((sd->down_x - cur_x) > finger_size)))
|
(!is_mirrored && (sd->timer) && ((sd->down_x - cur_x) > finger_size)))
|
||||||
{
|
{
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
||||||
sd->freeze = EINA_FALSE;
|
sd->freeze = EINA_FALSE;
|
||||||
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
||||||
|
@ -750,16 +747,6 @@ _efl_ui_panel_efl_content_content_unset(Eo *obj EINA_UNUSED, Efl_Ui_Panel_Data *
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
EOLIAN static void
|
|
||||||
_efl_ui_panel_efl_gfx_entity_position_set(Eo *obj, Efl_Ui_Panel_Data *sd, Eina_Position2D pos)
|
|
||||||
{
|
|
||||||
if (_evas_object_intercept_call(obj, EVAS_OBJECT_INTERCEPT_CB_MOVE, 0, pos.x, pos.y))
|
|
||||||
return;
|
|
||||||
|
|
||||||
efl_gfx_entity_position_set(efl_super(obj, MY_CLASS), pos);
|
|
||||||
efl_gfx_entity_position_set(sd->hit_rect, pos);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_scrollable_layout_resize(Eo *obj, Efl_Ui_Panel_Data *sd, Evas_Coord w, Evas_Coord h)
|
_scrollable_layout_resize(Eo *obj, Efl_Ui_Panel_Data *sd, Evas_Coord w, Evas_Coord h)
|
||||||
{
|
{
|
||||||
|
@ -793,7 +780,6 @@ _efl_ui_panel_efl_gfx_entity_size_set(Eo *obj, Efl_Ui_Panel_Data *sd, Eina_Size2
|
||||||
|
|
||||||
if (!sd->scrollable) return;
|
if (!sd->scrollable) return;
|
||||||
|
|
||||||
efl_gfx_entity_size_set(sd->hit_rect, sz);
|
|
||||||
_scrollable_layout_resize(obj, sd, sz.w, sz.h);
|
_scrollable_layout_resize(obj, sd, sz.w, sz.h);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -802,7 +788,7 @@ _efl_ui_panel_efl_canvas_group_group_member_add(Eo *obj, Efl_Ui_Panel_Data *sd,
|
||||||
{
|
{
|
||||||
efl_canvas_group_member_add(efl_super(obj, MY_CLASS), member);
|
efl_canvas_group_member_add(efl_super(obj, MY_CLASS), member);
|
||||||
|
|
||||||
if (sd->hit_rect) evas_object_raise(sd->hit_rect);
|
if (sd->scr_event) evas_object_raise(sd->scr_event);
|
||||||
}
|
}
|
||||||
|
|
||||||
EOLIAN static void
|
EOLIAN static void
|
||||||
|
@ -923,12 +909,12 @@ _efl_ui_panel_orient_set(Eo *obj, Efl_Ui_Panel_Data *sd, Efl_Ui_Panel_Orient ori
|
||||||
{
|
{
|
||||||
case EFL_UI_PANEL_ORIENT_TOP:
|
case EFL_UI_PANEL_ORIENT_TOP:
|
||||||
case EFL_UI_PANEL_ORIENT_BOTTOM:
|
case EFL_UI_PANEL_ORIENT_BOTTOM:
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
||||||
break;
|
break;
|
||||||
case EFL_UI_PANEL_ORIENT_LEFT:
|
case EFL_UI_PANEL_ORIENT_LEFT:
|
||||||
case EFL_UI_PANEL_ORIENT_RIGHT:
|
case EFL_UI_PANEL_ORIENT_RIGHT:
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -984,8 +970,9 @@ EOLIAN static Eina_Rect
|
||||||
_efl_ui_panel_efl_ui_widget_interest_region_get(const Eo *obj, Efl_Ui_Panel_Data *sd)
|
_efl_ui_panel_efl_ui_widget_interest_region_get(const Eo *obj, Efl_Ui_Panel_Data *sd)
|
||||||
{
|
{
|
||||||
Eina_Rect r = {};
|
Eina_Rect r = {};
|
||||||
|
Eina_Position2D p;
|
||||||
|
|
||||||
elm_interface_scrollable_content_pos_get(obj, &r.x, &r.y);
|
p = efl_ui_scrollable_content_pos_get(obj);
|
||||||
evas_object_geometry_get(obj, NULL, NULL, &r.w, &r.h);
|
evas_object_geometry_get(obj, NULL, NULL, &r.w, &r.h);
|
||||||
switch (sd->orient)
|
switch (sd->orient)
|
||||||
{
|
{
|
||||||
|
@ -1000,17 +987,21 @@ _efl_ui_panel_efl_ui_widget_interest_region_get(const Eo *obj, Efl_Ui_Panel_Data
|
||||||
}
|
}
|
||||||
if (r.w < 1) r.w = 1;
|
if (r.w < 1) r.w = 1;
|
||||||
if (r.h < 1) r.h = 1;
|
if (r.h < 1) r.h = 1;
|
||||||
|
r.x = p.x;
|
||||||
|
r.y = p.y;
|
||||||
|
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_anim_stop_cb(Evas_Object *obj, void *data EINA_UNUSED)
|
_anim_stop_cb(void *data EINA_UNUSED, const Efl_Event *event)
|
||||||
{
|
{
|
||||||
|
Eo *obj = event->object;
|
||||||
EFL_UI_PANEL_DATA_GET(obj, sd);
|
EFL_UI_PANEL_DATA_GET(obj, sd);
|
||||||
Evas_Object *ao;
|
Evas_Object *ao;
|
||||||
Evas_Coord pos, w, h, panel_size = 0;
|
Evas_Coord pos, w, h, panel_size = 0;
|
||||||
Eina_Bool open = EINA_FALSE, horizontal = EINA_FALSE, reverse = EINA_FALSE;
|
Eina_Bool open = EINA_FALSE, horizontal = EINA_FALSE, reverse = EINA_FALSE;
|
||||||
|
Eina_Position2D c;
|
||||||
|
|
||||||
if (elm_widget_disabled_get(obj)) return;
|
if (elm_widget_disabled_get(obj)) return;
|
||||||
|
|
||||||
|
@ -1029,13 +1020,14 @@ _anim_stop_cb(Evas_Object *obj, void *data EINA_UNUSED)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
c = efl_ui_scrollable_content_pos_get(obj);
|
||||||
evas_object_geometry_get(obj, NULL, NULL, &w, &h);
|
evas_object_geometry_get(obj, NULL, NULL, &w, &h);
|
||||||
if (horizontal)
|
if (horizontal)
|
||||||
{
|
{
|
||||||
if (w <= 0) return;
|
if (w <= 0) return;
|
||||||
|
|
||||||
panel_size = w * sd->content_size_ratio;
|
panel_size = w * sd->content_size_ratio;
|
||||||
elm_interface_scrollable_content_pos_get(obj, &pos, NULL);
|
pos = c.x;
|
||||||
reverse ^= efl_ui_mirrored_get(obj);
|
reverse ^= efl_ui_mirrored_get(obj);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -1043,7 +1035,7 @@ _anim_stop_cb(Evas_Object *obj, void *data EINA_UNUSED)
|
||||||
if (h <= 0) return;
|
if (h <= 0) return;
|
||||||
|
|
||||||
panel_size = h * sd->content_size_ratio;
|
panel_size = h * sd->content_size_ratio;
|
||||||
elm_interface_scrollable_content_pos_get(obj, NULL, &pos);
|
pos = c.y;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pos == 0) open = !reverse;
|
if (pos == 0) open = !reverse;
|
||||||
|
@ -1052,9 +1044,6 @@ _anim_stop_cb(Evas_Object *obj, void *data EINA_UNUSED)
|
||||||
|
|
||||||
if (open)
|
if (open)
|
||||||
{
|
{
|
||||||
elm_interface_scrollable_single_direction_set
|
|
||||||
(obj, ELM_SCROLLER_SINGLE_DIRECTION_HARD);
|
|
||||||
|
|
||||||
//focus & access
|
//focus & access
|
||||||
elm_object_tree_focus_allow_set(obj, EINA_TRUE);
|
elm_object_tree_focus_allow_set(obj, EINA_TRUE);
|
||||||
if (_elm_config->access_mode == ELM_ACCESS_MODE_ON)
|
if (_elm_config->access_mode == ELM_ACCESS_MODE_ON)
|
||||||
|
@ -1069,17 +1058,14 @@ _anim_stop_cb(Evas_Object *obj, void *data EINA_UNUSED)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (horizontal)
|
if (horizontal)
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
||||||
else
|
else
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
||||||
sd->freeze = EINA_TRUE;
|
sd->freeze = EINA_TRUE;
|
||||||
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,hidden", "efl");
|
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,hidden", "efl");
|
||||||
|
|
||||||
elm_interface_scrollable_single_direction_set
|
|
||||||
(obj, ELM_SCROLLER_SINGLE_DIRECTION_NONE);
|
|
||||||
|
|
||||||
//focus & access
|
//focus & access
|
||||||
elm_object_tree_focus_allow_set(obj, EINA_FALSE);
|
elm_object_tree_focus_allow_set(obj, EINA_FALSE);
|
||||||
if (_elm_config->access_mode == ELM_ACCESS_MODE_ON)
|
if (_elm_config->access_mode == ELM_ACCESS_MODE_ON)
|
||||||
|
@ -1091,63 +1077,21 @@ _anim_stop_cb(Evas_Object *obj, void *data EINA_UNUSED)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_scroll_cb(Evas_Object *obj, void *data EINA_UNUSED)
|
_scroll_cb(void *data EINA_UNUSED, const Efl_Event *event_info EINA_UNUSED)
|
||||||
{
|
{
|
||||||
|
Eo *obj = event_info->object;
|
||||||
EFL_UI_PANEL_DATA_GET(obj, sd);
|
EFL_UI_PANEL_DATA_GET(obj, sd);
|
||||||
Efl_Ui_Panel_Scroll_Info event;
|
|
||||||
Evas_Coord x, y, w, h;
|
|
||||||
|
|
||||||
if (elm_widget_disabled_get(obj)) return;
|
if (elm_widget_disabled_get(obj)) return;
|
||||||
// in the case of
|
// in the case of
|
||||||
// freeze_set(FALSE) -> mouse_up -> freeze_set(TRUE) -> scroll
|
// freeze_set(FALSE) -> mouse_up -> freeze_set(TRUE) -> scroll
|
||||||
if (sd->freeze)
|
if (sd->freeze)
|
||||||
{
|
{
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
(obj, EFL_UI_SCROLL_BLOCK_NONE);
|
||||||
sd->freeze = EINA_FALSE;
|
sd->freeze = EINA_FALSE;
|
||||||
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
elm_layout_signal_emit(sd->scr_ly, "efl,state,content,visible", "efl");
|
||||||
}
|
}
|
||||||
|
|
||||||
elm_interface_scrollable_content_pos_get(obj, &x, &y);
|
|
||||||
evas_object_geometry_get(obj, NULL, NULL, &w, &h);
|
|
||||||
|
|
||||||
switch (sd->orient)
|
|
||||||
{
|
|
||||||
case EFL_UI_PANEL_ORIENT_TOP:
|
|
||||||
event.rel_x = 1;
|
|
||||||
event.rel_y = 1 - ((double) y / (double) ((sd->content_size_ratio) * h));
|
|
||||||
break;
|
|
||||||
case EFL_UI_PANEL_ORIENT_BOTTOM:
|
|
||||||
event.rel_x = 1;
|
|
||||||
event.rel_y = (double) y / (double) ((sd->content_size_ratio) * h);
|
|
||||||
break;
|
|
||||||
case EFL_UI_PANEL_ORIENT_LEFT:
|
|
||||||
if (!efl_ui_mirrored_get(obj))
|
|
||||||
{
|
|
||||||
event.rel_x = 1 - ((double) x / (double) ((sd->content_size_ratio) * w));
|
|
||||||
event.rel_y = 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
event.rel_x = (double) x / (double) ((sd->content_size_ratio) * w);
|
|
||||||
event.rel_y = 1;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case EFL_UI_PANEL_ORIENT_RIGHT:
|
|
||||||
if (efl_ui_mirrored_get(obj))
|
|
||||||
{
|
|
||||||
event.rel_x = 1 - ((double) x / (double) ((sd->content_size_ratio) * w));
|
|
||||||
event.rel_y = 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
event.rel_x = (double) x / (double) ((sd->content_size_ratio) * w);
|
|
||||||
event.rel_y = 1;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
efl_event_callback_legacy_call
|
|
||||||
(obj, EFL_UI_EVENT_SCROLL, (void *) &event);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
EOLIAN static void
|
EOLIAN static void
|
||||||
|
@ -1163,13 +1107,13 @@ _efl_ui_panel_efl_ui_widget_disabled_set(Eo *obj, Efl_Ui_Panel_Data *sd, Eina_Bo
|
||||||
{
|
{
|
||||||
case ELM_PANEL_ORIENT_BOTTOM:
|
case ELM_PANEL_ORIENT_BOTTOM:
|
||||||
case ELM_PANEL_ORIENT_TOP:
|
case ELM_PANEL_ORIENT_TOP:
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ELM_PANEL_ORIENT_RIGHT:
|
case ELM_PANEL_ORIENT_RIGHT:
|
||||||
case ELM_PANEL_ORIENT_LEFT:
|
case ELM_PANEL_ORIENT_LEFT:
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1191,13 +1135,13 @@ _efl_ui_panel_efl_ui_widget_disabled_set(Eo *obj, Efl_Ui_Panel_Data *sd, Eina_Bo
|
||||||
{
|
{
|
||||||
case ELM_PANEL_ORIENT_BOTTOM:
|
case ELM_PANEL_ORIENT_BOTTOM:
|
||||||
case ELM_PANEL_ORIENT_TOP:
|
case ELM_PANEL_ORIENT_TOP:
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ELM_PANEL_ORIENT_RIGHT:
|
case ELM_PANEL_ORIENT_RIGHT:
|
||||||
case ELM_PANEL_ORIENT_LEFT:
|
case ELM_PANEL_ORIENT_LEFT:
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1278,29 +1222,33 @@ _efl_ui_panel_scrollable_set(Eo *obj, Efl_Ui_Panel_Data *sd, Eina_Bool scrollabl
|
||||||
|
|
||||||
elm_widget_resize_object_set(obj, sd->scr_edje);
|
elm_widget_resize_object_set(obj, sd->scr_edje);
|
||||||
|
|
||||||
if (!sd->hit_rect)
|
if (!sd->smanager)
|
||||||
{
|
{
|
||||||
sd->hit_rect = evas_object_rectangle_add(evas_object_evas_get(obj));
|
sd->smanager = efl_add(EFL_UI_SCROLL_MANAGER_CLASS, obj);
|
||||||
evas_object_smart_member_add(sd->hit_rect, obj);
|
efl_ui_mirrored_set(sd->smanager, efl_ui_mirrored_get(obj));
|
||||||
elm_widget_sub_object_add(obj, sd->hit_rect);
|
|
||||||
evas_object_color_set(sd->hit_rect, 0, 0, 0, 0);
|
|
||||||
evas_object_show(sd->hit_rect);
|
|
||||||
evas_object_repeat_events_set(sd->hit_rect, EINA_TRUE);
|
|
||||||
|
|
||||||
elm_interface_scrollable_objects_set(obj, sd->scr_edje, sd->hit_rect);
|
efl_event_callback_add(obj, EFL_UI_EVENT_SCROLL_ANIM_STOP, _anim_stop_cb, NULL);
|
||||||
elm_interface_scrollable_animate_stop_cb_set(obj, _anim_stop_cb);
|
efl_event_callback_add(obj, EFL_UI_EVENT_SCROLL, _scroll_cb, NULL);
|
||||||
elm_interface_scrollable_scroll_cb_set(obj, _scroll_cb);
|
}
|
||||||
|
|
||||||
|
efl_composite_attach(obj, sd->smanager);
|
||||||
|
efl_ui_scroll_connector_bind(obj, sd->smanager);
|
||||||
|
|
||||||
|
if (!sd->pan_obj)
|
||||||
|
{
|
||||||
|
sd->pan_obj = efl_add(EFL_UI_PAN_CLASS, obj);
|
||||||
|
efl_ui_scroll_manager_pan_set(sd->smanager, sd->pan_obj);
|
||||||
|
efl_content_set(efl_part(sd->scr_edje, "efl.content"), sd->pan_obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!sd->scr_ly)
|
if (!sd->scr_ly)
|
||||||
{
|
{
|
||||||
sd->scr_ly = efl_add(EFL_UI_LAYOUT_CLASS, obj,
|
sd->scr_ly = efl_add(EFL_UI_LAYOUT_CLASS, obj,
|
||||||
elm_layout_theme_set(efl_added,
|
efl_ui_layout_theme_set(efl_added,
|
||||||
"panel",
|
"panel", "scrollable/left",
|
||||||
"scrollable/left",
|
efl_ui_widget_style_get(obj)));
|
||||||
elm_widget_style_get(obj)));
|
|
||||||
|
|
||||||
evas_object_smart_member_add(sd->scr_ly, obj);
|
efl_canvas_group_member_add(obj, sd->scr_ly);
|
||||||
elm_widget_sub_object_add(obj, sd->scr_ly);
|
elm_widget_sub_object_add(obj, sd->scr_ly);
|
||||||
_scrollable_layout_theme_set(obj, sd);
|
_scrollable_layout_theme_set(obj, sd);
|
||||||
|
|
||||||
|
@ -1317,7 +1265,7 @@ _efl_ui_panel_scrollable_set(Eo *obj, Efl_Ui_Panel_Data *sd, Eina_Bool scrollabl
|
||||||
elm_layout_content_set(sd->scr_ly, "event_area", sd->scr_event);
|
elm_layout_content_set(sd->scr_ly, "event_area", sd->scr_event);
|
||||||
}
|
}
|
||||||
|
|
||||||
elm_interface_scrollable_content_set(obj, sd->scr_ly);
|
efl_content_set(sd->pan_obj, sd->scr_ly);
|
||||||
sd->freeze = EINA_TRUE;
|
sd->freeze = EINA_TRUE;
|
||||||
efl_content_set(efl_part(sd->scr_ly, "efl.content"), sd->bx);
|
efl_content_set(efl_part(sd->scr_ly, "efl.content"), sd->bx);
|
||||||
if (sd->content) elm_widget_sub_object_add(sd->scr_ly, sd->content);
|
if (sd->content) elm_widget_sub_object_add(sd->scr_ly, sd->content);
|
||||||
|
@ -1326,19 +1274,16 @@ _efl_ui_panel_scrollable_set(Eo *obj, Efl_Ui_Panel_Data *sd, Eina_Bool scrollabl
|
||||||
{
|
{
|
||||||
case EFL_UI_PANEL_ORIENT_TOP:
|
case EFL_UI_PANEL_ORIENT_TOP:
|
||||||
case EFL_UI_PANEL_ORIENT_BOTTOM:
|
case EFL_UI_PANEL_ORIENT_BOTTOM:
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
(obj, EFL_UI_SCROLL_BLOCK_VERTICAL);
|
||||||
break;
|
break;
|
||||||
case EFL_UI_PANEL_ORIENT_LEFT:
|
case EFL_UI_PANEL_ORIENT_LEFT:
|
||||||
case EFL_UI_PANEL_ORIENT_RIGHT:
|
case EFL_UI_PANEL_ORIENT_RIGHT:
|
||||||
elm_interface_scrollable_movement_block_set
|
efl_ui_scrollable_movement_block_set
|
||||||
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
(obj, EFL_UI_SCROLL_BLOCK_HORIZONTAL);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
elm_interface_scrollable_single_direction_set
|
|
||||||
(obj, ELM_SCROLLER_SINGLE_DIRECTION_NONE);
|
|
||||||
|
|
||||||
if (!elm_widget_disabled_get(obj) && !sd->callback_added)
|
if (!elm_widget_disabled_get(obj) && !sd->callback_added)
|
||||||
{
|
{
|
||||||
evas_object_event_callback_add(obj, EVAS_CALLBACK_MOUSE_DOWN,
|
evas_object_event_callback_add(obj, EVAS_CALLBACK_MOUSE_DOWN,
|
||||||
|
@ -1356,7 +1301,8 @@ _efl_ui_panel_scrollable_set(Eo *obj, Efl_Ui_Panel_Data *sd, Eina_Bool scrollabl
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
elm_interface_scrollable_content_set(obj, NULL);
|
efl_ui_scroll_connector_unbind(obj);
|
||||||
|
efl_composite_detach(obj, sd->smanager);
|
||||||
|
|
||||||
if (sd->callback_added)
|
if (sd->callback_added)
|
||||||
{
|
{
|
||||||
|
|
|
@ -15,7 +15,7 @@ struct @beta Efl.Ui.Panel_Scroll_Info
|
||||||
rel_y: double; [[content scrolled position (0.0 ~ 1.0) in the panel]]
|
rel_y: double; [[content scrolled position (0.0 ~ 1.0) in the panel]]
|
||||||
}
|
}
|
||||||
|
|
||||||
class @beta Efl.Ui.Panel extends Efl.Ui.Layout_Base implements Efl.Ui.Focus.Layer, Elm.Interface_Scrollable, Efl.Content,
|
class @beta Efl.Ui.Panel extends Efl.Ui.Layout_Base implements Efl.Ui.Focus.Layer, Efl.Ui.Scrollable_Interactive, Efl.Content,
|
||||||
Efl.Access.Widget.Action
|
Efl.Access.Widget.Action
|
||||||
{
|
{
|
||||||
[[Elementary panel class]]
|
[[Elementary panel class]]
|
||||||
|
@ -76,7 +76,6 @@ class @beta Efl.Ui.Panel extends Efl.Ui.Layout_Base implements Efl.Ui.Focus.Laye
|
||||||
implements {
|
implements {
|
||||||
Efl.Object.constructor;
|
Efl.Object.constructor;
|
||||||
Efl.Object.destructor;
|
Efl.Object.destructor;
|
||||||
Efl.Gfx.Entity.position { set; }
|
|
||||||
Efl.Gfx.Entity.size { set; }
|
Efl.Gfx.Entity.size { set; }
|
||||||
Efl.Canvas.Group.group_member_add;
|
Efl.Canvas.Group.group_member_add;
|
||||||
Efl.Canvas.Group.group_calculate;
|
Efl.Canvas.Group.group_calculate;
|
||||||
|
@ -93,4 +92,7 @@ class @beta Efl.Ui.Panel extends Efl.Ui.Layout_Base implements Efl.Ui.Focus.Laye
|
||||||
events {
|
events {
|
||||||
toggled: void; [[Called when the hidden state was toggled]]
|
toggled: void; [[Called when the hidden state was toggled]]
|
||||||
}
|
}
|
||||||
|
composite {
|
||||||
|
Efl.Ui.Scrollable_Interactive;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,8 +31,9 @@ struct _Efl_Ui_Panel_Data
|
||||||
Evas_Object *bx, *content;
|
Evas_Object *bx, *content;
|
||||||
Evas_Object *event;
|
Evas_Object *event;
|
||||||
Evas_Object *scr_ly;
|
Evas_Object *scr_ly;
|
||||||
Evas_Object *hit_rect, *panel_edje, *scr_edje;
|
Evas_Object *panel_edje, *scr_edje;
|
||||||
Evas_Object *scr_panel, *scr_event;
|
Evas_Object *scr_panel, *scr_event;
|
||||||
|
Evas_Object *smanager, *pan_obj;
|
||||||
|
|
||||||
|
|
||||||
Efl_Ui_Panel_Orient orient;
|
Efl_Ui_Panel_Orient orient;
|
||||||
|
|
Loading…
Reference in New Issue