php短视频源码之瀑布流分割线左右间距问题及解决代码

admin3年前PHP教程86

下面展示一下非瀑布流的item布局情况,每个item的高度都是一样的,所以
他的index就是左右左右,position所对应的itemView就是准确的,
左0,右1,左2,右3,以此类推…
这时候我们可以用下面代码即可成功设置分割线。

2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
/**
 
* 第一列设置左边距为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()来判断,这个方法不管你高度怎样,
他都是左右左右开始排列的,如下代码。

2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
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短视频源码内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

GPU服务器和普通服务器区别租用美国显卡服务器有什么优势

GPU服务器又被称为显卡服务器,是基于GPU的应用于视频编解码、深度学习、科学计算等多种场景的快速、稳定、弹性的计算服务。GPU加速计算可以提供非凡的应用程序性能,能将应用程序计算密集部分的工作负载转...

GPU服务器的用处有什么?租用江西GPU服务器如何使用?

GPU服务器是基于GPU功能的视频编解码、深度学习、科学计算等多种场景的快速、稳定、弹性的计算服务,提供和标准云服务器一致的管理方式。出色的图形处理能力和高性能计算能力提供极致计算性能,有效解放计算压...

网络安全威胁手段有哪些?美国电信高防服务器适合哪些行业购买?

网络安全是一种保护计算机、服务器、移动设备、电子系统、网络和数据免受恶意攻击的技术,这种技术也称为信息技术安全或电子信息安全。该术语适用于从业务到移动计算的各种环境,可以分为几个常见类别。应用程序安全...

php头编码实例设置方法及代码

在PHP中可以通过在PHP文件头部添加“header("Content-type: text/html; charset=utf-8");”语句来设置编码。...

香港大带宽服务器连接失败怎么处理

香港大带宽服务器连接失败怎么处理?如果您无法连接到香港大带宽服务器,则可能需要采取以下步骤:检查网络连接:确保您的本地计算机和香港大带宽服务器之间有可用的网络连接。您可以尝试使用ping命令测试服务器...

显卡服务器一般是用来做什么香港显卡服务器适合哪些行业购买

服务器是计算机的一种,它比普通计算机运行更快、负载更高、价格更贵。服务器在网络中为其它客户机(如PC机、智能手机、ATM等终端甚至是火车系统等大型设备)提供计算或者应用服务。服务器具有高速的CPU运算...