Android监听左右滑删除通知,Android 滑动监听RecyclerView线性流+左右划删除+上下移动...

废话不多说了,直接给大家贴代码了。具体代码如下所示:

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context="c.example.jreduch10.Recycler1Activity">

android:layout_width="match_parent"

android:layout_height="match_parent"

android:id="@+id/rv"

>

package c.example.jreduch10;

import android.os.Bundle;

import android.support.v7.app.AppCompatActivity;

import android.support.v7.widget.LinearLayoutManager;

import android.support.v7.widget.RecyclerView;

import android.support.v7.widget.helper.ItemTouchHelper;

import android.util.Log;

import android.view.View;

import android.view.ViewGroup;

import android.widget.ImageView;

import android.widget.TextView;

import android.widget.Toast;

import java.util.ArrayList;

import java.util.List;

import c.example.jreduch10.entity.Video;

import jp.wasabeef.recyclerview.adapters.AlphaInAnimationAdapter;

import jp.wasabeef.recyclerview.adapters.ScaleInAnimationAdapter;

public class Recycler1Activity extends AppCompatActivity {

private RecyclerView rv;

private List list;

private Adapter adapter;

private ItemTouchHelper itemTouchHelper;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_recycler1);

rv=(RecyclerView)findViewById(R.id.rv);

list=new ArrayList<>();

initData();

adapter=new Adapter(list);

LinearLayoutManager llm=new LinearLayoutManager(this);

llm.setOrientation(LinearLayoutManager.VERTICAL);

rv.setLayoutManager(llm);

// rv.setAdapter(adapter);

//动画效果

AlphaInAnimationAdapter alphaInAnimationAdapter=new AlphaInAnimationAdapter(adapter);

rv.setAdapter(new ScaleInAnimationAdapter(alphaInAnimationAdapter));

//默认动画效果

// rv.setItemAnimator(new DefaultItemAnimator());

itemTouchHelper=createItemTouchHelper();

itemTouchHelper.attachToRecyclerView(rv);

监听事件某一行

// RecyclerViewItemListener listener=new RecyclerViewItemListener(this, new RecyclerViewItemListener.OnItemClickListener() {

// @Override

// public void OnItemClick(View item, int adapterPosition) {

// Toast.makeText(getBaseContext(),adapterPosition+"",Toast.LENGTH_SHORT).show();

// }

// });

// rv.addOnItemTouchListener(listener);

}

public ItemTouchHelper createItemTouchHelper(){

itemTouchHelper=new ItemTouchHelper(new ItemTouchHelper.Callback() {

@Override

public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {

//拖拽时支持的方向向上向下

int dragFlags=ItemTouchHelper.UP|itemTouchHelper.DOWN;

//滑动的时候支持的方向为左右

int swipeFlags=ItemTouchHelper.LEFT|ItemTouchHelper.RIGHT;

//必须调用makeMovementFlags()方法通知 TouchHelper支持的种类

return makeMovementFlags(dragFlags,swipeFlags);

}

//上下拖动回调次方法。

@Override

public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) {

adapter.move(viewHolder.getAdapterPosition(),target.getAdapterPosition());

return true;

}

//左右滑动回调此方法。

@Override

public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) {

adapter.delete(viewHolder.getAdapterPosition());

}

@Override

public boolean isItemViewSwipeEnabled() {

return super.isItemViewSwipeEnabled();

}

@Override

public boolean isLongPressDragEnabled() {

return super.isLongPressDragEnabled();

}

});

return itemTouchHelper;

}

public void initData(){

Video video=new Video(R.mipmap.zyf,"国产","........");

list.add(video);

video=new Video(R.mipmap.zyfzyf,"国产","........");

list.add(video);

video=new Video(R.mipmap.zyfzyfzyf,"国产","........");

list.add(video);

video=new Video(R.mipmap.zyf,"国产","........");

list.add(video);

video=new Video(R.mipmap.g,"国产","........");

list.add(video);

video=new Video(R.mipmap.ic_launcher,"国产","........");

list.add(video);

video=new Video(R.mipmap.zyf,"国产","........");

list.add(video);

video=new Video(R.mipmap.zyf,"国产","........");

list.add(video);

video=new Video(R.mipmap.zyfzyf,"国产","........");

list.add(video);

video=new Video(R.mipmap.zyfzyfzyf,"国产","........");

list.add(video);

video=new Video(R.mipmap.zyf,"国产","........");

list.add(video);

video=new Video(R.mipmap.g,"国产","........");

list.add(video);

video=new Video(R.mipmap.ic_launcher,"国产","........");

list.add(video);

video=new Video(R.mipmap.zyf,"国产","........");

list.add(video);

}

public class Adapter extends RecyclerView.Adapter{

private List mData;

public Adapter(List mData){

this.mData=mData;

}

//左右滑动时调用此方法

public void delete(int position){

mData.remove(position);

notifyItemRemoved(position);

}

//上下拖动时调用此方法

public void move(int from,int to){

Video video=mData.remove(from);

mData.add(to>from?to-1:to,video);

notifyItemMoved(from,to);

}

@Override

public int getItemCount() {

return mData.size();

}

@Override

public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {

View view=getLayoutInflater().inflate(R.layout.recycle1_linear_layout,parent,false);

ViewHolder vh=new ViewHolder(view);

return vh;

}

@Override

public void onBindViewHolder(ViewHolder holder, int position) {

Video video=mData.get(position);

holder.iv.setImageResource(video.getImg());

holder.title.setText(video.getTitle());

holder.content.setText(video.getContent());

}

}

public class ViewHolder extends RecyclerView.ViewHolder{

ImageView iv;

TextView title;

TextView content;

public ViewHolder(View itemView) {

super(itemView);

iv= (ImageView) itemView.findViewById(R.id.iv);

title=(TextView)itemView.findViewById(R.id.title);

content=(TextView)itemView.findViewById(R.id.content);

//监听事件某一项

itemView.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View view) {

int position=getAdapterPosition();

Log.d("9999999999","uuuuu");

Toast.makeText(getBaseContext(),title.getText()+":"+position,Toast.LENGTH_SHORT).show();

}

});

}

}

}

104f81ee14f75143e42637ef9cb2e6be.png

24621e12988191e7f64e431eefe54505.png

2ad2391ec99c042d9a9943a0f3d39adc.png

以上所述是小编给大家介绍的Android 滑动监听RecyclerView线性流+左右划删除+上下移动,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程圈网站的支持!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值