Android RecyclerView Проведите пальцем, чтобы удалить с иконкой только на первом элементе - PullRequest
0 голосов
/ 16 ноября 2018

Все отлично работает, но одна вещь на самом деле не работает.Значок удаления отображается только в первом элементе списка просмотра переработчика, как показано на рисунке.

enter image description here enter image description here

Вот мой код класса ItemTouchHelper:

class ItemSwipeCallback(val context: Context) : ItemTouchHelper.Callback() {
    private val listeners = ArrayList<OnItemSwipe>()

    private val paint = Paint()
    val theme = context.themeId
    val icon = ContextCompat.getDrawable(context, R.drawable.ic_delete_filled_white_24dp)!!

    override fun onMove(
        recyclerView: RecyclerView,
        viewHolder: RecyclerView.ViewHolder,
        target: RecyclerView.ViewHolder): Boolean {

        return true
    }

    override fun getMovementFlags(recyclerView: RecyclerView, viewHolder: RecyclerView.ViewHolder): Int {
        val direction = context.sharedPreferences.getInt(Preferences.SWIPE_DIRECTION, Preferences.SWIPE_VALUE_RIGHT)

        return when (direction) {
            Preferences.SWIPE_VALUE_RIGHT -> makeMovementFlags(0, ItemTouchHelper.RIGHT)
            Preferences.SWIPE_VALUE_LEFT -> makeMovementFlags(0, ItemTouchHelper.LEFT)
            else -> makeMovementFlags(0, ItemTouchHelper.RIGHT)
        }
    }

    override fun onSwiped(viewHolder: RecyclerView.ViewHolder, direction: Int) {
        listeners.forEach { it.onSwiped(viewHolder.layoutPosition, direction) }
    }

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

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

        if (dX != 0f && isCurrentlyActive) {
            val itemView = viewHolder.itemView
            paint.color = Color.parseColor("#D32F2F")
            val top = (itemView.height - icon.intrinsicHeight) / 2
            val left = itemView.width - icon.intrinsicWidth - top

            if (theme == Preferences.THEME_VALUE_DARK) {
                icon.setTint(Color.BLACK)
            } else {
                icon.setTint(Color.WHITE)
            }

            if (dX < 0) {
                val background = RectF(itemView.right.toFloat() + dX, itemView.top.toFloat(),
                    itemView.right.toFloat(), itemView.bottom.toFloat())
                c.drawRect(background, paint)
                icon.setBounds(left, top, left + icon.intrinsicWidth, top + icon.intrinsicHeight)
            } else {
                val background = RectF(itemView.left.toFloat() + dX, itemView.top.toFloat(),
                    itemView.left.toFloat(), itemView.bottom.toFloat())
                c.drawRect(background, paint)
                icon.setBounds(top, top, top + icon.intrinsicWidth, top + icon.intrinsicHeight)
            }
            icon.draw(c)
        }
    }

    fun addOnItemSwipeListener(onItemSwipe: OnItemSwipe) {
        listeners.add(onItemSwipe)
    }
}

Может быть, значок, который загружен в начало класса, можно использовать только один раз?Я уже пытался преобразовать его в растровое изображение и использовать его.Я также попытался загрузить его в функцию onChildDraw.

Ответы [ 2 ]

0 голосов
/ 19 ноября 2018

Решение было слишком простым. Я всегда использовал itemView.height вместо itemView.top.

Холст включает в себя все предметы. Не у каждого предмета есть свой холст. Поэтому я должен добавить высоту вышеупомянутых предметов.

Рабочий код выглядит так:

val top = itemView.top + (itemView.height - intrinsicHeight) / 2
val left = itemView.width - intrinsicWidth - (itemView.height - intrinsicHeight) / 2
val right = left + intrinsicHeight
val bottom = top + intrinsicHeight

if (dX < 0) {
    background.setBounds(itemView.right + dX.toInt(), itemView.top, itemView.right, itemView.bottom)
    icon.setBounds(left, top, right, bottom)
} else if (dX > 0) {
    background.setBounds(itemView.left + dX.toInt(), itemView.top, itemView.left, itemView.bottom)
    icon.setBounds(top, top, top, bottom)
}
background.draw(c)
icon.draw(c)
0 голосов
/ 19 ноября 2018

Проверяли ли вы значение этого параметра: isCurrentlyActive?

Полагаю, в создании изображения нет ошибки (иконка). потому что изображение успешно создано в первый раз. Итак, проблема в цикле.

  if (dX < 0) {...}else{...}

Здесь, независимо от значения dX, изображение будет добавлено к детям (строка).

if (dX != 0f && isCurrentlyActive) 

Это единственная контрольная точка (значительно) в вашем коде. Технически весь блок будет пропущен, если isCurrentlyActive boolean равно false.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...