废话不多说了,直接给大家贴代码了。具体代码如下所示: <?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
2024-01-21
2023-10-28
2023-10-28
2023-10-27
2023-10-27
2023-10-27
2023-10-27
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0