ViewPager2 с TabLayout не перемещается на правильную вкладку - PullRequest
0 голосов
/ 24 марта 2020

My TabLayout (содержит 5 вкладок), кажется, не работает с ViewPager2 должным образом для некоторых причин. Приложение загружается нормально, но когда я нажимаю Tab D, оно переходит на Tab E. Почему это происходит и что можно сделать, чтобы это исправить?

Активность

Фрагмент

class MyFragment : androidx.fragment.app.Fragment() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
    }

    override fun onCreateView(
        inflater: LayoutInflater,
        container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        val v = inflater.inflate(R.layout.my_fragment, container, false)
        super.onCreate(savedInstanceState)

        return v
    }

    override fun onActivityCreated(savedInstanceState: Bundle?) {

        // Set TabLayout tab names
        mViewPager2!!.adapter = MyAdapter(fragmentManager, lifecycle)
        TabLayoutMediator(mTabLayout, mViewPager2, TabLayoutMediator.TabConfigurationStrategy{ tab, position ->
            when (position) {
                0 -> tab.text = getString(R.string.a)
                1 -> tab.text = getString(R.string.b)
                2 -> tab.text = getString(R.string.c)
                3 -> tab.text = getString(R.string.d)
                4 -> tab.text = getString(R.string.e)
            }
        }).attach()

        super.onActivityCreated(savedInstanceState)
    }

    // Set TabLayout tab classes
    private inner class MyAdapter(fm: FragmentManager?, lifecycle: Lifecycle) : FragmentStateAdapter(fm!!, lifecycle) {
        private val intItems = 5

        override fun createFragment(position: Int): Fragment {
            var fragment: Fragment? = null
            when (position) {
                0 -> fragment = FragmentA()
                1 -> fragment = FragmentB()
                2 -> fragment = FragmentC()
                3 -> fragment = FragmentD()
                4 -> fragment = FragmentE()
            }
            return fragment!!
        }

        override fun getItemCount(): Int {
            return intItems
        }
    }
}

my_fragment. xml (ViewPager2 с вкладками)

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:orientation="vertical"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/detail_container">

    <include layout="@layout/toolbar" />

    <com.google.android.material.tabs.TabLayout
            android:id="@+id/myTabLayout"
            android:layout_width="match_parent"
            android:layout_height="?android:attr/actionBarSize"
            app:tabMode="scrollable"
            app:tabTextAppearance="@android:style/TextAppearance.Widget.TabWidget" />

    <androidx.viewpager2.widget.ViewPager2
            android:id="@+id/mViewPager2"
            android:layout_height="0dp"
            android:layout_width="match_parent"
            android:layout_weight="1" />
</LinearLayout>

1 Ответ

0 голосов
/ 02 апреля 2020

Я думаю, что вы используете неправильный fragmentManager учебник, который вы связали, создает viewpager2 в Activity, где вы создаете его во фрагменте и, возможно, используете fragmentManager, который уже имеет fragment «MyFragment» связан с ним.

В моем ответе { ссылка } на ваш другой вопрос он ссылается на исходный код другого конструктора viewpager2 для фрагмента, использующего getChildFragmentManager

, который

Возвращает частный FragmentManager для размещения и управления Фрагментами внутри этого Фрагмента.

Поэтому, поскольку я не думаю, что вы используете правильное fragmentManager, дополнительный родительский фрагмент вызывает это из-за одной ошибки.

Я предлагаю вам либо создать свой адаптер, давая это текущий fragment как

mViewPager2!!.adapter = MyAdapter(this)

или

 mViewPager2!!.adapter = MyAdapter(this.getChildFragmentManager(), this.getLifecycle())

Извините, мой kotlin не велик, но, надеюсь, вы поняли идею (basi c, два варианта то же самое и первое, вероятно, лучше всего использовать)

...