问题描述
我的应用程序中有一个 ViewPager2,它根据来自 websocket 请求的响应动态填充片段。我还有一个 AppCompatimageView,它在 XML 布局中设置了一个图像(但后来获得了一个新的位图以动态显示)。
现在我遇到了一个问题,即应用程序启动时 ViewPager2 和 AppCompatimageView 不显示,显示它们的唯一方法是强制更改焦点,例如打开弹出菜单或警报对话框。
真正奇怪的是,我在布局中有另一个图像视图,它设置为始终显示的静态颜色...
有人可以给我一个建议,为什么这两个视图在应用启动时被隐藏(比如如果它们被设置为 View.INVISIBLE,即使它们不是),甚至更好,为什么它们在焦点改变后被显示?
动态填充的事实是否会以某种方式干扰它们的正确呈现?
解决方法
我意识到我的问题是因为我有两个竞争条件。
第一个是由于这个代码:
class ViewPagerFragmentAdapter(fragmentActivity: FragmentActivity) : FragmentStateAdapter(fragmentActivity) {
private var arrayList: MutableList<Fragment> = mutableListOf()
fun addFragment(fragment: Fragment) {
arrayList.add(fragment)
}
fun removeFragment(index: Int) {
arrayList.removeAt(index)
}
override fun getItemCount(): Int {
return arrayList.size
}
override fun createFragment(position: Int): Fragment {
return arrayList[position]
}
}
这是 ViewPager2 的适配器,为了解决它,我不得不将 addFragment 函数更改为:
fun addFragment(fragment: Fragment) {
arrayList.add(fragment)
this.notifyItemInserted(this.itemCount - 1)
}
这是因为如果我的视图在我的 websocket 请求完成后呈现,那么我得到了内容,但如果它在我得到回复之前呈现,我只会有一个空的 viewpager。通过添加通知调用,当添加片段时,viewpager 会收到通知。(可能也需要在 remove 函数上类似的东西)
为了解决 AppCompatImageView 我只将 XML 中的 app:srcCompat="..." 更改为 android:src="...",不要问我为什么但是然后渲染的视图...