100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > android实现菜单侧滑栏 Android侧滑-RecyclerView轻松实现高效的侧滑菜单

android实现菜单侧滑栏 Android侧滑-RecyclerView轻松实现高效的侧滑菜单

时间:2019-11-30 04:11:22

相关推荐

android实现菜单侧滑栏 Android侧滑-RecyclerView轻松实现高效的侧滑菜单

原标题:Android侧滑-RecyclerView轻松实现高效的侧滑菜单

一 前言

利用系统类ItemTouchHelper实现简单高效的RecyclerView侧滑菜单!

仿qq的侧滑,跟随滑动…

简单的侧滑点击删除,覆盖滑动…

二 知识准备

ItemTouchHelper是Android系统提供的一个帮助类,可以很轻松的用它实现长按拖拽和侧滑删除功能(这里的是侧滑之后直接删除整条Item),下面来看一下使用方法.

ItemTouchHelper.Callback

官方的解释是这样的,这个类是ItemTouchHelper和您的应用程序之间的契约。它允许您控制每个ViewHolder都启用了哪些触摸行为,并且在user执行这些操作时也会接收回调 .通俗来说就是我们可以再这个类里面去控制我们想要的触摸效果,也就是侧滑还是拖拽.然后可以得到动作执行中的回调,和动作执行结束后的回调.

我们需要继承ItemTouchHelper.Callback来实现自己的逻辑.我先大致的介绍一下具体的使用方法,详情还请自行查资料.请看代码:

/**

* 实现自己的逻辑

* Created by WANG on 18/3/14.

*/

publicclassItemTouchHelperCallbackextendsItemTouchHelper.Callback{

//是否支持侧滑

@Override

publicbooleanisItemViewSwipeEnabled(){

returntrue;

}

@Override

publicintgetMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder){

returnmakeMovementFlags( 0, ItemTouchHelper.START);

}

@Override

publicbooleanonMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target){

returnfalse;

}

@Override

publicvoidonSwiped(RecyclerView.ViewHolder viewHolder, intdirection){

}

@Override

publicvoidonChildDraw(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, floatdX, floatdY, intactionState, booleanisCurrentlyActive){

return;

}

@Override

publicvoidclearView(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder){

super.clearView(recyclerView, viewHolder);

}

}

//这里给RecyclerView设置一下就OK拉

ItemTouchHelperCallback touchHelperCallback = newItemTouchHelperCallback();

ItemTouchHelper itemTouchHelper=newItemTouchHelper(touchHelperCallback);

itemTouchHelper.attachToRecyclerView(recyclerView);

下面是我目前发现的系统的ItemTouchHelper的一些弊端和好处:

弊端:

1 当处于滑动状态的时候不下发点击事件.

2 滑动的距离为RecyclerView的宽度,往往就是屏幕的宽度.

3 限制滑动距离之后,无法正常恢复侧滑(让滑动的View复位).

4 当Item手动滑动之后不能自由的自动的恢复侧滑(让滑动的View复位).

5 无法做到特定的Item不让侧滑.

6 总问言之侧滑不流畅.

好处:

1 侧滑布局的样式我们可以随意的更改.

2 滑动的距离可以随意的固定.

3 侧滑恢复的动画我们可以控制.

4 总而言之给了开发者很大的自由.

三 改进版的WItemTouchHelperPlus

新增了一个接口Extension用来获取我们侧滑的距离,需要在获取侧滑控件的地方去实现该接口,因为再ItemTouchHelper里面我们操作的是ViewHolder,所以我们的ViewHiolder是实现它的最好选择了.代码如下:

//接口

publicinterfaceExtension{

floatgetActionWidth();

}

**********************Viewholder***********************

/**

* view.getWidth()获取的是屏幕中可以看到的大小.

*/

publicclassRecViewholderextendsRecyclerView.ViewHolderimplementsExtension{

publicTextView textView;

publicTextView slide;

publicRecViewholder(View itemView){

super(itemView);

textView = itemView.findViewById(R.id.item_text);

slide = itemView.findViewById(R.id.item_slide);

}

@Override

publicfloatgetActionWidth(){

returnslide.getWidth();

}

}

新增了tag.需要在我们滑动的xml布局里面设置一个tag=”slide_flag”,用来标识该布局为侧滑滑动的布局.用例:

//这个标识的布局就是我们能滑动的布局.

android: id= "@+id/item_text"

android:layout_width= "match_parent"

android:layout_height= "50dp"

android:background= "#e1e1e1"

android:gravity= "center"

android:tag= "slide_flag"

android:text= "item"

android:textColor= "#333333"

android:textSize= "16sp"/>

WItemTouchHelperPlus.Callback需要重写getItemSlideType方法返我们侧滑的布局类型,就是文章开始处的跟随GIF和覆盖GIF两种侧滑布局.

@Override

publicString getItemSlideType(){

returntype;

}

再onChildDraw里面做一些处理.

@Override

publicvoidonChildDraw(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, floatdX, floatdY, intactionState, booleanisCurrentlyActive){

if(viewHolder instanceofRecAdapter.RecViewholder) {

RecAdapter.RecViewholder holder = (RecAdapter.RecViewholder) viewHolder;

floatactionWidth = holder.getActionWidth();

if(dX < -actionWidth) {

dX = -actionWidth;

}

holder.slideItem.setTranslationX(dX);

} elseif(viewHolder instanceofRecOtherTypeAdapter.RecViewholder){

RecOtherTypeAdapter.RecViewholder holder = (RecOtherTypeAdapter.RecViewholder) viewHolder;

floatactionWidth = holder.getActionWidth();

if(dX < -actionWidth) {

dX = -actionWidth;

}

holder.textView.setTranslationX(dX);

}

return;

}

然后就是使用我们改进版的WItemTouchHelperPlus.Callback和WItemTouchHelperPlus来实现侧滑.基本使用和系统类别无差异.源码相当多,这里就不再贴出具体可以去Github欢迎start

结束

这里只是大概的介绍了一下定制版WItemTouchHelperPlus和系统类的一些不同,以及定制版的一些用法,希望大家多多指导文章中出现的错误,欢迎大家的反馈,欢迎评论吐槽哦~

责任编辑:

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。