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

所属分类: 软件编程 / Android 阅读数: 28
收藏 0 赞 0 分享

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

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="c.example.jreduch10.Recycler1Activity">
<android.support.v7.widget.RecyclerView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/rv"
></android.support.v7.widget.RecyclerView>
</RelativeLayout>
<span style="font-size:18px;">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<Video> 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<ViewHolder>{ 
private List<Video> mData; 
public Adapter(List<Video> 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(); 
} 
}); 
} 
} 
} 
</span> 



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

更多精彩内容其他人还在看

Android设计登录界面、找回密码、注册功能

这篇文章主要为大家详细介绍了Android设计登录界面的方法,Android实现找回密码、注册功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android通过手势实现答题器翻页效果

这篇文章主要为大家详细介绍了Android通过手势实现答题器翻页效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android采用双缓冲技术实现画板

这篇文章主要为大家详细介绍了Android采用双缓冲技术实现画板的相关资料,思路清晰,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android开发之毛玻璃效果实例代码

这篇文章主要给大家分享android开发之毛玻璃效果的实例代码,非常具有参考借鉴价值,感兴趣的朋友一起学习吧
收藏 0 赞 0 分享

Android实现桌面悬浮窗、蒙板效果实例代码

这篇文章主要介绍了Android实现桌面悬浮窗、蒙板效果实例代码的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

深入解读Android的Volley库的功能结构

这篇文章主要介绍了Android的Volley开发框架的功能结构,Volley是Android开发中网络部分的一大利器,包含很多HTTP协议通信的相关操作,需要的朋友可以参考下
收藏 0 赞 0 分享

Android开发中使用Volley库发送HTTP请求的实例教程

这篇文章主要介绍了Android开发中使用Volley库发送HTTP请求的实例教程,包括创建Volley单例的基本知识与取消Request请求的技巧等,需要的朋友可以参考下
收藏 0 赞 0 分享

Android仿QQ聊天撒花特效 很真实

本文写的这个特效,是关于聊天的,你肯定遇到过,就是你跟人家聊天的时候,比如发送应(么么哒),然后屏幕上全部就是表情了,今天我们就是做这个,撒花的特效,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android的HTTP操作库Volley的基本使用教程

这篇文章主要介绍了Android的HTTP操作库Volley的基本使用教程,包括JSON请求与图片加载等用法的实例,需要的朋友可以参考下
收藏 0 赞 0 分享

Android仿水波纹流量球进度条控制器

这篇文章主要介绍了Android仿水波纹流量球进度条控制器的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享
查看更多