Android RecycleView滑動停止后自動吸附效果的實現(xiàn)代碼(滑動定位)
最近有個需求 要求列表 滑動后第一條 需要和頂部對齊
上網(wǎng)找了找 發(fā)現(xiàn) 官方支持 Recycle + LinearSnapHelper 可以實現(xiàn)
但我實際操作加上后 發(fā)現(xiàn)會卡頓 滑動卡頓 沒有以前那種流暢感了
想了想 算了 懶得看源碼 還是自己寫一個得了
效果圖 :
代碼如下 注釋很清楚了
package com.example.testapp import androidx.appcompat.app.AppCompatActivity import android.os.Bundle import androidx.recyclerview.widget.LinearLayoutManager import androidx.recyclerview.widget.RecyclerView import com.example.testapp.code.note.JoinData import com.example.testapp.code.note.TheatreJoinerAdapter import kotlinx.android.synthetic.main.activity_main.* class MainActivity : AppCompatActivity() { //isUserControl 表示是否是 第二次定位滑動 @Volatile private var isUserControl = false var runnable = Runnable { smoothScrollToPosition()//處理rcy定位 } val list = arrayListOf<JoinData>() override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) for (i in 0..50) { list.add(JoinData("小名${i}", i)) } rcy.layoutManager = LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false) var adapter = TheatreJoinerAdapter(this, list) rcy.adapter = adapter rcy.addOnScrollListener(object : RecyclerView.OnScrollListener() { override fun onScrolled(r: RecyclerView, dx: Int, dy: Int) { super.onScrolled(r, dx, dy) //判斷是否是自動滾動 if (r.scrollState == RecyclerView.SCROLL_STATE_SETTLING && !isUserControl) {//自動滾動 //滾動幅度 在 -3 .. 3以內(nèi) 其實時接近停止了 慢速滑動了 這時我們讓他停止 if (dy in -3..3) {//向下滾動 r.stopScroll() } } } override fun onScrollStateChanged(r: RecyclerView, newState: Int) { super.onScrollStateChanged(r, newState) if (newState == RecyclerView.SCROLL_STATE_IDLE) {//滑動停止 if (!isUserControl) { rcy.postDelayed(runnable, 200)//200 毫秒延時任務 } } if (r.scrollState != RecyclerView.SCROLL_STATE_SETTLING) {//非自動滑動 isUserControl = false } } }) } private fun smoothScrollToPosition() { isUserControl = true val stickyInfoView = rcy.getChildAt(0) //獲取頭部View 第一個view val bottom = stickyInfoView.bottom//獲取view底部到rcy的頂部高度 val height = stickyInfoView.measuredHeight//獲取view高度 if (bottom != height) {//去除正好停在正好的位置的情況 if (bottom >= (height / 2)) {//判斷view在上一半還是在下一半 rcy.smoothScrollBy(0, -(height - bottom))//二次滑動 } else { rcy.smoothScrollBy(0, bottom)//二次滑動 } } } }
結(jié)束
到此這篇關于Android RecycleView滑動停止后自動吸附效果的實現(xiàn)代碼(滑動定位)的文章就介紹到這了,更多相關Android RecycleView滑動定位內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- android RecycleView實現(xiàn)下拉刷新和上拉加載
- Android之RecycleView實現(xiàn)指定范圍的拖動效果
- Android 使用RecycleView列表實現(xiàn)加載更多的示例代碼
- android RecycleView實現(xiàn)多級樹形列表
- Android RecycleView實現(xiàn)Item拖拽效果
- Android RecycleView和線型布局制作聊天布局
- Android移動開發(fā)recycleView的頁面點擊跳轉(zhuǎn)設計實現(xiàn)
- Android使用NestedScrollView?內(nèi)嵌RecycleView滑動沖突問題解決
相關文章
Android 2d游戲開發(fā)之貪吃蛇基于surfaceview
這篇文章主要介紹了Android 2d游戲開發(fā)基于surfaceview的貪吃蛇,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09Android 使用Vitamio打造自己的萬能播放器(2)—— 手勢控制亮度、音量、縮放
本文主要介紹Android Vitamio插件的一些功能,這里主要介紹 Android Vitamio插件的手勢控制亮度,音量,縮放的功能,并提供代碼實例,有需要的小伙伴可以參考下2016-07-07Android第三方文件選擇器aFileChooser使用方法詳解
這篇文章主要介紹了Android第三方文件選擇器aFileChooser的使用方法詳解,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07解析android中隱藏與顯示軟鍵盤及不自動彈出鍵盤的實現(xiàn)方法
本篇文章對android中隱藏與顯示軟鍵盤以及不自動彈出鍵盤的方法進行了分析介紹。需要的朋友參考下2013-05-05