概述
之前我們拋出了一個問題就是RecyclerView在顯示列表的時候,最底部也就是最后一個Item后面還有分割線,這大大影響界面的美觀。這篇文章就是解決這個問題的。
自定義分割線
通過分析源碼后我們發(fā)現(xiàn)沒有相關的方法來處理這一需求,所以只能自定義分割線,通過上一篇文章的基礎我們知道肯定是修改getItemOffsets。那我們的思路是讓這個方法在到最后一個條目時,不偏移分割線的間隙。同時也要修改onDraw方法,讓他不再繪制最后一條分割線。
private void drawHorizontal(Canvas c, RecyclerView parent, State state) { int childCount = parent.getChildCount() - 1; int left = 0; int top = parent.getPaddingTop(); int right = 0; int bottom = parent.getHeight() - parent.getPaddingBottom(); for (int i = 0; i < childCount; i++) { View view = parent.getChildAt(i); RecyclerView.LayoutParams params = (LayoutParams) view.getLayoutParams(); //考慮,padding left = view.getRight(); right = left + divider.getIntrinsicHeight(); //我們在自定義drawable的是是,寫死了高度,所以只能用高度 divider.setBounds(left, top, right, bottom); divider.draw(c); }}/** * 思路:就是獲取每個item,計算divider的left,top,right,bottom */private void drawVertical(Canvas c, RecyclerView parent, State state) { int childCount = parent.getChildCount() - 1; int left = parent.getPaddingLeft(); int top = 0; int right = parent.getWidth() - parent.getPaddingRight(); //考慮右邊的padding int bottom = 0; for (int i = 0; i < childCount; i++) { //不繪制最后一個條目的分割線 View view = parent.getChildAt(i); RecyclerView.LayoutParams params = (LayoutParams) view.getLayoutParams(); //考慮,padding top = view.getBottom() + params.topMargin; //就是當前view底部到頂部的距離 bottom = top + divider.getIntrinsicHeight() - params.bottomMargin; //就是top+divider高度 divider.setBounds(left, top, right, bottom); divider.draw(c); }}@Overridepublic void getItemOffsets(Rect outRect, View view, RecyclerView parent, State state) { int childAdapterPosition = parent.getChildAdapterPosition(view); int lastCount = parent.getAdapter().getItemCount() - 1; //如果當前條目與是最后一個條目,就不設置divider padding if (childAdapterPosition == lastCount) { outRect.set(0, 0, 0, 0); return; } Log.d("TAG", childAdapterPosition + "," + lastCount); if (orientation == LinearLayoutCompat.HORIZONTAL) { outRect.set(0, 0, divider.getIntrinsicHeight(), 0); //0,0,30,0,設置寬度 } else { outRect.set(0, 0, 0, divider.getIntrinsicHeight()); //0,0,0,30,設置高度 }}使用這個自定義分割線的效果圖如下:

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網(wǎng)。
新聞熱點
疑難解答
圖片精選