一个吸顶Item的简单实现方法分享

 更新时间:2019年09月07日 14:12:05   作者:susion  
这篇文章主要给大家介绍了一个吸顶Item的简单实现方法,文中通过示例代码介绍的非常详细,对各位Android开发者们具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧


一般的对于上图样式的Sticker我们使用CoordinatorLayout & AppBarLayout就可以说实现。

但是对于下面这种呢?

我的实现思路

首先整个页面的UI结构是通过RecyclerView实现的。

对于上面这个Sticker的实现是在布局的最上方添加了一个和RecyclerView中要吸顶的Item一模一样的布局。然后监听RecyclerView的滚动:

mPostDetailRv.addOnScrollListener(object : RecyclerView.OnScrollListener() {
 override fun onScrolled(recyclerView: RecyclerView, dx: Int, dy: Int) {
  if (pageStatus == null || pageStatus.stickerPos == -1) return

  val preHolder = recyclerView.findViewHolderForAdapterPosition(pageStatus!!.stickerPos - 1)
  val targetHolder = recyclerView.findViewHolderForAdapterPosition(pageStatus!!.stickerPos)

  var offset = if (targetHolder != null) { //滚出去了
   -targetHolder.itemView.top
  }else{
   0
  }

  if (preHolder != null) {
   offset = -1 
  }

  if (offset < 0) {
   mPostDetailCommentHeaderSticker.visibility = View.GONE
  } else {
   mPostDetailCommentHeaderSticker.visibility = View.VISIBLE
  }
 }
}

上面pageStatus.stickerPos是Sticker在RecyclerView中的数据的位置。上面的逻辑写的其实比较复杂,不过确实实现了需求(-_-), 我解释一下:

即我判断Sticker是否出现依赖于itemView.top和Sticker的前一个itemview:

  1. 如果当前的Sticker的 itemview显示在RecyclerView中,则根据它itemView.top来判断它是否滚动到了顶部
  2. 如果它的前一个itemview已经不在RecyclerView中了(被回收了),那说明它肯定滚出去了,这时直接显示

上面的逻辑很奇怪,不过确实实现了吸顶的需求。

不过在后面的需求迭代中Sticker ItemView的前一个ItemView会不断变化,于是上面这段代码就出现了bug。。。。 那怎么解决呢?

更简单通用的方法

最后灵机一动,对于StickerItemView的显示我完全可以不依赖于前面这个ItemView:

mPostDetailRv.addOnScrollListener(object : RecyclerView.OnScrollListener() {
 override fun onScrolled(recyclerView: RecyclerView, dx: Int, dy: Int) {
  val currentDataPos = recyclerView.getChildAdapterPosition(recyclerView.getChildAt(0))

  if (pageStatus != null && currentDataPos < pageStatus.stickerPos) {
   mPostDetailCommentHeaderSticker.visibility = View.GONE
  } else {
   mPostDetailCommentHeaderSticker.visibility = View.VISIBLE
  }
 }
})

上面这段代码很轻松的修复了bug。并且它的逻辑很简单,也很通用:

判断当前RecyclerView显示的第一个条目的位置是否大于StickerItem的位置,如果大于就展示吸顶Sticker

效果:

上面这种实现仅适用UI结构是RecyclerView的情况

PASS : 如果你就是这么做的,请无视我(-_-)

更多小分享 : AdvancedAndroid

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。

相关文章

  • Android 对话框sweet-alert-dialog

    Android 对话框sweet-alert-dialog

    这篇文章主要介绍了Android 对话框sweet-alert-dialog的相关资料,需要的朋友可以参考下
    2016-09-09
  • Flutter实现自定义搜索框AppBar的示例代码

    Flutter实现自定义搜索框AppBar的示例代码

    开发中,页面头部为搜索样式的设计非常常见,为了可以像系统AppBar那样使用,本文将利用Flutter自定义一个搜索框,感兴趣的可以了解一下
    2022-04-04
  • 解决Android Studio突然不显示logcat日志的问题

    解决Android Studio突然不显示logcat日志的问题

    这篇文章主要介绍了解决Android Studio突然不显示logcat日志的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-04-04
  • Android实现秒表功能

    Android实现秒表功能

    这篇文章主要为大家详细介绍了Android实现简易秒表功能,具备启停功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-09-09
  • Android Bugreport实现原理深入分析

    Android Bugreport实现原理深入分析

    这篇文章主要介绍了Android Bugreport实现原理,Bugreport主要用于分析手机的状态,在应用开发中,程序的调试分析是日常生产中进程会进行的工作,Bugreport就是很常用的工具,需要的朋友可以参考下
    2024-05-05
  • Android应用中使用及实现系统“分享”接口实例

    Android应用中使用及实现系统“分享”接口实例

    为了应用的推广、传播,很多的应用中都有“分享”功能,这篇文章主要介绍了Android应用中使用及实现系统“分享”接口实例,有兴趣的可以了解一下。
    2016-12-12
  • Android实现动态体温计

    Android实现动态体温计

    这篇文章主要为大家详细介绍了Android实现动态体温计,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-06-06
  • Android studio实现左右滑动切换图片

    Android studio实现左右滑动切换图片

    这篇文章主要为大家详细介绍了Android studio实现左右滑动切换图片,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • Android证书安装过程介绍

    Android证书安装过程介绍

    大家好,本篇文章主要讲的是Android证书安装过程介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12
  • Android实现同频共帧动画效果

    Android实现同频共帧动画效果

    我们听过“同频共振”,其原理是多个物体物体以同样的频率振动,但是本篇实现的效果是“同频共帧”,含义是:动画以同样的频率和同样的帧展示在多个不同View上,文中通过代码示例介绍的非常详细,感兴趣的同学可以自己动手尝试一下
    2024-01-01

最新评论