您好,登錄后才能下訂單哦!
本篇文章為大家展示了在android項目中使用LinearLayoutManager實現一個一鍵返回頂部功能,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
效果圖
要實現這種效果,有兩點需要實現:
1、控制LanyoutManager滑動距離,根據滑動狀態(距離)改變去設置隱藏或者顯示。
2、設置top的點擊事件,點擊回到頂部。
很遺憾LayoutManager只提供給了我們獲取第一個可見item的高度的方法,而這里我們需要獲取的是從開始到現在滑動的總距離,所以不得不動手去自己寫,網上也有很多方法,試了一通還是這個比較好用。
建議如果對RecyclerView還不是太熟悉的可以試試他的一些獲取高度的方法,像getChildAt()、getHeight(),來看一下效果,關于index,可以通過findFirstVisibleItemPosition();獲取,剛開始很天真的以為官方會提供有方法,然而進方法源碼去看并沒有,如果各位同行有更好的方法歡迎留言。
public int getScollYDistance() { int position = layoutManager.findFirstVisibleItemPosition(); View firstVisiableChildView = layoutManager.findViewByPosition(position); int firstVisiableChildViewTop = firstVisiableChildView.getTop(); int itemHeight = firstVisiableChildView.getHeight(); //可見的item的index*item高度-最頂端位置 return (position) * itemHeight - firstVisiableChildViewTop; }
獲取高度之后
我們需要獲取高度,設置效果
可以diy各種效果,常見的效果比如支付寶開始滑動的時候,title會漸變最后慢慢隱藏換成其他功能。都在這個方法里實現
如果只需要我們做返回頂部的效果,那么直接在這里設置距離就行了,這個距離就是滑動的總距離,當滑動距離超過400的時候設置按鈕可見,小于400的時候隱藏掉。
public void selectItem() { //彈出top返回頂部按鈕 if (getScollYDistance()>=400){ backTop.setVisibility(View.VISIBLE); }else { backTop.setVisibility(View.GONE); } }
當然這只是最簡單的樣式,要復雜的一點的話可以這樣:
在滑動中改變效果,或者設置漸變效果
if (getScollYDistance() <= 0) { float scale = (float) getScollYDistance() / 400; float alpha = (255 * scale); // 只是layout背景透明(仿知乎滑動效果) tvTitle.setBackgroundColor(Color.argb((int) alpha, 254, 184, 6)); } else { // tvTitle.setBackgroundColor(Color.argb((int) 0, 254, 184, 6)); tvTitle.setVisibility(View.GONE); }
等等,自己想要什么樣的效果,在這里面設置就行。
然后只需要我們在滑動事件中添加效果。
@Override public void onScrolled(RecyclerView recyclerView, int dx, int dy) { super.onScrolled(recyclerView, dx, dy); selectItem(); }
最后不要忘了設置返回按鈕的監聽事件
只一行代碼scrollToPosition(0);每次點擊讓其返回初始位置即可完成一鍵返回到頂部的操作。
backTop.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { recyclerView.scrollToPosition(0); } });
附上xml:
<RelativeLayout android:id="@+id/view_relat" android:layout_width="match_parent" android:layout_height="match_parent"> <android.support.v4.widget.SwipeRefreshLayout android:id="@+id/swipeRefreshLayout" android:layout_width="match_parent" android:layout_height="match_parent"> <android.support.v7.widget.RecyclerView android:id="@+id/recyclerView" android:dividerHeight="2dp" android:layout_width="match_parent" android:layout_height="match_parent"/> </android.support.v4.widget.SwipeRefreshLayout> <RelativeLayout android:layout_width="80dp" android:layout_height="80dp" android:layout_alignParentBottom="true" android:layout_alignParentEnd="true"> <ImageView android:id="@+id/back_top" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/back_top_icon" android:visibility="gone"/> </RelativeLayout> </RelativeLayout>
上述內容就是在android項目中使用LinearLayoutManager實現一個一鍵返回頂部功能,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。