前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >RecyclerView的左滑实现

RecyclerView的左滑实现

作者头像
非著名程序员
发布2018-02-09 11:18:38
1.7K0
发布2018-02-09 11:18:38
举报
文章被收录于专栏:非著名程序员非著名程序员

最终的效果图是这样的

要实现这样的一个效果,用到的关键技术: 自定义view的基本知识+事件处理+其它知识

一.右边的操作view

1.数据的组装

我们可以把右边的操作选项抽象出来数据对象即可,对于老司机的你们一看就懂。

1.SwipeMenuView的简单扩展(自定义view的一种吧)

说白了就是继承LinearLayout 加了一个回调接口,对于老司机的你们一看又懂了。对于SwipeMenuLayout是什么,我们后面会讲的,别着急吗?嘻嘻

二.RecyclerView.Adapter的处理

  • 我们本着在不影响用户原有的adapter的基础上尽量不改或者少改。 对于RecyclerView的Adapter 我们都是继承RecyclerView.Adapter。
  • 主要是重写onCreateViewHolder和onBindViewHolder方法。
  • 对于onBindViewHolder方法完美不错任何处理,也没有必要做。
  • 主要是onCreateViewHolder方法,这个方法返回是一条item的布局ui,对于我们这个效果在不改动优惠正常的view布局的情况下,我们可以这么做呢????
  • 咦! 我们可以在原来的基础上再套一层FrameLayout. 是的,没错,老司机!!

SwapWrapperUtils.wrap 这个方法这里就不说了就是LayoutInflater加载布局。

三.SwipeMenuLayout-view的设计

继承自FrameLayout

讲用户的itemview这里我们叫Contentview,以及操作view我们叫MenuView,添加到这个FrameLayout上

设置初始状态

我们要测量menuview的宽,高度就是Contentview的高。 我们要布局menuview,在Contentview的右侧。 如图:

控制滑动

在android中根据滑动来控制view有好多种,这里我们用layout方法 主要就是在recycleview滑动时找到其中一条的位置position在ontouch方法中合适的时机将事件传到该view上。什么时候触发这个方法呢 ,下文会说recycleview的处理事件。

我们写一个方法将事件传递到此view上来控制menuView和contentView

打开与关闭

借助computeScroll方法来不停的layout设置位置,代码都对于位置的计算有注释,生怕解释不清楚。

三.RecyclerView的时间处理

首先我们要明白一点就是:我们要影响用户原来的item的点击与长按等事件。

我们肯定要重新事件的拦截与处理方法。即onInterceptTouchEvent 与onTouchEvent方法。我们需要在这2个方法里做如下的处理。

  1. 找到按下去的那一条
  2. 什么时候拦截各种down,move,up事件
  3. 处理各种down,move,up事件
找到按下去的那一条

找到了pos位置就可以 View view = getChildAt(mTouchPosition - mFirstPosition);

来获取那个view了,就可以进行事件的处理了。 child.getHitRect方法 ,我们看下sdkapi的注释:

onInterceptTouchEvent 拦截 onTouch的处理 的搞基生活

down拦截的时候:

  1. menuView处于打开且点击的不在menu区域
  2. 达到了滑动的临界值 这写情况都要交要我们处理,交给ontouch方法

然后在onTouchEven方法里处理down:

move拦截的时候:

达到滑动的临界值就可以拦截了return true了。

mTouchSlop = ViewConfiguration.get(getContext()).getScaledTouchSlop();

然后在onTouchEven方法里处理move:如果是左右我们才处理,否则拜拜了您。

最后up事件就简单了不需要拦截,无非就是TOUCH_STATE_X状态交给我们之前的SwipeMenuLayout处理打开还是关闭,以及一些变量的初始化。

到此整个实现就完了。

这里只分析一些核心的关键技术,其它的都能看懂。

代码下载地址:

https://github.com/ta893115871/SwapMenuRecyclerView

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2016-07-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 非著名程序员 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一.右边的操作view
    • 1.数据的组装
    • 二.RecyclerView.Adapter的处理
    • 三.SwipeMenuLayout-view的设计
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档