php短視頻源碼之瀑布流分割線左右間距問題及解決代碼
下面展示一下非瀑布流的item布局情況,每個item的高度都是一樣的,所以
他的index就是左右左右,position所對應(yīng)的itemView就是準(zhǔn)確的,
左0,右1,左2,右3,以此類推…
這時候我們可以用下面代碼即可成功設(shè)置分割線。
/** * 第一列設(shè)置左邊距為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是根據(jù)列的高度哪個小而來加載下一個position在哪里,
上面瀑布流圖我們可以看到,左0,右1 之后,2到右邊了,那是因為
第二列的高度小于第一列的高度,所以就加載到第二列,以此類推,
下面的高度可以說就是隨機(jī)展示的,誰也不知道接下來要怎么判斷分割線,
所以用上面的那些代碼是行不通的,
大招來了,我們可以通過StaggeredGridLayoutManager.LayoutParams
里的getSpanIndex()來判斷,這個方法不管你高度怎樣,
他都是左右左右開始排列的,如下代碼。
StaggeredGridLayoutManager.LayoutParams params = (StaggeredGridLayoutManager.LayoutParams) view.getLayoutParams(); /** * 根據(jù)params.getSpanIndex()來判斷左右邊確定分割線 * 第一列設(shè)置左邊距為space,右邊距為space/2 (第二列反之) */ if (params.getSpanIndex() % 2 == 0) { outRect.left = space; outRect.right = space / 2; } else { outRect.left = space / 2; outRect.right = space; }
到此這篇關(guān)于php短視頻源碼之瀑布流分割線左右間距問題及解決代碼的文章就介紹到這了,更多相關(guān)php短視頻源碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
版權(quán)聲明:
本站所有文章和圖片均來自用戶分享和網(wǎng)絡(luò)收集,文章和圖片版權(quán)歸原作者及原出處所有,僅供學(xué)習(xí)與參考,請勿用于商業(yè)用途,如果損害了您的權(quán)利,請聯(lián)系網(wǎng)站客服處理。