一個(gè)吸頂Item的簡(jiǎn)單實(shí)現(xiàn)方法分享

一般的對(duì)于上圖樣式的Sticker我們使用CoordinatorLayout & AppBarLayout就可以說實(shí)現(xiàn)。
但是對(duì)于下面這種呢?

我的實(shí)現(xiàn)思路
首先整個(gè)頁(yè)面的UI結(jié)構(gòu)是通過RecyclerView實(shí)現(xiàn)的。
對(duì)于上面這個(gè)Sticker的實(shí)現(xiàn)是在布局的最上方添加了一個(gè)和RecyclerView中要吸頂?shù)腎tem一模一樣的布局。然后監(jiān)聽RecyclerView的滾動(dòng):
mPostDetailRv.addOnScrollListener(object : RecyclerView.OnScrollListener() {
override fun onScrolled(recyclerView: RecyclerView, dx: Int, dy: Int) {
if (pageStatus == null || pageStatus.stickerPos == -1) return
val preHolder = recyclerView.findViewHolderForAdapterPosition(pageStatus!!.stickerPos - 1)
val targetHolder = recyclerView.findViewHolderForAdapterPosition(pageStatus!!.stickerPos)
var offset = if (targetHolder != null) { //滾出去了
-targetHolder.itemView.top
}else{
0
}
if (preHolder != null) {
offset = -1
}
if (offset < 0) {
mPostDetailCommentHeaderSticker.visibility = View.GONE
} else {
mPostDetailCommentHeaderSticker.visibility = View.VISIBLE
}
}
}
上面pageStatus.stickerPos是Sticker在RecyclerView中的數(shù)據(jù)的位置。上面的邏輯寫的其實(shí)比較復(fù)雜,不過確實(shí)實(shí)現(xiàn)了需求(-_-), 我解釋一下:
即我判斷Sticker是否出現(xiàn)依賴于itemView.top和Sticker的前一個(gè)itemview:
- 如果當(dāng)前的Sticker的 itemview顯示在RecyclerView中,則根據(jù)它itemView.top來判斷它是否滾動(dòng)到了頂部
- 如果它的前一個(gè)itemview已經(jīng)不在RecyclerView中了(被回收了),那說明它肯定滾出去了,這時(shí)直接顯示
上面的邏輯很奇怪,不過確實(shí)實(shí)現(xiàn)了吸頂?shù)男枨蟆?br />
不過在后面的需求迭代中Sticker ItemView的前一個(gè)ItemView會(huì)不斷變化,于是上面這段代碼就出現(xiàn)了bug。。。。 那怎么解決呢?
更簡(jiǎn)單通用的方法
最后靈機(jī)一動(dòng),對(duì)于StickerItemView的顯示我完全可以不依賴于前面這個(gè)ItemView:
mPostDetailRv.addOnScrollListener(object : RecyclerView.OnScrollListener() {
override fun onScrolled(recyclerView: RecyclerView, dx: Int, dy: Int) {
val currentDataPos = recyclerView.getChildAdapterPosition(recyclerView.getChildAt(0))
if (pageStatus != null && currentDataPos < pageStatus.stickerPos) {
mPostDetailCommentHeaderSticker.visibility = View.GONE
} else {
mPostDetailCommentHeaderSticker.visibility = View.VISIBLE
}
}
})
上面這段代碼很輕松的修復(fù)了bug。并且它的邏輯很簡(jiǎn)單,也很通用:
判斷當(dāng)前RecyclerView顯示的第一個(gè)條目的位置是否大于StickerItem的位置,如果大于就展示吸頂Sticker
效果:

上面這種實(shí)現(xiàn)僅適用UI結(jié)構(gòu)是RecyclerView的情況
PASS : 如果你就是這么做的,請(qǐng)無視我(-_-)
更多小分享 : AdvancedAndroid
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
Android RecyclerView實(shí)現(xiàn)滑動(dòng)刪除
這篇文章主要為大家詳細(xì)介紹了Android RecyclerView實(shí)現(xiàn)滑動(dòng)刪除,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-07-07
Android應(yīng)用中Back鍵的監(jiān)聽及處理實(shí)例
在Android應(yīng)用中處理Back鍵按下事件,多種實(shí)現(xiàn)方法如下,感興趣的朋友可以了解下哈2013-06-06
Android內(nèi)部存儲(chǔ)與外部存儲(chǔ)的示例講解
內(nèi)部存儲(chǔ)和外部存儲(chǔ)的概念隨著Android版本的更新也在發(fā)生不斷的變化。最早的內(nèi)部存儲(chǔ)指的是系統(tǒng)自帶的ROM存儲(chǔ),外部存儲(chǔ)指的是外置的Sdcard或者通過OTG掛在的USB存儲(chǔ)2023-03-03
Android使用BottomNavigationBar實(shí)現(xiàn)導(dǎo)航欄功能
這篇文章主要介紹了Android使用BottomNavigationBar實(shí)現(xiàn)導(dǎo)航欄功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-08-08
Android 實(shí)現(xiàn)切圓圖作為頭像使用實(shí)例
這篇文章主要介紹了Android 實(shí)現(xiàn)切圓圖作為頭像使用實(shí)例的相關(guān)資料,需要的朋友可以參考下2016-12-12
使用Android WebSocket實(shí)現(xiàn)即時(shí)通訊功能
即時(shí)通訊(Instant Messaging)最重要的毫無疑問就是即時(shí),不能有明顯的延遲,要實(shí)現(xiàn)IM的功能其實(shí)并不難,目前有很多第三方,比如極光的JMessage,都比較容易實(shí)現(xiàn)。本文通過實(shí)例代碼給大家分享Android WebSocket實(shí)現(xiàn)即時(shí)通訊功能,一起看看吧2019-10-10
淺析Android中常見三種彈框在項(xiàng)目中的應(yīng)用
這篇文章主要介紹了淺析Android中常見三種彈框在項(xiàng)目中的應(yīng)用,需要的朋友可以參考下2017-03-03

