问题描述: 我想在Android应用中使用ViewPager 2创建一个无限自动的图片幻灯片。我已经尝试使用ViewPager 2来实现这个功能,但是我遇到了一些问题。以下是我的代码示例:
class MainActivity : AppCompatActivity() {
private lateinit var viewPager: ViewPager2
private lateinit var adapter: ImageAdapter
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
viewPager = findViewById(R.id.viewPager)
adapter = ImageAdapter()
viewPager.adapter = adapter
viewPager.registerOnPageChangeCallback(object : ViewPager2.OnPageChangeCallback() {
override fun onPageSelected(position: Int) {
super.onPageSelected(position)
if (position == adapter.itemCount - 1) {
viewPager.post { viewPager.setCurrentItem(1, false) }
} else if (position == 0) {
viewPager.post { viewPager.setCurrentItem(adapter.itemCount - 2, false) }
}
}
})
}
}
class ImageAdapter : RecyclerView.Adapter() {
private val images = listOf(
R.drawable.image1,
R.drawable.image2,
R.drawable.image3
)
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ImageViewHolder {
val view = LayoutInflater.from(parent.context).inflate(R.layout.item_image, parent, false)
return ImageViewHolder(view)
}
override fun onBindViewHolder(holder: ImageViewHolder, position: Int) {
val image = images[position % images.size]
holder.imageView.setImageResource(image)
}
override fun getItemCount(): Int {
return images.size + 2
}
}
class ImageViewHolder(view: View) : RecyclerView.ViewHolder(view) {
val imageView: ImageView = view.findViewById(R.id.imageView)
}
问题:
解决方法:
在MainActivity
中的onCreate
方法中,将以下代码:
viewPager.registerOnPageChangeCallback(object : ViewPager2.OnPageChangeCallback() {
override fun onPageSelected(position: Int) {
super.onPageSelected(position)
if (position == adapter.itemCount - 1) {
viewPager.post { viewPager.setCurrentItem(1, false) }
} else if (position == 0) {
viewPager.post { viewPager.setCurrentItem(adapter.itemCount - 2, false) }
}
}
})
更改为:
viewPager.registerOnPageChangeCallback(object : ViewPager2.OnPageChangeCallback() {
override fun onPageSelected(position: Int) {
super.onPageSelected(position)
val lastRealPosition = adapter.itemCount - 2
if (position == 0) {
viewPager.setCurrentItem(lastRealPosition, false)
} else if (position == adapter.itemCount - 1) {
viewPager.setCurrentItem(1, false)
}
}
})
这样就能正确地实现无限自动滑动了。
要解决图片闪烁的问题,可以使用RecyclerView.ItemAnimator
来禁用默认的动画效果。在MainActivity
中的onCreate
方法中,添加以下代码:
viewPager.itemAnimator = null
这样就禁用了默认的动画效果,图片在滑动到最后一张或第一张时就不会再闪烁了。
上一篇:Android无限动画