android中LinearLayoutManager一鍵返回頂部示例
之前在學(xué)習(xí)RecyclerView的時(shí)候,建立了一個(gè)可以滑動(dòng)的View列表,但是當(dāng)滑動(dòng)距離過長(zhǎng)的時(shí)候,需要手動(dòng)返回到頂部,于是加了一個(gè)一鍵返回頂部的按鈕。
效果圖
要實(shí)現(xiàn)這種效果,有兩點(diǎn)需要實(shí)現(xiàn):
1、控制LanyoutManager滑動(dòng)距離,根據(jù)滑動(dòng)狀態(tài)(距離)改變?nèi)ピO(shè)置隱藏或者顯示。
2、設(shè)置top的點(diǎn)擊事件,點(diǎn)擊回到頂部。
很遺憾LayoutManager只提供給了我們獲取第一個(gè)可見item的高度的方法,而這里我們需要獲取的是從開始到現(xiàn)在滑動(dòng)的總距離,所以不得不動(dòng)手去自己寫,網(wǎng)上也有很多方法,試了一通還是這個(gè)比較好用。
建議如果對(duì)RecyclerView還不是太熟悉的可以試試他的一些獲取高度的方法,像getChildAt()、getHeight(),來看一下效果,關(guān)于index,可以通過findFirstVisibleItemPosition();獲取,剛開始很天真的以為官方會(huì)提供有方法,然而進(jìn)方法源碼去看并沒有,如果各位同行有更好的方法歡迎留言。
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; }
獲取高度之后
我們需要獲取高度,設(shè)置效果
可以diy各種效果,常見的效果比如支付寶開始滑動(dòng)的時(shí)候,title會(huì)漸變最后慢慢隱藏?fù)Q成其他功能。都在這個(gè)方法里實(shí)現(xiàn)
如果只需要我們做返回頂部的效果,那么直接在這里設(shè)置距離就行了,這個(gè)距離就是滑動(dòng)的總距離,當(dāng)滑動(dòng)距離超過400的時(shí)候設(shè)置按鈕可見,小于400的時(shí)候隱藏掉。
public void selectItem() { //彈出top返回頂部按鈕 if (getScollYDistance()>=400){ backTop.setVisibility(View.VISIBLE); }else { backTop.setVisibility(View.GONE); } }
當(dāng)然這只是最簡(jiǎn)單的樣式,要復(fù)雜的一點(diǎn)的話可以這樣:
在滑動(dòng)中改變效果,或者設(shè)置漸變效果
if (getScollYDistance() <= 0) { float scale = (float) getScollYDistance() / 400; float alpha = (255 * scale); // 只是layout背景透明(仿知乎滑動(dòng)效果) tvTitle.setBackgroundColor(Color.argb((int) alpha, 254, 184, 6)); } else { // tvTitle.setBackgroundColor(Color.argb((int) 0, 254, 184, 6)); tvTitle.setVisibility(View.GONE); }
等等,自己想要什么樣的效果,在這里面設(shè)置就行。
然后只需要我們?cè)诨瑒?dòng)事件中添加效果。
@Override public void onScrolled(RecyclerView recyclerView, int dx, int dy) { super.onScrolled(recyclerView, dx, dy); selectItem(); }
最后不要忘了設(shè)置返回按鈕的監(jiān)聽事件
只一行代碼scrollToPosition(0);每次點(diǎn)擊讓其返回初始位置即可完成一鍵返回到頂部的操作。
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-CollectionDemo_jb51.rar
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android LinearLayout實(shí)現(xiàn)自動(dòng)換行效果
- Android LinearLayout實(shí)現(xiàn)自動(dòng)換行
- Android自定義LinearLayout布局顯示不完整的解決方法
- Android使用LinearLayout設(shè)置邊框
- Android編程使用LinearLayout和PullRefreshView實(shí)現(xiàn)上下翻頁功能的方法
- Android中的LinearLayout布局
- Android基礎(chǔ)之獲取LinearLayout的寬高
- Android超詳細(xì)講解組件LinearLayout的使用
相關(guān)文章
Android GridView實(shí)現(xiàn)動(dòng)畫效果實(shí)現(xiàn)代碼
這篇文章主要介紹了 Android GridView實(shí)現(xiàn)動(dòng)畫效果實(shí)現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下2017-03-03Android集成騰訊X5實(shí)現(xiàn)文檔瀏覽功能
Android內(nèi)部沒有控件來直接顯示文檔,跳轉(zhuǎn)WPS或其他第三方文檔App體驗(yàn)性不好,使用騰訊X5內(nèi)核能很好的解決的這一問題這篇文章主要介紹了Android集成騰訊X5實(shí)現(xiàn)文檔瀏覽功能,需要的朋友可以參考下2019-10-10使用Java代碼在Android中實(shí)現(xiàn)圖片裁剪功能
這篇文章主要介紹了使用Java代碼在Android中實(shí)現(xiàn)圖片裁剪功能,許多應(yīng)用都需要此類從相冊(cè)中選取圖片然后編輯的功能,需要的朋友可以參考下2015-07-07Android編程中TextView寬度過大導(dǎo)致Drawable無法居中問題解決方法
這篇文章主要介紹了Android編程中TextView寬度過大導(dǎo)致Drawable無法居中問題解決方法,以實(shí)例形式較為詳細(xì)的分析了TextView設(shè)置及xml布局與調(diào)用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10FragmentTabHost FrameLayout實(shí)現(xiàn)底部導(dǎo)航欄
這篇文章主要為大家詳細(xì)介紹了FragmentTabHost和FrameLayout實(shí)現(xiàn)底部導(dǎo)航欄,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03android實(shí)現(xiàn)圖片反轉(zhuǎn)效果
這篇文章主要介紹了android實(shí)現(xiàn)圖片反轉(zhuǎn)效果的方法,需要的朋友可以參考下2015-09-09