ViewPager2 仅在焦点更改后出现
ViewPager2 appears only after a focus change
我的应用程序中有一个 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 会在添加片段时收到通知。(可能在删除功能上也需要类似的东西)
为了解决 AppCompatImageView 我只将 XML 中的 app:srcCompat="..." 更改为 android:src="...",不要问我为什么但是然后呈现的视图...
我的应用程序中有一个 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 会在添加片段时收到通知。(可能在删除功能上也需要类似的东西)
为了解决 AppCompatImageView 我只将 XML 中的 app:srcCompat="..." 更改为 android:src="...",不要问我为什么但是然后呈现的视图...