Android技术程序员Android进阶之旅

RecyclerViewItem滑动排序以及侧滑删除

2017-05-18  本文已影响128人  阴天吃鱼
GridLayoutManager效果图:
gridview.gif
录像软件不好使了,所以图片网上借用,但效果相符,本文提供具体的实现方式。
LinearLayoutManager效果图:
linear2.gif

主要实现RecyclerView 条目根据不同的布局,支持随意拖动以及侧滑删除。话不多说直接上代码。

滑动排序实现的方式,是通过继承ItemTouchHelper.Callback 重写其的方法,而在这些方法中我需要通过接口获取:
public interface OnItemMoveListener {

    void onItemMove(int fromPosition, int toPosition);

    void onItemDismiss(int position);
}

So 我实例了以上的接口为了方便在adapter中使用的时候处理我需要做的操作。

接下来直接上ItemTouchHelper.Callback,我分别做了GridLayoutManager和LinearLayoutManager的可拖滑动方向以及侧滑删除判断

<pre >
public class MoveItem extends ItemTouchHelper.Callback {

private OnItemMoveListener adapter;//因为要在adaper中使用所以直接赋值此名

public MoveItem(OnItemMoveListener adapter) {
    this.adapter = adapter;
}
@Override
public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {
    //主要设置屏幕中Item可拖动的方向,以及侧滑的方向。
    RecyclerView.LayoutManager layoutManager = recyclerView.getLayoutManager();
    if (layoutManager instanceof GridLayoutManager) {
        int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN | ItemTouchHelper.LEFT | ItemTouchHelper.RIGHT;
        int swipeFlags = ItemTouchHelper.LEFT | ItemTouchHelper.RIGHT;
        return makeMovementFlags(dragFlags, swipeFlags);
    } else if (layoutManager instanceof LinearLayoutManager) {
        LinearLayoutManager linearLayoutManager = (LinearLayoutManager) layoutManager;
        if (linearLayoutManager.getOrientation() == LinearLayoutManager.HORIZONTAL) {
            int dragFlags = ItemTouchHelper.LEFT | ItemTouchHelper.RIGHT;
            int swipeFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN;
            return makeMovementFlags(dragFlags, swipeFlags);
        } else {
            int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN;
            int swipeFlags = ItemTouchHelper.LEFT | ItemTouchHelper.RIGHT;
            return makeMovementFlags(dragFlags, swipeFlags);
        }
    }
    return makeMovementFlags(0, 0);
}

@Override
public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) {
    adapter.onItemMove(viewHolder.getAdapterPosition(), target.getAdapterPosition());//移动
    return true;
}

@Override
public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) {
    adapter.onItemDismiss(viewHolder.getAdapterPosition());//侧滑
}

@Override
public boolean isLongPressDragEnabled() {
    return true;//必须为true才支持
}

@Override
public boolean isItemViewSwipeEnabled() {
    return true;//必须为true才支持
}

}

</pre>

接口的方式也是为了进行传值,接下来是adapter中的操作。为adapter实现接口,重写方法

<pre>
public class RecyclerMoveAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> implements
OnItemMoveListener {
private List<String> list;
private Context mContext;
private LayoutInflater inflater;

public RecyclerMoveAdapter(Context mContext) {
    this.mContext = mContext;
    inflater = (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
}

public void setData(List<String> list) {
    this.list = list;
    notifyDataSetChanged();
}

@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    View view = inflater.inflate(R.layout.item_recycler_move, parent, false);
    MyViewHolder holder = new MyViewHolder(view);
    return holder;
}

@Override
public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
    MyViewHolder myViewHolder = (MyViewHolder) holder;
    myViewHolder.text.setText(list.get(position));
}

@Override
public int getItemCount() {
    return list.size();
}

@Override
public void onItemMove(int fromPosition, int toPosition) {
    Collections.swap(list, fromPosition, toPosition);
    notifyItemMoved(fromPosition, toPosition);
}

@Override
public void onItemDismiss(int position) {
    list.remove(position);
    notifyDataSetChanged();
}

class MyViewHolder extends RecyclerView.ViewHolder {
    TextView text;

    public MyViewHolder(View itemView) {
        super(itemView);
        text = (TextView) itemView.findViewById(R.id.text);
    }
}

}
</pre>

adapter没什么说的,主要就是多了一步实现接口。并进行了item顺序的调换以及即时刷新。

接下来的重点就是使用啦。

    private RecyclerView recycler;
    private List<String> recyclerData = new ArrayList<>();
    private RecyclerMoveAdapter recyclerMoveAdapter;
    private MoveItem moveItem;
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_banner);
        initView();
        initData();
    }
    public void initView() {
        recycler = (RecyclerView) findViewById(R.id.recycler);
        recyclerMoveAdapter = new RecyclerMoveAdapter(this);
        moveItem = new MoveItem(recyclerMoveAdapter);
      
    public void initData() {
       for (int i = 0; i < 20; i++) {
              recyclerData.add(i + "");
        }


      //在itemTouch里面已经进行了布局管理判断。
       //GridLayoutManager layoutManager = new GridLayoutManager(mActivity, 3);
       LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this,LinearLayoutManager.VERTICAL,false);
        recycler.setLayoutManager(linearLayoutManager);
        recycler.setHasFixedSize(true);
        recycler.setAdapter(recyclerMoveAdapter);

        recyclerMoveAdapter.setData(recyclerData);

        ItemTouchHelper helper = new ItemTouchHelper(moveItem);
        helper.attachToRecyclerView(recycler);
    }
不喜勿喷,谢谢。

有兴趣的小伙伴可以帮忙关注一下csdn,谢谢
https://blog.csdn.net/binbinxiaoz

上一篇 下一篇

猜你喜欢

热点阅读