• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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短视频源码内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • PHP+Jquery与ajax相结合实现下拉淡出瀑布流效果【无需插件】
    • PHP结合Jquery和ajax实现瀑布流特效
    • thinkPHP实现瀑布流的方法
    上一篇:php中日期类型转换实例讲解
    下一篇:关于PHP5和PHP7中数组实现方式的比较总结
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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