Adding a new scroller API, to block its movements (by user input).
With this new API the user can block movements on X axis, Y Axis or both. I was left with no option but to come up with this, side by side with elm_object_scroll_freeze_push(), elm_object_scroll_hold_push() and elm_object_scroll_lock_x_set() (or elm_object_scroll_lock_y_set()), once all of these will act on *parent and/or child* widgets too, making those useless for any pratical use of scroll blocking. Here's a sane, new option, enjoy it.
This commit is contained in:
parent
9c28b4409e
commit
52597125f7
|
@ -45,6 +45,58 @@ my_bt_hold_toggle(void *data, Evas_Object *obj, void *event_info __UNUSED__)
|
|||
elm_object_scroll_hold_pop((Evas_Object *)data);
|
||||
}
|
||||
|
||||
void
|
||||
my_bt_block_movements_x_axis(void *data, Evas_Object *obj,
|
||||
void *event_info __UNUSED__)
|
||||
{
|
||||
Elm_Scroller_Movement_Block block;
|
||||
|
||||
block = elm_scroller_movement_block_get((Evas_Object *)data);
|
||||
|
||||
if (elm_check_state_get(obj))
|
||||
{
|
||||
elm_scroller_movement_block_set((Evas_Object *)data,
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_HORIZONTAL |
|
||||
block);
|
||||
}
|
||||
else if (block & ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL)
|
||||
{
|
||||
elm_scroller_movement_block_set((Evas_Object *)data,
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL);
|
||||
}
|
||||
else
|
||||
{
|
||||
elm_scroller_movement_block_set((Evas_Object *)data,
|
||||
ELM_SCROLLER_MOVEMENT_NO_BLOCK);
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
my_bt_block_movements_y_axis(void *data, Evas_Object *obj,
|
||||
void *event_info __UNUSED__)
|
||||
{
|
||||
Elm_Scroller_Movement_Block block;
|
||||
|
||||
block = elm_scroller_movement_block_get((Evas_Object *)data);
|
||||
|
||||
if (elm_check_state_get(obj))
|
||||
{
|
||||
elm_scroller_movement_block_set((Evas_Object *)data,
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL |
|
||||
block);
|
||||
}
|
||||
else if (block & ELM_SCROLLER_MOVEMENT_BLOCK_HORIZONTAL)
|
||||
{
|
||||
elm_scroller_movement_block_set((Evas_Object *)data,
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_HORIZONTAL);
|
||||
}
|
||||
else
|
||||
{
|
||||
elm_scroller_movement_block_set((Evas_Object *)data,
|
||||
ELM_SCROLLER_MOVEMENT_NO_BLOCK);
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
_sc_move_cb(void *data, Evas *e __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__)
|
||||
{
|
||||
|
@ -64,7 +116,7 @@ _sc_resize_cb(void *data, Evas *e __UNUSED__, Evas_Object *obj, void *event_info
|
|||
void
|
||||
test_scroller(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
|
||||
{
|
||||
Evas_Object *win, *bg2, *tb, *tb2, *sc, *bt, *ck1, *ck2, *bx, *bx2, *fr;
|
||||
Evas_Object *win, *bg2, *tb, *tb2, *sc, *bt, *ck1, *ck2, *bx, *bx2, *fr, *ck3, *ck4;
|
||||
int i, j, n;
|
||||
char buf[PATH_MAX];
|
||||
Evas_Coord x = 0, y = 0, w = 0, h = 0;
|
||||
|
@ -111,6 +163,16 @@ test_scroller(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_in
|
|||
elm_box_pack_end(bx2, ck2);
|
||||
evas_object_show(ck2);
|
||||
|
||||
ck3 = elm_check_add(win);
|
||||
elm_object_text_set(ck3, "Block movements in X axis");
|
||||
elm_box_pack_end(bx2, ck3);
|
||||
evas_object_show(ck3);
|
||||
|
||||
ck4 = elm_check_add(win);
|
||||
elm_object_text_set(ck4, "Block movements in Y axis");
|
||||
elm_box_pack_end(bx2, ck4);
|
||||
evas_object_show(ck4);
|
||||
|
||||
sc = elm_scroller_add(win);
|
||||
evas_object_size_hint_weight_set(sc, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
|
||||
evas_object_size_hint_align_set(sc, EVAS_HINT_FILL, EVAS_HINT_FILL);
|
||||
|
@ -145,6 +207,10 @@ test_scroller(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_in
|
|||
|
||||
evas_object_smart_callback_add(ck1, "changed", my_bt_freeze_toggle, tb);
|
||||
evas_object_smart_callback_add(ck2, "changed", my_bt_hold_toggle, tb);
|
||||
evas_object_smart_callback_add(ck3, "changed", my_bt_block_movements_x_axis,
|
||||
sc);
|
||||
evas_object_smart_callback_add(ck4, "changed", my_bt_block_movements_y_axis,
|
||||
sc);
|
||||
|
||||
tb2 = elm_table_add(win);
|
||||
|
||||
|
|
|
@ -1874,6 +1874,10 @@ _elm_scroll_wheel_event_cb(void *data,
|
|||
sid = data;
|
||||
ev = event_info;
|
||||
direction = ev->direction;
|
||||
|
||||
if (sid->block & ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL)
|
||||
return;
|
||||
|
||||
if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD) return;
|
||||
if ((evas_key_modifier_is_set(ev->modifiers, "Control")) ||
|
||||
(evas_key_modifier_is_set(ev->modifiers, "Alt")) ||
|
||||
|
@ -2301,6 +2305,10 @@ _elm_scroll_mouse_up_event_cb(void *data,
|
|||
|
||||
if (!sid->pan_obj) return;
|
||||
|
||||
if ((sid->block & ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL) &&
|
||||
(sid->block & ELM_SCROLLER_MOVEMENT_BLOCK_HORIZONTAL))
|
||||
return;
|
||||
|
||||
#ifdef SMOOTHDBG
|
||||
if (_elm_scroll_smooth_debug) _elm_scroll_smooth_debug_shutdown();
|
||||
#endif
|
||||
|
@ -2461,7 +2469,9 @@ _elm_scroll_mouse_up_event_cb(void *data,
|
|||
(sid->obj)))
|
||||
{
|
||||
pgx = _elm_scroll_page_x_get(sid, ox, EINA_TRUE);
|
||||
if (pgx != x)
|
||||
if (pgx != x &&
|
||||
!(sid->block &
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_HORIZONTAL))
|
||||
{
|
||||
ev->event_flags |= EVAS_EVENT_FLAG_ON_SCROLL;
|
||||
_elm_scroll_scroll_to_x
|
||||
|
@ -2473,7 +2483,9 @@ _elm_scroll_mouse_up_event_cb(void *data,
|
|||
(sid->obj)))
|
||||
{
|
||||
pgy = _elm_scroll_page_y_get(sid, oy, EINA_TRUE);
|
||||
if (pgy != y)
|
||||
if (pgy != y &&
|
||||
!(sid->block &
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL))
|
||||
{
|
||||
ev->event_flags |= EVAS_EVENT_FLAG_ON_SCROLL;
|
||||
_elm_scroll_scroll_to_y
|
||||
|
@ -2560,6 +2572,10 @@ _elm_scroll_mouse_down_event_cb(void *data,
|
|||
sid = data;
|
||||
ev = event_info;
|
||||
|
||||
if ((sid->block & ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL) &&
|
||||
(sid->block & ELM_SCROLLER_MOVEMENT_BLOCK_HORIZONTAL))
|
||||
return;
|
||||
|
||||
#ifdef SMOOTHDBG
|
||||
if (getenv("ELS_SCROLLER_SMOOTH_DEBUG")) _elm_scroll_smooth_debug = 1;
|
||||
if (_elm_scroll_smooth_debug) _elm_scroll_smooth_debug_init();
|
||||
|
@ -2977,6 +2993,10 @@ _elm_scroll_mouse_move_event_cb(void *data,
|
|||
|
||||
if (!sid->pan_obj) return;
|
||||
|
||||
if ((sid->block & ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL) &&
|
||||
(sid->block & ELM_SCROLLER_MOVEMENT_BLOCK_HORIZONTAL))
|
||||
return;
|
||||
|
||||
ev = event_info;
|
||||
if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD)
|
||||
sid->down.hold_parent = EINA_TRUE;
|
||||
|
@ -2988,7 +3008,8 @@ _elm_scroll_mouse_move_event_cb(void *data,
|
|||
|
||||
if (!sid->down.now) return;
|
||||
|
||||
if ((sid->scrollto.x.animator) && (!sid->hold) && (!sid->freeze))
|
||||
if ((sid->scrollto.x.animator) && (!sid->hold) && (!sid->freeze) &&
|
||||
!(sid->block & ELM_SCROLLER_MOVEMENT_BLOCK_HORIZONTAL))
|
||||
{
|
||||
Evas_Coord px;
|
||||
ecore_animator_del(sid->scrollto.x.animator);
|
||||
|
@ -2998,7 +3019,8 @@ _elm_scroll_mouse_move_event_cb(void *data,
|
|||
sid->down.x = sid->down.history[0].x;
|
||||
}
|
||||
|
||||
if ((sid->scrollto.y.animator) && (!sid->hold) && (!sid->freeze))
|
||||
if ((sid->scrollto.y.animator) && (!sid->hold) && (!sid->freeze) &&
|
||||
!(sid->block & ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL))
|
||||
{
|
||||
Evas_Coord py;
|
||||
ecore_animator_del(sid->scrollto.y.animator);
|
||||
|
@ -3053,20 +3075,36 @@ _elm_scroll_mouse_move_event_cb(void *data,
|
|||
int dodir = 0;
|
||||
if (x > (y * 2))
|
||||
{
|
||||
sid->down.dir_x = EINA_TRUE;
|
||||
if (!(sid->block &
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_HORIZONTAL))
|
||||
{
|
||||
sid->down.dir_x = EINA_TRUE;
|
||||
}
|
||||
sid->down.dir_y = EINA_FALSE;
|
||||
dodir++;
|
||||
}
|
||||
if (y > (x * 2))
|
||||
{
|
||||
sid->down.dir_x = EINA_FALSE;
|
||||
sid->down.dir_y = EINA_TRUE;
|
||||
if (!(sid->block &
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL))
|
||||
{
|
||||
sid->down.dir_y = EINA_TRUE;
|
||||
}
|
||||
dodir++;
|
||||
}
|
||||
if (!dodir)
|
||||
{
|
||||
sid->down.dir_x = EINA_TRUE;
|
||||
sid->down.dir_y = EINA_TRUE;
|
||||
if (!(sid->block &
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_HORIZONTAL))
|
||||
{
|
||||
sid->down.dir_x = EINA_TRUE;
|
||||
}
|
||||
if (!(sid->block &
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL))
|
||||
{
|
||||
sid->down.dir_y = EINA_TRUE;
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (sid->one_direction_at_a_time ==
|
||||
|
@ -3074,21 +3112,37 @@ _elm_scroll_mouse_move_event_cb(void *data,
|
|||
{
|
||||
if (x > y)
|
||||
{
|
||||
sid->down.dir_x = EINA_TRUE;
|
||||
if (!(sid->block &
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_HORIZONTAL))
|
||||
{
|
||||
sid->down.dir_x = EINA_TRUE;
|
||||
}
|
||||
sid->down.dir_y = EINA_FALSE;
|
||||
}
|
||||
if (y > x)
|
||||
{
|
||||
sid->down.dir_x = EINA_FALSE;
|
||||
sid->down.dir_y = EINA_TRUE;
|
||||
if (!(sid->block &
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL))
|
||||
{
|
||||
sid->down.dir_y = EINA_TRUE;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
sid->down.dir_x = EINA_TRUE;
|
||||
sid->down.dir_y = EINA_TRUE;
|
||||
if (!(sid->block &
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_HORIZONTAL))
|
||||
{
|
||||
sid->down.dir_x = EINA_TRUE;
|
||||
}
|
||||
if (!(sid->block &
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL))
|
||||
{
|
||||
sid->down.dir_y = EINA_TRUE;
|
||||
}
|
||||
}
|
||||
}
|
||||
if ((!sid->hold) && (!sid->freeze))
|
||||
|
@ -4299,6 +4353,27 @@ _elm_scroll_gravity_get(Eo *obj EINA_UNUSED, void *_pd EINA_UNUSED, va_list *lis
|
|||
eo_do(sid->pan_obj, elm_obj_pan_gravity_get(x, y));
|
||||
}
|
||||
|
||||
static void
|
||||
_elm_scroll_movement_block_set(Eo *obj __UNUSED__, void *_pd, va_list *list)
|
||||
{
|
||||
Elm_Scrollable_Smart_Interface_Data *sid = _pd;
|
||||
|
||||
Elm_Scroller_Movement_Block block = va_arg(*list,
|
||||
Elm_Scroller_Movement_Block);
|
||||
|
||||
sid->block = block;
|
||||
}
|
||||
|
||||
static void
|
||||
_elm_scroll_movement_block_get(Eo *obj __UNUSED__, void *_pd, va_list *list)
|
||||
{
|
||||
Elm_Scrollable_Smart_Interface_Data *sid = _pd;
|
||||
Elm_Scroller_Movement_Block *block = va_arg(*list,
|
||||
Elm_Scroller_Movement_Block *);
|
||||
|
||||
*block = sid->block;
|
||||
}
|
||||
|
||||
static void
|
||||
_elm_scroll_interface_add(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
|
||||
{
|
||||
|
@ -4329,6 +4404,7 @@ _elm_scroll_interface_add(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
|
|||
sid->one_direction_at_a_time = ELM_SCROLLER_SINGLE_DIRECTION_SOFT;
|
||||
sid->momentum_animator_disabled = EINA_FALSE;
|
||||
sid->bounce_animator_disabled = EINA_FALSE;
|
||||
sid->block = ELM_SCROLLER_MOVEMENT_NO_BLOCK;
|
||||
|
||||
_elm_scroll_scroll_bar_reset(sid);
|
||||
|
||||
|
@ -4434,6 +4510,8 @@ _elm_scrollable_interface_constructor(Eo_Class *klass)
|
|||
EO_OP_FUNC(ELM_SCROLLABLE_INTERFACE_ID(ELM_SCROLLABLE_INTERFACE_SUB_ID_BOUNCE_ANIMATOR_DISABLED_GET), _elm_scroll_bounce_animator_disabled_get),
|
||||
EO_OP_FUNC(ELM_SCROLLABLE_INTERFACE_ID(ELM_SCROLLABLE_INTERFACE_SUB_ID_WHEEL_DISABLED_GET), _elm_scroll_wheel_disabled_get),
|
||||
EO_OP_FUNC(ELM_SCROLLABLE_INTERFACE_ID(ELM_SCROLLABLE_INTERFACE_SUB_ID_WHEEL_DISABLED_SET), _elm_scroll_wheel_disabled_set),
|
||||
EO_OP_FUNC(ELM_SCROLLABLE_INTERFACE_ID(ELM_SCROLLABLE_INTERFACE_SUB_ID_MOVEMENT_BLOCK_SET), _elm_scroll_movement_block_set),
|
||||
EO_OP_FUNC(ELM_SCROLLABLE_INTERFACE_ID(ELM_SCROLLABLE_INTERFACE_SUB_ID_MOVEMENT_BLOCK_GET), _elm_scroll_movement_block_get),
|
||||
EO_OP_FUNC_SENTINEL
|
||||
};
|
||||
eo_class_funcs_set(klass, func_desc);
|
||||
|
@ -4504,6 +4582,8 @@ static const Eo_Op_Description op_desc[] = {
|
|||
EO_OP_DESCRIPTION(ELM_SCROLLABLE_INTERFACE_SUB_ID_BOUNCE_ANIMATOR_DISABLED_GET, "description here"),
|
||||
EO_OP_DESCRIPTION(ELM_SCROLLABLE_INTERFACE_SUB_ID_WHEEL_DISABLED_GET, "description here"),
|
||||
EO_OP_DESCRIPTION(ELM_SCROLLABLE_INTERFACE_SUB_ID_WHEEL_DISABLED_SET, "description here"),
|
||||
EO_OP_DESCRIPTION(ELM_SCROLLABLE_INTERFACE_SUB_ID_MOVEMENT_BLOCK_SET, "Set movement block in a axis"),
|
||||
EO_OP_DESCRIPTION(ELM_SCROLLABLE_INTERFACE_SUB_ID_MOVEMENT_BLOCK_GET, "Get the movement block"),
|
||||
EO_OP_DESCRIPTION_SENTINEL
|
||||
};
|
||||
|
||||
|
|
|
@ -211,6 +211,8 @@ enum
|
|||
ELM_SCROLLABLE_INTERFACE_SUB_ID_BOUNCE_ANIMATOR_DISABLED_GET,
|
||||
ELM_SCROLLABLE_INTERFACE_SUB_ID_WHEEL_DISABLED_GET,
|
||||
ELM_SCROLLABLE_INTERFACE_SUB_ID_WHEEL_DISABLED_SET,
|
||||
ELM_SCROLLABLE_INTERFACE_SUB_ID_MOVEMENT_BLOCK_SET,
|
||||
ELM_SCROLLABLE_INTERFACE_SUB_ID_MOVEMENT_BLOCK_GET,
|
||||
ELM_SCROLLABLE_INTERFACE_SUB_ID_LAST
|
||||
};
|
||||
|
||||
|
@ -939,6 +941,29 @@ enum
|
|||
*/
|
||||
#define elm_scrollable_interface_wheel_disabled_set(disabled) ELM_SCROLLABLE_INTERFACE_ID(ELM_SCROLLABLE_INTERFACE_SUB_ID_WHEEL_DISABLED_SET), EO_TYPECHECK(Eina_Bool, disabled)
|
||||
|
||||
/**
|
||||
* @def elm_scrollable_interface_movement_block_set
|
||||
* @since 1.8
|
||||
*
|
||||
* No description supplied by the EAPI.
|
||||
*
|
||||
* @param[in] block
|
||||
*
|
||||
*/
|
||||
#define elm_scrollable_interface_movement_block_set(block) ELM_SCROLLABLE_INTERFACE_ID(ELM_SCROLLABLE_INTERFACE_SUB_ID_MOVEMENT_BLOCK_SET), EO_TYPECHECK(Elm_Scroller_Movement_Block, block)
|
||||
|
||||
/**
|
||||
* @def elm_scrollable_interface_movement_block_set
|
||||
* @since 1.8
|
||||
*
|
||||
* No description supplied by the EAPI.
|
||||
*
|
||||
* @param[in] block
|
||||
*
|
||||
*/
|
||||
#define elm_scrollable_interface_movement_block_get(block) ELM_SCROLLABLE_INTERFACE_ID(ELM_SCROLLABLE_INTERFACE_SUB_ID_MOVEMENT_BLOCK_GET), EO_TYPECHECK(Elm_Scroller_Movement_Block *, block)
|
||||
|
||||
|
||||
/**
|
||||
* Elementary scroller panning base smart data.
|
||||
*/
|
||||
|
@ -976,6 +1001,7 @@ struct _Elm_Scrollable_Smart_Interface_Data
|
|||
|
||||
Elm_Scroller_Policy hbar_flags, vbar_flags;
|
||||
Elm_Scroller_Single_Direction one_direction_at_a_time;
|
||||
Elm_Scroller_Movement_Block block;
|
||||
|
||||
struct
|
||||
{
|
||||
|
|
|
@ -1210,6 +1210,27 @@ elm_scroller_gravity_get(const Evas_Object *obj,
|
|||
eo_do((Eo *) obj, elm_scrollable_interface_gravity_get(x, y));
|
||||
}
|
||||
|
||||
EAPI void
|
||||
elm_scroller_movement_block_set(Evas_Object *obj,
|
||||
Elm_Scroller_Movement_Block block)
|
||||
{
|
||||
ELM_SCROLLABLE_CHECK(obj);
|
||||
|
||||
eo_do(obj, elm_scrollable_interface_movement_block_set(block));
|
||||
}
|
||||
|
||||
EAPI Elm_Scroller_Movement_Block
|
||||
elm_scroller_movement_block_get(const Evas_Object *obj)
|
||||
{
|
||||
Elm_Scroller_Movement_Block block;
|
||||
|
||||
ELM_SCROLLABLE_CHECK(obj, ELM_SCROLLER_SINGLE_DIRECTION_NONE);
|
||||
|
||||
eo_do((Eo *) obj, elm_scrollable_interface_movement_block_get(&block));
|
||||
|
||||
return block;
|
||||
}
|
||||
|
||||
EAPI void
|
||||
elm_scroller_propagate_events_set(Evas_Object *obj,
|
||||
Eina_Bool propagation)
|
||||
|
|
|
@ -24,4 +24,18 @@ typedef enum
|
|||
ELM_SCROLLER_SINGLE_DIRECTION_LAST
|
||||
} Elm_Scroller_Single_Direction;
|
||||
|
||||
/**
|
||||
* @brief Type that blocks the scroll movement in one or more direction.
|
||||
*
|
||||
* @see elm_scroller_movement_block()
|
||||
*
|
||||
* @since 1.8
|
||||
*/
|
||||
typedef enum
|
||||
{
|
||||
ELM_SCROLLER_MOVEMENT_NO_BLOCK = 1 << 0, /**< Do not block movements */
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_VERTICAL = 1 << 1, /**< Block vertical movements */
|
||||
ELM_SCROLLER_MOVEMENT_BLOCK_HORIZONTAL = 1 << 2 /**< Block horizontal movements */
|
||||
} Elm_Scroller_Movement_Block;
|
||||
|
||||
|
||||
|
|
|
@ -446,3 +446,40 @@ EAPI void elm_scroller_gravity_set(Evas_Object *obj, do
|
|||
*/
|
||||
EAPI void elm_scroller_gravity_get(const Evas_Object *obj, double *x, double *y);
|
||||
|
||||
/**
|
||||
* @brief Set blocking of scrolling (per axis) on a given scroller
|
||||
*
|
||||
* @param obj The scroller object
|
||||
* @param block The axis to block
|
||||
*
|
||||
* This function will block scrolling movement (by input of a user) in
|
||||
* a given direction. One can disable movements in the X axis, the Y
|
||||
* axis or both. The default value is @c ELM_SCROLLER_MOVEMENT_NO_BLOCK,
|
||||
* where movements are allowed in both directions.
|
||||
*
|
||||
* What makes this function different from
|
||||
* elm_object_scroll_freeze_push(), elm_object_scroll_hold_push() and
|
||||
* elm_object_scroll_lock_x_set() (or elm_object_scroll_lock_y_set())
|
||||
* is that it @b doesn't propagate its effects to any parent or child
|
||||
* widget of @a obj. Only the target scrollable widget will be locked
|
||||
* with regard to scrolling.
|
||||
*
|
||||
* @since 1.8
|
||||
*
|
||||
* @ingroup Scroller
|
||||
*/
|
||||
EAPI void elm_scroller_movement_block_set(Evas_Object *obj, Elm_Scroller_Movement_Block block);
|
||||
|
||||
/**
|
||||
* @brief Get a scroller's scroll blocking state
|
||||
*
|
||||
* @param parent The scroller object
|
||||
* @return The blocking state
|
||||
*
|
||||
* @since 1.8
|
||||
*
|
||||
* @see elm_scroller_movement_block_set() for more details
|
||||
*
|
||||
* @ingroup Scroller
|
||||
*/
|
||||
EAPI Elm_Scroller_Movement_Block elm_scroller_movement_block_get(const Evas_Object *obj);
|
||||
|
|
Loading…
Reference in New Issue