2017-12-18 3 views
4

私はリサイクルビューをアンドロイドに持っています。 ItemTouchHelperを添付しました。左から右へのスワイプだけを有効にしました。距離を近づけた後、リサイクラービューでアイテムをスワイプする方法

リサイクルビューのアイテムをスワイプすると、アイテムは右に向かって移動し始め、左にはテキストが描画されます。 これは問題ありません。 私の要件は、ユーザーにある距離だけスワイプさせ、その距離に達してユーザーがタッチを離すと、スワイプされているアイテムが左に向かって元の位置に戻るようにすることです。

問題は、左から右にスワイプすると、ビューが画面から完全にスワイプされるという問題です。私はそれをある距離だけスワイプするように制限することはできますか? どうすればいいですか? 、それは100になるように、最大​​のx位置を設定し、次のようで

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

private void initSwipe(){ 
    ItemTouchHelper.SimpleCallback simpleItemTouchCallback = new ItemTouchHelper.SimpleCallback(0, ItemTouchHelper.RIGHT) { 
      @Override 
      public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) { 
       return false; 
      } 

      @Override 
      public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) { 
       int position = viewHolder.getAdapterPosition(); 
      } 

     @Override 
     public void onChildDraw(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive) { 
      ViewHolder viewHolder1 = (ViewHolder)viewHolder; 
      int position = viewHolder1.getAdapterPosition(); 
      MyItem item = dataList.get(position); 
      if (item==null)return; 
      if(actionState == ItemTouchHelper.ACTION_STATE_SWIPE){ 

       View itemView = viewHolder.itemView; 
       float height = (float) itemView.getBottom() - (float) itemView.getTop(); 
       float width = height/3; 
       Paint p = new Paint(); 
       Paint textPaint = new Paint(); 
       textPaint.setColor(Color.WHITE); 
       textPaint.setTextSize(20); 

       if(dX > 0) { 
        p.setColor(Color.parseColor("#000000")); 
        RectF background = new RectF((float) itemView.getLeft(), (float) itemView.getTop(), dX,(float) itemView.getBottom()); 
        c.drawRect(background,p); 
        //RectF icon_dest = new RectF((float) itemView.getLeft() + width ,(float) itemView.getTop() + width,(float) itemView.getLeft()+ 2*width,(float)itemView.getBottom() - width); 
        //c.drawBitmap(icon,null,icon_dest,p); 
        c.drawText(item.getDate(),(float)(itemView.getLeft() + width),(float)(itemView.getBottom() - width), textPaint); 
       } 
      } 
      super.onChildDraw(c, recyclerView, viewHolder, dX, dY, actionState, isCurrentlyActive); 
     } 
    }; 
    ItemTouchHelper itemTouchHelper = new ItemTouchHelper(simpleItemTouchCallback); 
    itemTouchHelper.attachToRecyclerView(myRecycler); 
}` 

答えて

0

はonChildDrawでこの行を置き換えます

は、ここでアイテムのタッチコールバックのための私のコードですこの値を必要に応じて調整します。コールバックハンドラのonSwipedで

float newDx = dX; 
if (newDx >= >100f) { 
    newDx = 100f 
} 
super.onChildDraw(c, recyclerView, viewHolder, newDx, dY, actionState, isCurrentlyActive); 

Then、RecyclerViewアダプタにnotifyItemChangedを呼び出します。

@Override 
public void onSwiped(RecyclerView.ViewHolder viewHolder, 
    int direction) { 
     if (direction == ItemTouchHelper.RIGHT) { 
     adapter.notifyItemChanged(viewHolder.getAdapterPosition()) 
    } 
} 

notifyItemChangedと若干の問題は、ビューがそれの元の位置に復元取得されたときに、迅速なフラッシュに気づくかもしれないということです。

関連する問題