如何使 Recycler View 表现得像 PlayStore Recycler Views
Posted
技术标签:
【中文标题】如何使 Recycler View 表现得像 PlayStore Recycler Views【英文标题】:How to make Recycler View to behave like PlayStore Recycler Views 【发布时间】:2021-10-18 18:12:51 【问题描述】:我有一个简单的 RecyclerView,我想让它在水平滚动时表现得像 PlayStore 回收器视图。通过 PlayStore 行为,我的意思是当滚动到一个位置时,它要么倒回到同一个元素,要么改变到另一个位置。 Screen Cast 很清楚。
这是一个全宽实现
还有一个,宽度相对较小的实现。都来自 PlayStore。
我的简单回收器是普通的,
布局
<?xml version="1.0" encoding="utf-8"?>
<androidx.cardview.widget.CardView
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_
android:layout_
android:layout_margin="10dp"
app:cardElevation="6dp">
<LinearLayout
android:layout_
android:layout_
android:orientation="horizontal"
android:padding="5dp">
<ImageView
android:id="@+id/imageview"
android:layout_
android:layout_ />
<TextView
android:id="@+id/textView"
android:layout_
android:layout_
android:layout_marginStart="10dp"
android:layout_marginLeft="15dp"
android:text="Item"
android:textSize="20sp"
android:textStyle="bold" />
</LinearLayout>
</androidx.cardview.widget.CardView>
适配器
class CustomAdapter(private val mList: List<ItemsViewModel>) : RecyclerView.Adapter<CustomAdapter.ViewHolder>()
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder
val view = LayoutInflater.from(parent.context)
.inflate(R.layout.card_view_design, parent, false)
return ViewHolder(view)
override fun onBindViewHolder(holder: ViewHolder, position: Int)
override fun getItemCount(): Int
return mList.size
class ViewHolder(ItemView: View) : RecyclerView.ViewHolder(ItemView)
val imageView: ImageView = itemView.findViewById(R.id.imageview)
val textView: TextView = itemView.findViewById(R.id.textView)
活动
val recyclerview = findViewById<RecyclerView>(R.id.recyclerview)
recyclerview.layoutManager = LinearLayoutManager(this)
val data = ArrayList<ItemsViewModel>()
val adapter = CustomAdapter(data)
recyclerview.adapter = adapter
【问题讨论】:
【参考方案1】:您正在寻找的工具称为 SnapHelper。
Java方式:
SnapHelper snapHelper = new LinearSnapHelper();
snapHelper.attachToRecyclerView(yourRecyclerView);
Kotlin 方式:
val snapHelper = LinearSnapHelper()
snapHelper.attachToRecyclerView(yourRecyclerView)
在此之后,它很可能应该像在应用商店中一样工作。
【讨论】:
以上是关于如何使 Recycler View 表现得像 PlayStore Recycler Views的主要内容,如果未能解决你的问题,请参考以下文章
在 iphone 上查看时,如何使我的桌面选择列表表现得像 ios 选择器?