java.lang.Object
↳androidx.recyclerview.widget.ItemTouchHelper.Callback
Subclasses:
ItemTouchHelper.SimpleCallback
Overview
This class is the contract between ItemTouchHelper and your application. It lets you control
which touch behaviors are enabled per each ViewHolder and also receive callbacks when user
performs these actions.
To control which actions user can take on each view, you should override
ItemTouchHelper.Callback and return appropriate set
of direction flags. (ItemTouchHelper.LEFT, ItemTouchHelper.RIGHT, ItemTouchHelper.START, ItemTouchHelper.END,
ItemTouchHelper.UP, ItemTouchHelper.DOWN). You can use
ItemTouchHelper.Callback.makeMovementFlags(int, int) to easily construct it. Alternatively, you can use
ItemTouchHelper.SimpleCallback.
If user drags an item, ItemTouchHelper will call
onMove(recyclerView, dragged, target).
Upon receiving this callback, you should move the item from the old position
(dragged.getAdapterPosition()) to new position (target.getAdapterPosition())
in your adapter and also call RecyclerView.Adapter.notifyItemMoved(int, int).
To control where a View can be dropped, you can override
ItemTouchHelper.Callback. When a
dragging View overlaps multiple other views, Callback chooses the closest View with which
dragged View might have changed positions. Although this approach works for many use cases,
if you have a custom LayoutManager, you can override
ItemTouchHelper.Callback to select a
custom drop target.
When a View is swiped, ItemTouchHelper animates it until it goes out of bounds, then calls
ItemTouchHelper.Callback. At this point, you should update your
adapter (e.g. remove the item) and call related Adapter#notify event.
Summary
Methods |
---|
public boolean | canDropOver(RecyclerView recyclerView, RecyclerView.ViewHolder current, RecyclerView.ViewHolder target)
Return true if the current ViewHolder can be dropped over the the target ViewHolder. |
public RecyclerView.ViewHolder | chooseDropTarget(RecyclerView.ViewHolder selected, java.util.List<RecyclerView.ViewHolder> dropTargets, int curX, int curY)
Called by ItemTouchHelper to select a drop target from the list of ViewHolders that
are under the dragged View. |
public void | clearView(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder)
Called by the ItemTouchHelper when the user interaction with an element is over and it
also completed its animation. |
public int | convertToAbsoluteDirection(int flags, int layoutDirection)
Converts a given set of flags to absolution direction which means ItemTouchHelper.START and
ItemTouchHelper.END are replaced with ItemTouchHelper.LEFT and ItemTouchHelper.RIGHT depending on the layout
direction. |
public static int | convertToRelativeDirection(int flags, int layoutDirection)
Replaces a movement direction with its relative version by taking layout direction into
account. |
public long | getAnimationDuration(RecyclerView recyclerView, int animationType, float animateDx, float animateDy)
Called by the ItemTouchHelper when user action finished on a ViewHolder and now the View
will be animated to its final position. |
public int | getBoundingBoxMargin()
When finding views under a dragged view, by default, ItemTouchHelper searches for views
that overlap with the dragged View. |
public static ItemTouchUIUtil | getDefaultUIUtil()
Returns the ItemTouchUIUtil that is used by the ItemTouchHelper.Callback class for
visual
changes on Views in response to user interactions. |
public abstract int | getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder)
Should return a composite flag which defines the enabled move directions in each state
(idle, swiping, dragging). |
public float | getMoveThreshold(RecyclerView.ViewHolder viewHolder)
Returns the fraction that the user should move the View to be considered as it is
dragged. |
public float | getSwipeEscapeVelocity(float defaultValue)
Defines the minimum velocity which will be considered as a swipe action by the user. |
public float | getSwipeThreshold(RecyclerView.ViewHolder viewHolder)
Returns the fraction that the user should move the View to be considered as swiped. |
public float | getSwipeVelocityThreshold(float defaultValue)
Defines the maximum velocity ItemTouchHelper will ever calculate for pointer movements. |
public int | interpolateOutOfBoundsScroll(RecyclerView recyclerView, int viewSize, int viewSizeOutOfBounds, int totalSize, long msSinceStartScroll)
Called by the ItemTouchHelper when user is dragging a view out of bounds. |
public boolean | isItemViewSwipeEnabled()
Returns whether ItemTouchHelper should start a swipe operation if a pointer is swiped
over the View. |
public boolean | isLongPressDragEnabled()
Returns whether ItemTouchHelper should start a drag and drop operation if an item is
long pressed. |
public static int | makeFlag(int actionState, int directions)
Shifts the given direction flags to the offset of the given action state. |
public static int | makeMovementFlags(int dragFlags, int swipeFlags)
Convenience method to create movement flags. |
public void | onChildDraw(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive)
Called by ItemTouchHelper on RecyclerView's onDraw callback. |
public void | onChildDrawOver(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive)
Called by ItemTouchHelper on RecyclerView's onDraw callback. |
public abstract boolean | onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target)
Called when ItemTouchHelper wants to move the dragged item from its old position to
the new position. |
public void | onMoved(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, int fromPos, RecyclerView.ViewHolder target, int toPos, int x, int y)
Called when ItemTouchHelper.Callback returns true. |
public void | onSelectedChanged(RecyclerView.ViewHolder viewHolder, int actionState)
Called when the ViewHolder swiped or dragged by the ItemTouchHelper is changed. |
public abstract void | onSwiped(RecyclerView.ViewHolder viewHolder, int direction)
Called when a ViewHolder is swiped by the user. |
from java.lang.Object | clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Fields
public static final int
DEFAULT_DRAG_ANIMATION_DURATIONpublic static final int
DEFAULT_SWIPE_ANIMATION_DURATIONConstructors
Methods
Returns the ItemTouchUIUtil that is used by the ItemTouchHelper.Callback class for
visual
changes on Views in response to user interactions. ItemTouchUIUtil has different
implementations for different platform versions.
By default, ItemTouchHelper.Callback applies these changes on
RecyclerView.ViewHolder.itemView.
For example, if you have a use case where you only want the text to move when user
swipes over the view, you can do the following:
public void clearView(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder){
getDefaultUIUtil().clearView(((ItemTouchViewHolder) viewHolder).textView);
}
public void onSelectedChanged(RecyclerView.ViewHolder viewHolder, int actionState) {
if (viewHolder != null){
getDefaultUIUtil().onSelected(((ItemTouchViewHolder) viewHolder).textView);
}
}
public void onChildDraw(Canvas c, RecyclerView recyclerView,
RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState,
boolean isCurrentlyActive) {
getDefaultUIUtil().onDraw(c, recyclerView,
((ItemTouchViewHolder) viewHolder).textView, dX, dY,
actionState, isCurrentlyActive);
return true;
}
public void onChildDrawOver(Canvas c, RecyclerView recyclerView,
RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState,
boolean isCurrentlyActive) {
getDefaultUIUtil().onDrawOver(c, recyclerView,
((ItemTouchViewHolder) viewHolder).textView, dX, dY,
actionState, isCurrentlyActive);
return true;
}
Returns:
The ItemTouchUIUtil instance that is used by the ItemTouchHelper.Callback
public static int
convertToRelativeDirection(int flags, int layoutDirection)
Replaces a movement direction with its relative version by taking layout direction into
account.
Parameters:
flags: The flag value that include any number of movement flags.
layoutDirection: The layout direction of the View. Can be obtained from
ViewCompat.
Returns:
Updated flags which uses relative flags (ItemTouchHelper.START, ItemTouchHelper.END) instead
of ItemTouchHelper.LEFT, ItemTouchHelper.RIGHT.
See also: ItemTouchHelper.Callback.convertToAbsoluteDirection(int, int)
public static int
makeMovementFlags(int dragFlags, int swipeFlags)
Convenience method to create movement flags.
For instance, if you want to let your items be drag & dropped vertically and swiped
left to be dismissed, you can call this method with:
makeMovementFlags(UP | DOWN, LEFT);
Parameters:
dragFlags: The directions in which the item can be dragged.
swipeFlags: The directions in which the item can be swiped.
Returns:
Returns an integer composed of the given drag and swipe flags.
public static int
makeFlag(int actionState, int directions)
Shifts the given direction flags to the offset of the given action state.
Parameters:
actionState: The action state you want to get flags in. Should be one of
ItemTouchHelper.ACTION_STATE_IDLE, ItemTouchHelper.ACTION_STATE_SWIPE or
ItemTouchHelper.ACTION_STATE_DRAG.
directions: The direction flags. Can be composed from ItemTouchHelper.UP, ItemTouchHelper.DOWN,
ItemTouchHelper.RIGHT, ItemTouchHelper.LEFT ItemTouchHelper.START and ItemTouchHelper.END.
Returns:
And integer that represents the given directions in the provided actionState.
Should return a composite flag which defines the enabled move directions in each state
(idle, swiping, dragging).
Instead of composing this flag manually, you can use ItemTouchHelper.Callback.makeMovementFlags(int, int)
or ItemTouchHelper.Callback.makeFlag(int, int).
This flag is composed of 3 sets of 8 bits, where first 8 bits are for IDLE state, next
8 bits are for SWIPE state and third 8 bits are for DRAG state.
Each 8 bit sections can be constructed by simply OR'ing direction flags defined in
ItemTouchHelper.
For example, if you want it to allow swiping LEFT and RIGHT but only allow starting to
swipe by swiping RIGHT, you can return:
makeFlag(ACTION_STATE_IDLE, RIGHT) | makeFlag(ACTION_STATE_SWIPE, LEFT | RIGHT);
This means, allow right movement while IDLE and allow right and left movement while
swiping.
Parameters:
recyclerView: The RecyclerView to which ItemTouchHelper is attached.
viewHolder: The ViewHolder for which the movement information is necessary.
Returns:
flags specifying which movements are allowed on this ViewHolder.
See also: ItemTouchHelper.Callback.makeMovementFlags(int, int), ItemTouchHelper.Callback.makeFlag(int, int)
public int
convertToAbsoluteDirection(int flags, int layoutDirection)
Converts a given set of flags to absolution direction which means ItemTouchHelper.START and
ItemTouchHelper.END are replaced with ItemTouchHelper.LEFT and ItemTouchHelper.RIGHT depending on the layout
direction.
Parameters:
flags: The flag value that include any number of movement flags.
layoutDirection: The layout direction of the RecyclerView.
Returns:
Updated flags which includes only absolute direction values.
Return true if the current ViewHolder can be dropped over the the target ViewHolder.
This method is used when selecting drop target for the dragged View. After Views are
eliminated either via bounds check or via this method, resulting set of views will be
passed to ItemTouchHelper.Callback.
Default implementation returns true.
Parameters:
recyclerView: The RecyclerView to which ItemTouchHelper is attached to.
current: The ViewHolder that user is dragging.
target: The ViewHolder which is below the dragged ViewHolder.
Returns:
True if the dragged ViewHolder can be replaced with the target ViewHolder, false
otherwise.
Called when ItemTouchHelper wants to move the dragged item from its old position to
the new position.
If this method returns true, ItemTouchHelper assumes viewHolder has been moved
to the adapter position of target ViewHolder
(ViewHolder#getAdapterPositionInRecyclerView()).
If you don't support drag & drop, this method will never be called.
Parameters:
recyclerView: The RecyclerView to which ItemTouchHelper is attached to.
viewHolder: The ViewHolder which is being dragged by the user.
target: The ViewHolder over which the currently active item is being
dragged.
Returns:
True if the viewHolder has been moved to the adapter position of
target.
See also: ItemTouchHelper.Callback
public boolean
isLongPressDragEnabled()
Returns whether ItemTouchHelper should start a drag and drop operation if an item is
long pressed.
Default value returns true but you may want to disable this if you want to start
dragging on a custom view touch using ItemTouchHelper.Callback.
Returns:
True if ItemTouchHelper should start dragging an item when it is long pressed,
false otherwise. Default value is true
.
See also: ItemTouchHelper.Callback
public boolean
isItemViewSwipeEnabled()
Returns whether ItemTouchHelper should start a swipe operation if a pointer is swiped
over the View.
Default value returns true but you may want to disable this if you want to start
swiping on a custom view touch using ItemTouchHelper.Callback.
Returns:
True if ItemTouchHelper should start swiping an item when user swipes a pointer
over the View, false otherwise. Default value is true
.
See also: ItemTouchHelper.Callback
public int
getBoundingBoxMargin()
When finding views under a dragged view, by default, ItemTouchHelper searches for views
that overlap with the dragged View. By overriding this method, you can extend or shrink
the search box.
Returns:
The extra margin to be added to the hit box of the dragged View.
Returns the fraction that the user should move the View to be considered as swiped.
The fraction is calculated with respect to RecyclerView's bounds.
Default value is .5f, which means, to swipe a View, user must move the View at least
half of RecyclerView's width or height, depending on the swipe direction.
Parameters:
viewHolder: The ViewHolder that is being dragged.
Returns:
A float value that denotes the fraction of the View size. Default value
is .5f .
Returns the fraction that the user should move the View to be considered as it is
dragged. After a view is moved this amount, ItemTouchHelper starts checking for Views
below it for a possible drop.
Parameters:
viewHolder: The ViewHolder that is being dragged.
Returns:
A float value that denotes the fraction of the View size. Default value is
.5f .
public float
getSwipeEscapeVelocity(float defaultValue)
Defines the minimum velocity which will be considered as a swipe action by the user.
You can increase this value to make it harder to swipe or decrease it to make it easier.
Keep in mind that ItemTouchHelper also checks the perpendicular velocity and makes sure
current direction velocity is larger then the perpendicular one. Otherwise, user's
movement is ambiguous. You can change the threshold by overriding
ItemTouchHelper.Callback.getSwipeVelocityThreshold(float).
The velocity is calculated in pixels per second.
The default framework value is passed as a parameter so that you can modify it with a
multiplier.
Parameters:
defaultValue: The default value (in pixels per second) used by the
ItemTouchHelper.
Returns:
The minimum swipe velocity. The default implementation returns the
defaultValue
parameter.
See also: ItemTouchHelper.Callback.getSwipeVelocityThreshold(float), ItemTouchHelper.Callback
public float
getSwipeVelocityThreshold(float defaultValue)
Defines the maximum velocity ItemTouchHelper will ever calculate for pointer movements.
To consider a movement as swipe, ItemTouchHelper requires it to be larger than the
perpendicular movement. If both directions reach to the max threshold, none of them will
be considered as a swipe because it is usually an indication that user rather tried to
scroll then swipe.
The velocity is calculated in pixels per second.
You can customize this behavior by changing this method. If you increase the value, it
will be easier for the user to swipe diagonally and if you decrease the value, user will
need to make a rather straight finger movement to trigger a swipe.
Parameters:
defaultValue: The default value(in pixels per second) used by the ItemTouchHelper.
Returns:
The velocity cap for pointer movements. The default implementation returns the
defaultValue
parameter.
See also: ItemTouchHelper.Callback.getSwipeEscapeVelocity(float)
Called by ItemTouchHelper to select a drop target from the list of ViewHolders that
are under the dragged View.
Default implementation filters the View with which dragged item have changed position
in the drag direction. For instance, if the view is dragged UP, it compares the
view.getTop()
of the two views before and after drag started. If that value
is different, the target view passes the filter.
Among these Views which pass the test, the one closest to the dragged view is chosen.
This method is called on the main thread every time user moves the View. If you want to
override it, make sure it does not do any expensive operations.
Parameters:
selected: The ViewHolder being dragged by the user.
dropTargets: The list of ViewHolder that are under the dragged View and
candidate as a drop.
curX: The updated left value of the dragged View after drag translations
are applied. This value does not include margins added by
RecyclerView.ItemDecorations.
curY: The updated top value of the dragged View after drag translations
are applied. This value does not include margins added by
RecyclerView.ItemDecorations.
Returns:
A ViewHolder to whose position the dragged ViewHolder should be
moved to.
Called when a ViewHolder is swiped by the user.
If you are returning relative directions (ItemTouchHelper.START , ItemTouchHelper.END) from the
ItemTouchHelper.Callback method, this method
will also use relative directions. Otherwise, it will use absolute directions.
If you don't support swiping, this method will never be called.
ItemTouchHelper will keep a reference to the View until it is detached from
RecyclerView.
As soon as it is detached, ItemTouchHelper will call
ItemTouchHelper.Callback.
Parameters:
viewHolder: The ViewHolder which has been swiped by the user.
direction: The direction to which the ViewHolder is swiped. It is one of
ItemTouchHelper.UP, ItemTouchHelper.DOWN,
ItemTouchHelper.LEFT or ItemTouchHelper.RIGHT. If your
ItemTouchHelper.Callback
method
returned relative flags instead of ItemTouchHelper.LEFT / ItemTouchHelper.RIGHT;
`direction` will be relative as well. (ItemTouchHelper.START or ItemTouchHelper.END).
Called when the ViewHolder swiped or dragged by the ItemTouchHelper is changed.
If you override this method, you should call super.
Parameters:
viewHolder: The new ViewHolder that is being swiped or dragged. Might be null if
it is cleared.
actionState: One of ItemTouchHelper.ACTION_STATE_IDLE,
ItemTouchHelper.ACTION_STATE_SWIPE or
ItemTouchHelper.ACTION_STATE_DRAG.
See also: ItemTouchHelper.Callback.clearView(RecyclerView, RecyclerView.ViewHolder)
Called when ItemTouchHelper.Callback returns true.
ItemTouchHelper does not create an extra Bitmap or View while dragging, instead, it
modifies the existing View. Because of this reason, it is important that the View is
still part of the layout after it is moved. This may not work as intended when swapped
Views are close to RecyclerView bounds or there are gaps between them (e.g. other Views
which were not eligible for dropping over).
This method is responsible to give necessary hint to the LayoutManager so that it will
keep the View in visible area. For example, for LinearLayoutManager, this is as simple
as calling LinearLayoutManager.scrollToPositionWithOffset(int, int).
Default implementation calls RecyclerView.scrollToPosition(int) if the View's
new position is likely to be out of bounds.
It is important to ensure the ViewHolder will stay visible as otherwise, it might be
removed by the LayoutManager if the move causes the View to go out of bounds. In that
case, drag will end prematurely.
Parameters:
recyclerView: The RecyclerView controlled by the ItemTouchHelper.
viewHolder: The ViewHolder under user's control.
fromPos: The previous adapter position of the dragged item (before it was
moved).
target: The ViewHolder on which the currently active item has been dropped.
toPos: The new adapter position of the dragged item.
x: The updated left value of the dragged View after drag translations
are applied. This value does not include margins added by
RecyclerView.ItemDecorations.
y: The updated top value of the dragged View after drag translations
are applied. This value does not include margins added by
RecyclerView.ItemDecorations.
Called by the ItemTouchHelper when the user interaction with an element is over and it
also completed its animation.
This is a good place to clear all changes on the View that was done in
ItemTouchHelper.Callback.onSelectedChanged(RecyclerView.ViewHolder, int),
ItemTouchHelper.Callback or
ItemTouchHelper.Callback.
Parameters:
recyclerView: The RecyclerView which is controlled by the ItemTouchHelper.
viewHolder: The View that was interacted by the user.
Called by ItemTouchHelper on RecyclerView's onDraw callback.
If you would like to customize how your View's respond to user interactions, this is
a good place to override.
Default implementation translates the child by the given dX
,
dY
.
ItemTouchHelper also takes care of drawing the child after other children if it is being
dragged. This is done using child re-ordering mechanism. On platforms prior to L, this
is
achieved via android.view.ViewGroup
and on L
and after, it changes View's elevation value to be greater than all other children.)
Parameters:
c: The canvas which RecyclerView is drawing its children
recyclerView: The RecyclerView to which ItemTouchHelper is attached to
viewHolder: The ViewHolder which is being interacted by the User or it was
interacted and simply animating to its original position
dX: The amount of horizontal displacement caused by user's action
dY: The amount of vertical displacement caused by user's action
actionState: The type of interaction on the View. Is either ItemTouchHelper.ACTION_STATE_DRAG or ItemTouchHelper.ACTION_STATE_SWIPE.
isCurrentlyActive: True if this view is currently being controlled by the user or
false it is simply animating back to its original state.
See also: ItemTouchHelper.Callback
Called by ItemTouchHelper on RecyclerView's onDraw callback.
If you would like to customize how your View's respond to user interactions, this is
a good place to override.
Default implementation translates the child by the given dX
,
dY
.
ItemTouchHelper also takes care of drawing the child after other children if it is being
dragged. This is done using child re-ordering mechanism. On platforms prior to L, this
is
achieved via android.view.ViewGroup
and on L
and after, it changes View's elevation value to be greater than all other children.)
Parameters:
c: The canvas which RecyclerView is drawing its children
recyclerView: The RecyclerView to which ItemTouchHelper is attached to
viewHolder: The ViewHolder which is being interacted by the User or it was
interacted and simply animating to its original position
dX: The amount of horizontal displacement caused by user's action
dY: The amount of vertical displacement caused by user's action
actionState: The type of interaction on the View. Is either ItemTouchHelper.ACTION_STATE_DRAG or ItemTouchHelper.ACTION_STATE_SWIPE.
isCurrentlyActive: True if this view is currently being controlled by the user or
false it is simply animating back to its original state.
See also: ItemTouchHelper.Callback
public long
getAnimationDuration(
RecyclerView recyclerView, int animationType, float animateDx, float animateDy)
Called by the ItemTouchHelper when user action finished on a ViewHolder and now the View
will be animated to its final position.
Default implementation uses ItemAnimator's duration values. If
animationType
is ItemTouchHelper.ANIMATION_TYPE_DRAG, it returns
RecyclerView.ItemAnimator.getMoveDuration(), otherwise, it returns
RecyclerView.ItemAnimator.getRemoveDuration(). If RecyclerView does not have
any RecyclerView.ItemAnimator attached, this method returns
DEFAULT_DRAG_ANIMATION_DURATION or DEFAULT_SWIPE_ANIMATION_DURATION
depending on the animation type.
Parameters:
recyclerView: The RecyclerView to which the ItemTouchHelper is attached to.
animationType: The type of animation. Is one of ItemTouchHelper.ANIMATION_TYPE_DRAG,
ItemTouchHelper.ANIMATION_TYPE_SWIPE_CANCEL or
ItemTouchHelper.ANIMATION_TYPE_SWIPE_SUCCESS.
animateDx: The horizontal distance that the animation will offset
animateDy: The vertical distance that the animation will offset
Returns:
The duration for the animation
public int
interpolateOutOfBoundsScroll(
RecyclerView recyclerView, int viewSize, int viewSizeOutOfBounds, int totalSize, long msSinceStartScroll)
Called by the ItemTouchHelper when user is dragging a view out of bounds.
You can override this method to decide how much RecyclerView should scroll in response
to this action. Default implementation calculates a value based on the amount of View
out of bounds and the time it spent there. The longer user keeps the View out of bounds,
the faster the list will scroll. Similarly, the larger portion of the View is out of
bounds, the faster the RecyclerView will scroll.
Parameters:
recyclerView: The RecyclerView instance to which ItemTouchHelper is
attached to.
viewSize: The total size of the View in scroll direction, excluding
item decorations.
viewSizeOutOfBounds: The total size of the View that is out of bounds. This value
is negative if the View is dragged towards left or top edge.
totalSize: The total size of RecyclerView in the scroll direction.
msSinceStartScroll: The time passed since View is kept out of bounds.
Returns:
The amount that RecyclerView should scroll. Keep in mind that this value will
be passed to RecyclerView.scrollBy(int, int) method.