Fix the region_show/region_bring_in don't have a limit at a paging movement.

This commit is contained in:
Jaehwan Kim 2013-04-10 11:22:52 +09:00
parent 1f62ff7647
commit f5029ca33c
3 changed files with 39 additions and 24 deletions

View File

@ -1233,3 +1233,7 @@
2013-04-09 WooHyun Jung 2013-04-09 WooHyun Jung
* Ctxpopup is now supproting focus_direction. * Ctxpopup is now supproting focus_direction.
2013-04-10 Jaehwan Kim
* Fix the region_show/region_bring_in don't have a limit at a paging movement.

View File

@ -203,6 +203,7 @@ Fixes:
* Quit the scroll animator if the scroller don't have a bounce and reach a edge. * Quit the scroll animator if the scroller don't have a bounce and reach a edge.
* Fix the scroller show by a page if the page size is set and the region_bring_in or region_show is called. * Fix the scroller show by a page if the page size is set and the region_bring_in or region_show is called.
* Fix elc_player crash issue. * Fix elc_player crash issue.
* Fix the region_show/region_bring_in don't have a limit at a paging movement.
Removals: Removals:

View File

@ -34,10 +34,10 @@ static const Evas_Smart_Cb_Description _smart_callbacks[] = {
static void _elm_pan_content_set(Evas_Object *, Evas_Object *); static void _elm_pan_content_set(Evas_Object *, Evas_Object *);
static Eina_Bool _paging_is_enabled(Elm_Scrollable_Smart_Interface_Data *sid); static Eina_Bool _paging_is_enabled(Elm_Scrollable_Smart_Interface_Data *sid);
static Evas_Coord static Evas_Coord _elm_scroll_page_x_get
_elm_scroll_page_x_get(Elm_Scrollable_Smart_Interface_Data *sid, int offset); (Elm_Scrollable_Smart_Interface_Data *sid, int offset, Eina_Bool limit);
static Evas_Coord static Evas_Coord _elm_scroll_page_y_get
_elm_scroll_page_y_get(Elm_Scrollable_Smart_Interface_Data *sid, int offset); (Elm_Scrollable_Smart_Interface_Data *sid, int offset, Eina_Bool limit);
static void static void
_elm_pan_update(Elm_Pan_Smart_Data *psd) _elm_pan_update(Elm_Pan_Smart_Data *psd)
@ -1709,8 +1709,8 @@ _elm_scroll_content_region_show_internal(Evas_Object *obj,
if (_paging_is_enabled(sid)) if (_paging_is_enabled(sid))
{ {
x = _elm_scroll_page_x_get(sid, nx - px); x = _elm_scroll_page_x_get(sid, nx - px, EINA_FALSE);
y = _elm_scroll_page_y_get(sid, ny - py); y = _elm_scroll_page_y_get(sid, ny - py, EINA_FALSE);
} }
else else
{ {
@ -1994,7 +1994,7 @@ _elm_scroll_momentum_animator(void *data)
static Evas_Coord static Evas_Coord
_elm_scroll_page_x_get(Elm_Scrollable_Smart_Interface_Data *sid, _elm_scroll_page_x_get(Elm_Scrollable_Smart_Interface_Data *sid,
int offset) int offset, Eina_Bool limit)
{ {
Evas_Coord x, y, w, h, dx, cw, ch, minx = 0; Evas_Coord x, y, w, h, dx, cw, ch, minx = 0;
@ -2008,12 +2008,17 @@ _elm_scroll_page_x_get(Elm_Scrollable_Smart_Interface_Data *sid,
if (sid->pagerel_h > 0.0) if (sid->pagerel_h > 0.0)
sid->pagesize_h = w * sid->pagerel_h; sid->pagesize_h = w * sid->pagerel_h;
dx = (sid->pagesize_h * ((double)sid->page_limit_h - 0.5)); if (!limit)
x += offset;
if (offset > 0)
x += (abs(offset) < dx ? offset : dx);
else else
x += (abs(offset) < dx ? offset : -dx); {
dx = (sid->pagesize_h * ((double)sid->page_limit_h - 0.5));
if (offset > 0)
x += (abs(offset) < dx ? offset : dx);
else
x += (abs(offset) < dx ? offset : -dx);
}
if (sid->pagesize_h > 0) if (sid->pagesize_h > 0)
{ {
@ -2029,7 +2034,7 @@ _elm_scroll_page_x_get(Elm_Scrollable_Smart_Interface_Data *sid,
static Evas_Coord static Evas_Coord
_elm_scroll_page_y_get(Elm_Scrollable_Smart_Interface_Data *sid, _elm_scroll_page_y_get(Elm_Scrollable_Smart_Interface_Data *sid,
int offset) int offset, Eina_Bool limit)
{ {
Evas_Coord x, y, w, h, dy, cw, ch, miny = 0; Evas_Coord x, y, w, h, dy, cw, ch, miny = 0;
@ -2043,12 +2048,17 @@ _elm_scroll_page_y_get(Elm_Scrollable_Smart_Interface_Data *sid,
if (sid->pagerel_v > 0.0) if (sid->pagerel_v > 0.0)
sid->pagesize_v = h * sid->pagerel_v; sid->pagesize_v = h * sid->pagerel_v;
dy = (sid->pagesize_v * ((double)sid->page_limit_v - 0.5)); if (!limit)
y += offset;
if (offset > 0)
y += (abs(offset) < dy ? offset : dy);
else else
y += (abs(offset) < dy ? offset : -dy); {
dy = (sid->pagesize_v * ((double)sid->page_limit_v - 0.5));
if (offset > 0)
y += (abs(offset) < dy ? offset : dy);
else
y += (abs(offset) < dy ? offset : -dy);
}
if (sid->pagesize_v > 0) if (sid->pagesize_v > 0)
{ {
@ -2391,7 +2401,7 @@ _elm_scroll_mouse_up_event_cb(void *data,
(!elm_widget_drag_child_locked_x_get (!elm_widget_drag_child_locked_x_get
(sid->obj))) (sid->obj)))
{ {
pgx = _elm_scroll_page_x_get(sid, ox); pgx = _elm_scroll_page_x_get(sid, ox, EINA_TRUE);
if (pgx != x) if (pgx != x)
{ {
ev->event_flags |= EVAS_EVENT_FLAG_ON_SCROLL; ev->event_flags |= EVAS_EVENT_FLAG_ON_SCROLL;
@ -2403,7 +2413,7 @@ _elm_scroll_mouse_up_event_cb(void *data,
(!elm_widget_drag_child_locked_y_get (!elm_widget_drag_child_locked_y_get
(sid->obj))) (sid->obj)))
{ {
pgy = _elm_scroll_page_y_get(sid, oy); pgy = _elm_scroll_page_y_get(sid, oy, EINA_TRUE);
if (pgy != y) if (pgy != y)
{ {
ev->event_flags |= EVAS_EVENT_FLAG_ON_SCROLL; ev->event_flags |= EVAS_EVENT_FLAG_ON_SCROLL;
@ -2427,7 +2437,7 @@ _elm_scroll_mouse_up_event_cb(void *data,
(!elm_widget_drag_child_locked_x_get (!elm_widget_drag_child_locked_x_get
(sid->obj))) (sid->obj)))
{ {
pgx = _elm_scroll_page_x_get(sid, ox); pgx = _elm_scroll_page_x_get(sid, ox, EINA_TRUE);
if (pgx != x) if (pgx != x)
_elm_scroll_scroll_to_x _elm_scroll_scroll_to_x
(sid, _elm_config->page_scroll_friction, pgx); (sid, _elm_config->page_scroll_friction, pgx);
@ -2436,7 +2446,7 @@ _elm_scroll_mouse_up_event_cb(void *data,
(!elm_widget_drag_child_locked_y_get (!elm_widget_drag_child_locked_y_get
(sid->obj))) (sid->obj)))
{ {
pgy = _elm_scroll_page_y_get(sid, oy); pgy = _elm_scroll_page_y_get(sid, oy, EINA_TRUE);
if (pgy != y) if (pgy != y)
_elm_scroll_scroll_to_y _elm_scroll_scroll_to_y
(sid, _elm_config->page_scroll_friction, pgy); (sid, _elm_config->page_scroll_friction, pgy);
@ -3165,8 +3175,8 @@ _elm_scroll_page_adjust(Elm_Scrollable_Smart_Interface_Data *sid)
eo_do(sid->obj, elm_scrollable_interface_content_viewport_size_get(&w, &h)); eo_do(sid->obj, elm_scrollable_interface_content_viewport_size_get(&w, &h));
x = _elm_scroll_page_x_get(sid, 0); x = _elm_scroll_page_x_get(sid, 0, EINA_TRUE);
y = _elm_scroll_page_y_get(sid, 0); y = _elm_scroll_page_y_get(sid, 0, EINA_TRUE);
eo_do(sid->obj, elm_scrollable_interface_content_region_set(x, y, w, h)); eo_do(sid->obj, elm_scrollable_interface_content_region_set(x, y, w, h));
} }