# ASwipeLayout **Repository Path**: WelliJohn/ASwipeLayout ## Basic Information - **Project Name**: ASwipeLayout - **Description**: 一个万能的侧滑控件,解决了各种手势冲突 - **Primary Language**: Android - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 30 - **Forks**: 2 - **Created**: 2018-04-22 - **Last Updated**: 2025-01-27 ## Categories & Tags **Categories**: android-modules **Tags**: None ## README # ASwipeLayout Android侧滑菜单库 ## APK下载地址 ![ASwipeLayout](https://github.com/WelliJohn/ASwipeLayout/blob/master/images/QRCode_336.png?raw=true) ## 前言 该控件的优点: - 1.无论是在RecyclerView,ListView,还是LinearLayout等,只要是ViewGroup用该控件都能实现侧滑。 - 2.控件的手势滑动冲突已解决,不会出现嵌套到ScrollView等控件出现滑动不流畅的情况 - 3.控件使用简单,只需要在xml外套一层该控件就好了,秒接入 - 4.点击事件很方便,原来什么写法就什么写法 ## 1.效果图 ![single](https://github.com/WelliJohn/ASwipeLayout/blob/master/images/single_row.gif?raw=true) ![single](https://github.com/WelliJohn/ASwipeLayout/blob/master/images/two_rows.gif?raw=true) ## 2.使用方式其实挺简单的,在设计的时候,就是想着怎么简单怎么来。 引入库: ``` Step 1. Add it in your root build.gradle at the end of repositories: allprojects { repositories { ... maven { url 'https://jitpack.io' } } } Step 2. Add the dependency dependencies { implementation 'com.github.WelliJohn:ASwipeLayout:0.0.2' } ``` 在需要侧滑的布局的根布局中添加下面这段代码,注意注释的地方才是可以定制的: ``` //在这里是实现你的主item的东西,根据你们的项目随便添加 //在这里是实现右侧的菜单,根据你们的项目随便添加 ``` 注意在这里ll_content,right_menu_content是一定要的,这个id对应的布局不要自己去改变,以后有需要会放开,一般的情况只需要定制主item的内容和右侧菜单栏了,在这里我也省去了定义一些额外的自定义view了,单纯就是用id,来区分主item和右侧的菜单。 ## 3.因为RecyclerView中有复用Item的情况,针对这种情况的解决方案 因为item复用会使得当我们滑出某个menu的时候,再进行RecyclerView的上下滑动时,会使得其他的Item也滑出了menu,这就是item复用导致了布局错乱,所以针对这类型的问题的话,我在这里已经提供了OnSwipeStateChangeListener接口,在这里你们可以记录下滑动的状态,在onBindViewHolder方法里面,根据状态来设定Item是打开menu还是关闭menu: ``` @Override public void onBindViewHolder(ViewHolder holder, int position) { final Person person = mDatas.get(position); holder.scrollDelLl.setOpen(person.isOpen()); holder.scrollDelLl.setOnSwipeStateChangeListener(new OnSwipeStateChangeListener() { @Override public void onSwipeStateChange(boolean open) { person.setOpen(open); } }); } ``` 如上代码就可以解决Item复用导致布局错乱的问题了(粑粑再也不用担心RecyclerView复用的问题了)。