繁体   English   中英

如何在 recyclerview 中添加从左向右滑动

[英]How To add swipe Left to Right in recyclerview

我正在尝试为我的 recyclerview 添加刷卡功能。 我正在关注此链接以添加滑动。 https://github.com/nikhilpanju/RecyclerViewEnhanced/blob/master/recyclerviewenhanced/src/main/java/com/nikhilpanju/recyclerviewenhanced/RecyclerTouchListener.java

在此链接中,我只能从右向左滑动。 我想添加从左到右滑动。 我试图在onInterceptTouchEvent添加功能。 但我不能从左到右滑动。 有人可以帮我添加从左到右滑动吗?

要在 RecyclerView 中实现此类行为,您需要声明一个ItemTouchHelper ,如下所示:

// The class to detect swipes and drags
private lateinit var itemTouchHelper: ItemTouchHelper

ItemTouchHelper类有一个ItemTouchHelper.SimpleCallback.onChildDraw回调方法,您可以在其中检测用户是否在您的回收站ItemTouchHelper.SimpleCallback.onChildDraw向右或向左扫过某个项目。 所以接下来,我们现在将实现这个回调,像这样:

private fun setupRecyclerView() {
    val myRecyclerView = findViewById<RecyclerView>(R.id.myRecyclerView)
    val customAdapter = CustomAdapter()
    myRecyclerView.adapter = customAdapter

    val simpleCallback = object :
        ItemTouchHelper.SimpleCallback(
            0,
            ItemTouchHelper.LEFT or ItemTouchHelper.RIGHT
        ) {
        override fun onMove(
            recyclerView: RecyclerView,
            viewHolder: RecyclerView.ViewHolder,
            target: RecyclerView.ViewHolder
        ): Boolean = false

        override fun onChildDraw(
            c: Canvas,
            recyclerView: RecyclerView,
            viewHolder: RecyclerView.ViewHolder,
            dX: Float,
            dY: Float,
            actionState: Int,
            isCurrentlyActive: Boolean
        ) {

           // If you want to add a background, a text, an icon
          //  as the user swipes, this is where to start decorating
          //  I will link you to a library I created for that below

            super.onChildDraw(
                c,
                recyclerView,
                viewHolder,
                dX,
                dY,
                actionState,
                isCurrentlyActive
            )
        }

        override fun onSwiped(viewHolder: RecyclerView.ViewHolder, direction: Int) {
            val position = viewHolder.adapterPosition
            when (direction) {
                ItemTouchHelper.LEFT -> {
                   // Do something when a user swept left
                }
                ItemTouchHelper.RIGHT -> {
                  // Do something when a user swept right
                }
            }
        }
    }
    itemTouchHelper = ItemTouchHelper(simpleCallback)
    itemTouchHelper.attachToRecyclerView(myRecyclerView)
}

现在,您的回收站视图中将收听该滑动行为。 此外,如果您希望将背景、图标或文本显示为应用程序的用户滑动,您可以使用我为该用途创建的这个很棒的库。 如果您使用的是 gradle,则可以将其下载到您的项目中。 这是它的文档链接: https : //github.com/kevingermainbusiness/ItemDecorator

添加到收藏夹 滑动删除

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM