php短视频源码之瀑布流分割线左右间距问题及解决代码
下面展示一下非瀑布流的item布局情况,每个item的高度都是一样的,所以
他的index就是左右左右,position所对应的itemView就是准确的,
左0,右1,左2,右3,以此类推…
这时候我们可以用下面代码即可成功设置分割线。
/** * 第一列设置左边距为space,右边距为space/2 (第二列反之) */ if (parent.getChildLayoutPosition(view) % 2 == 0) { outRect.left = space; outRect.right = space / 2; } else { outRect.left = space / 2; outRect.right = space; }
瀑布流的position是根据列的高度哪个小而来加载下一个position在哪里,
上面瀑布流图我们可以看到,左0,右1 之后,2到右边了,那是因为
第二列的高度小于第一列的高度,所以就加载到第二列,以此类推,
下面的高度可以说就是随机展示的,谁也不知道接下来要怎么判断分割线,
所以用上面的那些代码是行不通的,
大招来了,我们可以通过StaggeredGridLayoutManager.LayoutParams
里的getSpanIndex()来判断,这个方法不管你高度怎样,
他都是左右左右开始排列的,如下代码。
StaggeredGridLayoutManager.LayoutParams params = (StaggeredGridLayoutManager.LayoutParams) view.getLayoutParams(); /** * 根据params.getSpanIndex()来判断左右边确定分割线 * 第一列设置左边距为space,右边距为space/2 (第二列反之) */ if (params.getSpanIndex() % 2 == 0) { outRect.left = space; outRect.right = space / 2; } else { outRect.left = space / 2; outRect.right = space; }
到此这篇关于php短视频源码之瀑布流分割线左右间距问题及解决代码的文章就介绍到这了,更多相关php短视频源码内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
discuz 首页四格:最新话题+最新回复+热门话题+精华文章插件
discuz 首页四格:最新话题+最新回复+热门话题+精华文章插件...2007-08-08Zend Framework实现留言本分页功能(附demo源码下载)
这篇文章主要介绍了Zend Framework实现留言本分页功能,详细分析了Zend Framework实现留言本所涉及的控制器动作,分页样式及模板调用技巧,并附代码demo源码供读者下载参考,需要的朋友可以参考下2016-03-03ThinkPHP5+UEditor图片上传到阿里云对象存储OSS功能示例
这篇文章主要介绍了ThinkPHP5+UEditor图片上传到阿里云对象存储OSS功能,结合实例形式分析了ThinkPHP5使用富文本编辑器UEditor实现图片上传到阿里云的相关操作技巧,需要的朋友可以参考下2019-08-08解决Laravel 使用insert插入数据,字段created_at为0000的问题
今天小编就为大家分享一篇解决Laravel 使用insert插入数据,字段created_at为0000的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2019-10-10
最新评论