Моя цель состоит в том, чтобы реализовать функцию удаления в списке, которая содержит два иерархических уровня элементов A и B, один из которых содержит другой. Список может быть:
Что мне удастся сделать с моим recycler adapter
, так это реализовать этот список с помощью удаления, однако каждый элемент (A или B) является элементом списка. Чтобы различать guish иерархию, я просто отобразил элемент B с левым полем.
Поскольку каждый элемент рассматривается как элемент списка, если вы проведете пальцем, чтобы удалить элемент A, business logi c удаляет все элементы B, связанные с A, и если вы проводите, чтобы удалить элемент B, удаляется только этот элемент.
Что я хотел бы сделать, так это то, что когда я элемент A, я хотел бы, чтобы каждый связанный с ним B был проведен одновременно, только с движением пальца A. Я не знаю, что я должен сделать, чтобы реализовать это. Я не знаю, звучит ли что-нибудь ясно, но я пытаюсь объяснить простой эффект ^^
ItemTouchHelper itemTouchHelper = new ItemTouchHelper(new ItemTouchHelper.SimpleCallback(0, ItemTouchHelper.RIGHT) {
@Override
public boolean onMove(@NonNull RecyclerView recyclerView, @NonNull RecyclerView.ViewHolder viewHolder, @NonNull RecyclerView.ViewHolder target) {
return false;
}
@Override
public void onChildDraw(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive) {
if (actionState == ItemTouchHelper.ACTION_STATE_SWIPE) {
// Get RecyclerView item from the ViewHolder
View itemView = viewHolder.itemView;
Paint p = new Paint();
//Bitmap icon;
if (dX > 0) {
Bitmap icon = getBitmapFromVectorDrawable(getApplicationContext(), R.drawable.ic_delete_black_24dp);
/* Set the color for positive displacement */
p.setARGB(255, 255, 0, 0);
// Draw Rect with varying right side, equal to displacement dX
c.drawRect((float) itemView.getLeft(), (float) itemView.getTop(), dX,
(float) itemView.getBottom(), p);
c.drawBitmap(icon,
(float) dX - convertDpToPx(40),
(float) itemView.getTop() + ((float) itemView.getBottom() - (float) itemView.getTop() - icon.getHeight())/2,
p);
}
// Fade out the view as it is swiped out of the parent's bounds
final float alpha = 1.0f - Math.abs(dX) / (float) viewHolder.itemView.getWidth();
viewHolder.itemView.setAlpha(alpha);
viewHolder.itemView.setTranslationX(dX);
// If negative displacement is needed
/*else {
*//* Set the color for negative displacement *//*
p.setARGB(255, 0, 255, 0);
// Draw Rect with varying left side, equal to the item's right side plus negative displacement dX
c.drawRect((float) itemView.getRight() + dX, (float) itemView.getTop(),
(float) itemView.getRight(), (float) itemView.getBottom(), p);
}*/
super.onChildDraw(c, recyclerView, viewHolder, dX, dY, actionState, isCurrentlyActive);
}
}