Android RecycleView 实现左滑上下分层示例代码(自定义功能)
由于项目原因,需要在很多地方需要左划删除,并在后期会在item中不定增加功能。网上很多左划删除的demo,但大多封装的不太彻底,所以就试着自己进行封装。
独立上下两层互补干扰,满足不同item的左划
底部功能项不定如(删除、收藏)
截图
独立Adapter的操作方式
思路: public RCommonSlideAdapter(Object object, List datas, int layoutId, Class clazz, SlideItemHolder handle) {
在onCreateViewHolder中通过反射创建holder,保证数据的操作通过回调函数,交给activity处理
Constructor constructor2 = mClazz.getConstructor(View.class); holder = constructor2.newInstance(v);
上下分层
思路:创建底部xml布局,再通过addView插入顶部view,并交由activity处理,底部布局处理放在adapter中处理。
Constructor constructor = ViewHolderClass.SlideViewHolder.class.getConstructor(View.class); holder = constructor.newInstance(v); View contentView = View.inflate(parent.getContext(), mLayoutId, null); ViewGroup.LayoutParams params = new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup .LayoutParams.WRAP_CONTENT); ((ViewHolderClass.SlideViewHolder) holder).mRlSlidContent.addView(contentView, params); Constructor constructor2 = mClazz.getConstructor(View.class); holder = constructor2.newInstance(v); ((ViewHolderClass.SlideViewHolder) holder).mRlSlidContent.getLayoutParams().width = getScreenWidth(parent.getContext());
独立功能项
思路:在xml布局中,不断增加item。并再回调函数中,对每个按钮选择性处理,并可动态添加
<LinearLayout android:id="@+id/linDelete" android:layout_width="100dp" android:layout_height="wrap_content" android:layout_alignParentRight="true" android:layout_centerVertical="true" android:layout_toRightOf="@+id/rlSlidContent" android:orientation="vertical" > <ImageView android:id="@+id/sliding_delete" android:layout_width="30dp" android:layout_height="30dp" android:layout_gravity="center_horizontal" android:src="@drawable/icon_item_delete" /> </LinearLayout>
public class ViewHolderClass { public static class SlideViewHolder extends RecyclerView.ViewHolder { @BindView(R.id.sliding_delete) public ImageView btn_Delete; @BindView(R.id.rlSlidContent) public RelativeLayout mRlSlidContent; @BindView(R.id.linSlideTitle) public LinearLayout mLinSlideTitle; @BindView(R.id.tvSlideTitle) public TextView mTvSlideTitle; public SlideViewHolder(View view) { super(view); ButterKnife.bind(this, view); } } public static class ShopCarViewHolder extends SlideViewHolder { @BindView(R.id.itemTv) public TextView mItemTv; public ShopCarViewHolder(View view) { super(view); } } }
代码如下:RecycleSlideDemo_jb51.rar
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
Android实现跟随手指拖动并自动贴边的View样式(实例demo)
本文通过实例代码给大家介绍了android实现跟随手指拖动并自动贴边的View样式,效果非常棒,具有参考借鉴价值,需要的朋友参考下吧2017-01-01android studio 项目 :UI设计高精度实现简单计算器
这篇文章主要介绍了android studio 项目 :UI设计高精度实现简单计算器,自主完成一个简单APP的设计工作,综合应用已经学到的Android UI设计技巧,下面来看看实验实现过程2021-12-12Android中TabLayout+ViewPager实现tab和页面联动效果
本篇文章主要介绍了Android中TabLayout+ViewPager实现tab和页面联动效果,具有一定的参考价值,有兴趣的可以了解一下2017-06-06
最新评论