项目中需要这个效果,是仿QQ的,资料参考:https://github.com/mcxtzhang/SwipeDelMenuLayout
RecyclerView的Activity:
public class DeleteRecyclerViewActivity extends BaseActivity {
private RecyclerView mRecyclerView;
private List<String> mDatas;
private static final String TAG = "zxt";
private FullDelDemoAdapter mAdapter;
private LinearLayoutManager mLayoutManager;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_recyclerview);
mRecyclerView = (RecyclerView) findViewById(R.id.recyclerview);
// mRecyclerView.setLayoutManager(new LinearLayoutManager(this));
initDatas();
mAdapter = new FullDelDemoAdapter(this, mDatas);
mAdapter.setOnDelListener(new FullDelDemoAdapter.onSwipeListener() {
@Override
public void onDel(int pos) {
if (pos >= 0 && pos < mDatas.size()) {
Toast.makeText(DeleteRecyclerViewActivity.this, "删除:" + pos, Toast.LENGTH_SHORT).show();
mDatas.remove(pos);
mAdapter.notifyItemRemoved(pos);//推荐用这个
//如果删除时,不使用mAdapter.notifyItemRemoved(pos),则删除没有动画效果,
//且如果想让侧滑菜单同时关闭,需要同时调用 ((CstSwipeDelMenu) holder.itemView).quickClose();
//mAdapter.notifyDataSetChanged();
}
}
@Override
public void onTop(int pos) {
if (pos > 0 && pos < mDatas.size()) {
String swipeBean = mDatas.get(pos);
mDatas.remove(swipeBean);
mAdapter.notifyItemInserted(0);
mDatas.add(0, swipeBean);
mAdapter.notifyItemRemoved(pos + 1);
if (mLayoutManager.findFirstVisibleItemPosition() == 0) {
mRecyclerView.scrollToPosition(0);
}
//notifyItemRangeChanged(0,holder.getAdapterPosition()+1);
}
}
});
mRecyclerView.setAdapter(mAdapter);
mRecyclerView.setLayoutManager(new LinearLayoutManager(this));
// mRecyclerView.setLayoutManager(mLayoutManager = new GridLayoutManager(this, 2));
//6 2016 10 21 add , 增加viewChache 的 get()方法,
// 可以用在:当点击外部空白处时,关闭正在展开的侧滑菜单。我个人觉得意义不大,
mRecyclerView.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
if (event.getAction() == MotionEvent.ACTION_UP) {
SwipeMenuLayout viewCache = SwipeMenuLayout.getViewCache();
if (null != viewCache) {
viewCache.smoothClose();
}
}
return false;
}
});
}
@Override
protected void onPostCreate(@Nullable Bundle savedInstanceState) {
super.onPostCreate(savedInstanceState);
if (mRefreshLayout != null) {
mRefreshLayout.addOnRefreshListener(new VRefreshLayout.OnRefreshListener() {
@Override
public void onRefresh() {
mRefreshLayout.postDelayed(new Runnable() {
@Override
public void run() {
Log.e("RecyclerViewActivity","下拉刷新");
mRefreshLayout.refreshComplete();
}
}, 1000);
}
});
}
}
private void initDatas() {
mDatas = new ArrayList<>();
for (int i = 0; i < 20; i++) {
mDatas.add("" + i);
}
}
}
布局文件:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<com.leelay.freshlayout.verticalre.VRefreshLayout
android:id="@id/refresh_layout"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerview"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@android:color/white"
>
</android.support.v7.widget.RecyclerView>
</com.leelay.freshlayout.verticalre.VRefreshLayout>
</LinearLayout>
适配器:
public class FullDelDemoAdapter extends RecyclerView.Adapter<FullDelDemoAdapter.FullDelDemoVH> {
private Context mContext;
private LayoutInflater mInfalter;
private List<String> mDatas;
public FullDelDemoAdapter(Context context, List<String> mDatas) {
mContext = context;
mInfalter = LayoutInflater.from(context);
this.mDatas = mDatas;
}
@Override
public FullDelDemoVH onCreateViewHolder(ViewGroup parent, int viewType) {
return new FullDelDemoVH(mInfalter.inflate(R.layout.recyclerview_adapter, parent, false));
}
@Override
public void onBindViewHolder(final FullDelDemoVH holder, final int position) {
// ((SwipeMenuLayout) holder.itemView).setIos(false).setLeftSwipe(position % 2 == 0 ? true : false);//这句话关掉IOS阻塞式交互效果 并依次打开左滑右滑
// holder.content.setText(mDatas.get(position) + (position % 2 == 0 ? "我右白虎" : "我左青龙"));
holder.content.setText(mDatas.get(position));
//验证长按
holder.content.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View v) {
Toast.makeText(mContext, "longclig", Toast.LENGTH_SHORT).show();
Log.d("TAG", "onLongClick() called with: v = [" + v + "]");
return false;
}
});
// holder.btnUnRead.setVisibility(position % 3 == 0 ? View.GONE : View.VISIBLE);
holder.btnDelete.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (null != mOnSwipeListener) {
//如果删除时,不使用mAdapter.notifyItemRemoved(pos),则删除没有动画效果,
//且如果想让侧滑菜单同时关闭,需要同时调用 ((CstSwipeDelMenu) holder.itemView).quickClose();
//((CstSwipeDelMenu) holder.itemView).quickClose();
mOnSwipeListener.onDel(holder.getAdapterPosition());
}
}
});
//注意事项,设置item点击,不能对整个holder.itemView设置咯,只能对第一个子View,即原来的content设置,这算是局限性吧。
(holder.content).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(mContext, "onClick:" + mDatas.get(holder.getAdapterPosition()), Toast.LENGTH_SHORT).show();
Log.d("TAG", "onClick() called with: v = [" + v + "]");
}
});
//置顶:
holder.btnTop.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (null!=mOnSwipeListener){
mOnSwipeListener.onTop(holder.getAdapterPosition());
}
}
});
}
@Override
public int getItemCount() {
return null != mDatas ? mDatas.size() : 0;
}
/**
* 和Activity通信的接口
*/
public interface onSwipeListener {
void onDel(int pos);
void onTop(int pos);
}
private onSwipeListener mOnSwipeListener;
public onSwipeListener getOnDelListener() {
return mOnSwipeListener;
}
public void setOnDelListener(onSwipeListener mOnDelListener) {
this.mOnSwipeListener = mOnDelListener;
}
class FullDelDemoVH extends RecyclerView.ViewHolder {
TextView content;
Button btnDelete;
Button btnUnRead;
Button btnTop;
public FullDelDemoVH(View itemView) {
super(itemView);
content = (TextView) itemView.findViewById(R.id.content);
btnDelete = (Button) itemView.findViewById(R.id.btnDelete);
btnUnRead = (Button) itemView.findViewById(R.id.btnUnRead);
btnTop = (Button) itemView.findViewById(R.id.btnTop);
}
}
}
适配器布局文件:
<?xml version="1.0" encoding="utf-8"?>
<com.mcxtzhang.swipemenulib.SwipeMenuLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="100dp"
app:ios="false"
app:leftSwipe="true"
app:swipeEnable="true"
android:clickable="true"
android:paddingBottom="1dp">
<TextView
android:id="@+id/content"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="?android:attr/selectableItemBackground"
android:gravity="center"
android:text="项目中我是任意复杂的原ContentItem布局"/>
<!-- 以下都是侧滑菜单的内容依序排列 -->
<Button
android:id="@+id/btnTop"
android:layout_width="60dp"
android:layout_height="match_parent"
android:background="#d9dee4"
android:visibility="gone"
android:text="置顶"
android:textColor="@android:color/white"/>
<Button
android:id="@+id/btnUnRead"
android:layout_width="120dp"
android:layout_height="match_parent"
android:background="#ecd50a"
android:clickable="true"
android:visibility="gone"
android:text="标记未读"
android:textColor="@android:color/white"/>
<Button
android:id="@+id/btnDelete"
android:layout_width="60dp"
android:layout_height="match_parent"
android:background="#ff4a57"
android:text="删除"
android:textColor="@android:color/white"/>
</com.mcxtzhang.swipemenulib.SwipeMenuLayout>
这个开源控件摘自网络
里面的刷新想看源码请移步http://download.csdn.net/detail/pengyu1801/9872136