返回顶部
首页 > 资讯 > 移动开发 >Android 滑动监听RecyclerView线性流+左右划删除+上下移动
  • 376
分享到

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

recyclerviewAndroid 2022-06-06 07:06:39 376人浏览 安东尼
摘要

废话不多说了,直接给大家贴代码了。具体代码如下所示: <?xml version="1.0" encoding="utf-8"?> <R

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


<?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线性流+左右划删除+上下移动,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程网网站的支持!

您可能感兴趣的文章:RecyclerView+CardView实现横向卡片式滑动效果RecyclerView滑动到指定Position的方法Android中RecyclerView实现横向滑动代码Android中RecyclerView嵌套滑动冲突解决的代码片段Android中RecyclerView 滑动时图片加载的优化android RecyclerView侧滑菜单,滑动删除,长按拖拽,下拉刷新上拉加载Android实现评论栏随Recyclerview滑动左右移动Android开发中RecyclerView模仿探探左右滑动布局功能Android RecyclerView滑动删除和拖动排序Android嵌套RecyclerView左右滑动替代自定义viewRecyclerView实现探探卡片滑动效果


--结束END--

本文标题: Android 滑动监听RecyclerView线性流+左右划删除+上下移动

本文链接: https://lsjlt.com/news/23816.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作