一行程式碼搞定使用LinearLayoutManager一鍵返回頂部
之前在學習RecyclerView的時候,建立了一個可以滑動的View列表,但是當滑動距離過長的時候,需要手動返回到頂部,於是加了一個一鍵返回頂部的按鈕。
效果圖
要實現這種效果,有兩點需要實現:
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:class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="@drawable/back_top_icon" android:visibility="gone"/> </RelativeLayout> </RelativeLayout>
作者:八怪不姓醜
連結:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/4479/viewspace-2818183/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Shell 一行程式碼搞定大問題行程
- 網站返回頂部jquery js實現程式碼方式案例網站jQueryJS
- 返回頂部寫法
- Java 三目運算 if else 一行程式碼搞定Java行程
- 簡單版—返回頂部
- JavaScript返回頂部詳解JavaScript
- js之返回網頁頂部JS網頁
- js選項卡不會寫?JQuery一行程式碼搞定!JSjQuery行程
- 一行程式碼解決UITableView鍵盤收起行程UIView
- mac中使用妙控鍵盤頂部的功能鍵Mac
- 【PowerQuery】如何一行程式碼搞定,做了一萬遍的工資條行程
- 巧用自定義註解,一行程式碼搞定審計日誌行程
- 初識sa-token,一行程式碼搞定登入授權!行程
- div有滾動條 返回頂部
- 網站返回頂部功能視訊網站
- 神操作!一行程式碼搞定一款遊戲?厲害了程式設計師!行程遊戲程式設計師
- js返回頁面頂部的實現(layui)JSUI
- [前端外掛] js返回頂部 效果實現前端JS
- 無需一行程式碼就能搞定機器學習的開源神器——手把手教你配置使用行程機器學習
- 一行程式碼建立cell行程
- 一行 CSS 程式碼的魅力CSS
- [外掛擴充套件]返回頂部ReturnTop外掛套件
- pycharm誤刪一行怎麼返回?PyCharm
- 一行命令搞定windows檢視埠占用Windows
- 一行程式碼如何隱藏Linux程式?行程Linux
- 一行程式碼讓你的專案輕鬆使用Dapr行程
- 無需安裝、註冊,一行命令搞定內網穿透!關鍵是完全免費內網穿透
- 第一行程式碼——書的理解行程
- 一行 Python 程式碼實現並行Python並行
- 一行程式碼實現微前端行程前端
- js使用waterfall橫向載入瀑布流,一行程式碼完成JS行程
- vue js 獲取滾動距離 以及 返回頂部按鈕VueJS
- mui裡點選input框是為什麼會返回頂部UI
- RecyclerView的LinearLayoutManager分析View
- 一行命令搭建內部的管道
- 一行程式碼引發的恐懼行程
- 一行程式碼實現ViewPager卡片效果行程Viewpager
- Flutter之一行程式碼 全灰致敬Flutter行程