RecycleView Item换位置,item删除--ItemTouchHelper

简单的recycleView 使用

       首先写一个简单的RecycleView:首先是MainActivity

 public class MainActivity extends AppCompatActivity {
          RecyclerView recyclerView;
          MyAdapter myAdapter ;
          ArrayList arrayList  = new ArrayList<>();
          @Override
          protected void onCreate(Bundle savedInstanceState) {
          super.onCreate(savedInstanceState);
          setContentView(R.layout.activity_main);
          recyclerView = findViewById(R.id.rv);
          //这里完全可以换成LinearLayoutManager 只是个人demo这样写了。
          GridLayoutManager gridLayoutManager = new GridLayoutManager(this, 1);
          myAdapter = new MyAdapter(this);
          recyclerView.setLayoutManager(gridLayoutManager);
          //修改默认的动画,不是重点
          DefaultItemAnimator defaultItemAnimator = new DefaultItemAnimator();
          defaultItemAnimator.setAddDuration(1000);
          recyclerView.setItemAnimator(defaultItemAnimator);
          recyclerView.setAdapter(myAdapter);
          initData();
      }
      private void initData(){
          for(int a = 0; a < 20; a ++){
              arrayList.add("demo"+"==="+a);
          }
          myAdapter.setData(arrayList);
      }
  }

    其次是adapter:

public class MyAdapter extends RecyclerView.Adapter {
    @NonNull
    Context mContext;
    ArrayList data = null;
    public MyAdapter(@NonNull Context mContext) {
        this.mContext = mContext;
      }
      public  void setData(ArrayList data){
          this.data = data;
          notifyDataSetChanged();
    }
      @Override
      public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int i) {
          View view  = LayoutInflater.from(mContext).inflate(R.layout.recycleview_item,viewGroup,false);
          return new ViewHolder(view);
    }
      @Override
      public void onBindViewHolder(final RecyclerView.ViewHolder viewHolder, final int i) {
          ((ViewHolder)viewHolder).tv.setText(data.get(i));
         }
    @Override
      public int getItemCount() {
          return data==null?0:data.size();
      }
      class ViewHolder extends RecyclerView.ViewHolder {
          TextView  tv ;
          LinearLayout ll;
          public ViewHolder(@NonNull View itemView) {
            super(itemView);
            tv = itemView.findViewById(R.id.tv);
            ll = itemView.findViewById(R.id.ll);
        }
    }

       运行跑起来就是我们一般见到的简单的列表 如图1:

RecycleView Item换位置,item删除--ItemTouchHelper_第1张图片
图1.png

       这是简单的使用,假如做为展示的列表这样就可以完成了。但是有时候做成菜单,也就说个数有限。item的顺序可以由用户自己排序,删除。那么就要稍微加点东西了。下面看一下这个文章的主角 ItemTouchHelper这里先贴出写好的类然后再分析吧。RecycleViewHelper:

public class RecycleViewHelp {
    String TAG = "RecycleViewHelp";
    MyAdapter myAdapter;
    //绑定Adapter 方便调用adapter里面的方法  其实这边也可以用接口实现。
    public RecycleViewHelp(MyAdapter myAdapter) {
        this.myAdapter = myAdapter;
    }
    //这个是主角
    ItemTouchHelper itemTouchHelper = new ItemTouchHelper(new ItemTouchHelper.Callback() {
        @Override
        public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {
            int swipeFlag = ItemTouchHelper.START|ItemTouchHelper.END;
            int drawFlag = ItemTouchHelper.RIGHT|1|2|4;
            /** 这个是可以滑动的标志 第一个是长按换位置,第二个是滑动删除 上面的两个int 代表的是滑动的 方向,开源码看一下    
                源码中是这么定义的   
                public static final int UP = 1;
                public static final int DOWN = 1 << 1;  
                public static final int LEFT = 1 << 2;  
                public static final int RIGHT = 1 << 3;  
                分别代表了上下左右。看源码的时候会发现写代码的会经常用a<

MainActivity中添加代码:

    RecycleViewHelp recycleViewHelp = new RecycleViewHelp(myAdapter);
    recycleViewHelp.attacthRecycle(recyclerView);

Adapter中添加代码:

 public void move(int start ,int end){
       Collections.swap(data, start, end);
       }

       运行启动。

RecycleView Item换位置,item删除--ItemTouchHelper_第2张图片
换位置.gif

       至于滑动删除也同理,先改数据源再去刷新适配器。删除,增加 都是有系统提供的方法

    data.remove(position)
    notifyDataSetChanged();

       最后给上自己做的小例子,一般的菜单栏。git:https://github.com/w171066813/RecycleView

RecycleView Item换位置,item删除--ItemTouchHelper_第3张图片
类似菜单的RecycleView.gif

你可能感兴趣的:(RecycleView Item换位置,item删除--ItemTouchHelper)