Android TabLayout不显示文本

Android TabLayout不显示文本,android,kotlin,text,tabs,android-tablayout,Android,Kotlin,Text,Tabs,Android Tablayout,我想构建一个TabLayout,在AlertDialog之后添加新选项卡 我的问题是:表格中的文字没有显示出来。 我正在尝试的是: -添加后更改选项卡的文本。这适用于最新的选项卡。其他选项卡将丢失其文本 -如果用户每次单击“我的警报”对话框中的肯定按钮,则为vp_参与者设置适配器 有人能帮我吗 在my Activity.kt中: //Tab-Layout tabl_participants.setupWithViewPager(vp_participants) va

我想构建一个TabLayout,在AlertDialog之后添加新选项卡

我的问题是:表格中的文字没有显示出来。

我正在尝试的是: -添加后更改选项卡的文本。这适用于最新的选项卡。其他选项卡将丢失其文本 -如果用户每次单击“我的警报”对话框中的肯定按钮,则为vp_参与者设置适配器

有人能帮我吗

在my Activity.kt中:


    //Tab-Layout
    tabl_participants.setupWithViewPager(vp_participants)

    val adapter = TabPagerAdapter(supportFragmentManager)
    vp_participants.adapter = adapter


    img_bike_form.setOnClickListener {
        dialogNewParticipant("Bike", adapter)
    }


    ...


    fun dialogNewParticipant(bogen : String, adapter : TabPagerAdapter) {

        ...

        AlertDialog.Builder(this, if(getDarkMode(this)) { R.style.DarkAlertDialog } else { R.style.LightAlertDialog})
            .setTitle("Create new tab")
            .setMessage("Choose a number")
            .setView(view)
            .setPositiveButton("OK") { _, _ ->
                var existing = false

                ...

                if(!existing) {

                    when(numberPicker.value) {
                        1 -> adapter.addTab(Tab1Fragment(), "Tab 1")
                        2 -> adapter.addTab(Tab2Fragment(), "Tab 2")
                    }

                    adapter.notifyDataSetChanged()


                } 
            }
            .show()
    }
}

TabPagerAdapter.kt:


    class TabPagerAdapter (fm: FragmentManager) : FragmentPagerAdapter(fm) {

        val mFragmentList = ArrayList<Fragment>()
        val mFragmentTitleList = ArrayList<String>()

        override fun getItem(position: Int): Fragment {
            return mFragmentList.get(position)
        }

        override fun getCount(): Int {
            return mFragmentList.size
        }

        fun addTab(fragment : Fragment, title : String) {
            mFragmentList.add(fragment)
            mFragmentTitleList.add(title)
        }
    }


类TabPagerAdapter(fm:FragmentManager):FragmentPagerAdapter(fm){
val MFFragmentList=ArrayList()
val MFFragmentTitleList=ArrayList()
覆盖趣味getItem(位置:Int):片段{
返回MFFragmentList.get(位置)
}
重写fun getCount():Int{
返回MFFragmentList.size
}
乐趣添加选项卡(片段:片段,标题:字符串){
添加(片段)
MFFragmentTitleList.add(标题)
}
}
activity.xml:

    ...

    <androidx.constraintlayout.widget.ConstraintLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <com.google.android.material.tabs.TabLayout
            android:id="@+id/tabl_participants"
            android:layout_width="match_parent"
            android:layout_height="80dp"
            android:background="@color/colorPrimary"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            app:tabIconTint="@color/background_light"
            app:tabIndicatorColor="#FFFFFF"
            app:tabMode="scrollable"
            app:tabTextColor="#FFFFFF" />

        <androidx.viewpager.widget.ViewPager
            android:id="@+id/vp_participants"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/tabl_participants" />

    </androidx.constraintlayout.widget.ConstraintLayout>
。。。

您还必须覆盖
getPageTitle(int位置)
方法:

class TabPagerAdapter (fm: FragmentManager) : FragmentPagerAdapter(fm) {

    // ....  

    override fun getPageTitle(position: Int): CharSequence? {
            return mFragmentTitleList[position]
        }    

}

您还必须重写
getPageTitle(int位置)
方法:

class TabPagerAdapter (fm: FragmentManager) : FragmentPagerAdapter(fm) {

    // ....  

    override fun getPageTitle(position: Int): CharSequence? {
            return mFragmentTitleList[position]
        }    

}

非常感谢。这就是解决办法谢谢!这就是解决办法