溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

在android項(xiàng)目中使用LinearLayoutManager實(shí)現(xiàn)一個(gè)一鍵返回頂部功能

發(fā)布時(shí)間:2020-11-23 16:53:26 來(lái)源:億速云 閱讀:146 作者:Leah 欄目:移動(dòng)開(kāi)發(fā)

本篇文章為大家展示了在android項(xiàng)目中使用LinearLayoutManager實(shí)現(xiàn)一個(gè)一鍵返回頂部功能,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

效果圖

在android項(xiàng)目中使用LinearLayoutManager實(shí)現(xiàn)一個(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è)可見(jiàn)item的高度的方法,而這里我們需要獲取的是從開(kāi)始到現(xiàn)在滑動(dòng)的總距離,所以不得不動(dòng)手去自己寫,網(wǎng)上也有很多方法,試了一通還是這個(gè)比較好用。

建議如果對(duì)RecyclerView還不是太熟悉的可以試試他的一些獲取高度的方法,像getChildAt()、getHeight(),來(lái)看一下效果,關(guān)于index,可以通過(guò)findFirstVisibleItemPosition();獲取,剛開(kāi)始很天真的以為官方會(huì)提供有方法,然而進(jìn)方法源碼去看并沒(méi)有,如果各位同行有更好的方法歡迎留言。

 public int getScollYDistance() {
  int position = layoutManager.findFirstVisibleItemPosition();
  View firstVisiableChildView = layoutManager.findViewByPosition(position);
  int firstVisiableChildViewTop = firstVisiableChildView.getTop();
  int itemHeight = firstVisiableChildView.getHeight();
  //可見(jiàn)的item的index*item高度-最頂端位置
  return (position) * itemHeight - firstVisiableChildViewTop;
 }

獲取高度之后

我們需要獲取高度,設(shè)置效果

可以diy各種效果,常見(jiàn)的效果比如支付寶開(kāi)始滑動(dòng)的時(shí)候,title會(huì)漸變最后慢慢隱藏?fù)Q成其他功能。都在這個(gè)方法里實(shí)現(xiàn)

如果只需要我們做返回頂部的效果,那么直接在這里設(shè)置距離就行了,這個(gè)距離就是滑動(dòng)的總距離,當(dāng)滑動(dòng)距離超過(guò)400的時(shí)候設(shè)置按鈕可見(jiàn),小于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)聽(tīng)事件

只一行代碼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>

上述內(nèi)容就是在android項(xiàng)目中使用LinearLayoutManager實(shí)現(xiàn)一個(gè)一鍵返回頂部功能,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI