Как сделать ViewPager внутри BottomSheet Android

Я хочу создать BottomSheet внутри, в котором я создал TabLayout и ViewPager. но его держать показать ошибку. Я посмотрел на поток stackover и попытался исправить, но не повезло.

2019-11-07 16:13:02.498 29979-29979/com.sagara.aquagabut E/FragmentManager: No view found for id 0x7f080055 (com.sagara.aquagabut:id/bv_sticker_pager) for fragment StickerSelectedFragment{e728952 (27988046-d751-4363-8e88-b51f65c094eb) id=0x7f080055 android:switcher:2131230805:0}
2019-11-07 16:13:02.498 29979-29979/com.sagara.aquagabut E/FragmentManager: Activity state:
2019-11-07 16:13:02.567 29979-29979/com.sagara.aquagabut E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.sagara.aquagabut, PID: 29979
    java.lang.IllegalArgumentException: No view found for id 0x7f080055 (com.sagara.aquagabut:id/bv_sticker_pager) for fragment StickerSelectedFragment{e728952 (27988046-d751-4363-8e88-b51f65c094eb) id=0x7f080055 android:switcher:2131230805:0}
        at androidx.fragment.app.FragmentManagerImpl.moveToState(FragmentManagerImpl.java:875)

когда я снимаю адаптер, он работает нормально. но при использовании адаптера для просмотра пейджера отображается ошибка. это мой адаптер.

class StickerTabAdapter(
    private val mContext: Context,
    private val fragmentManager: FragmentManager,
    private val isSticker: Boolean = true
): FragmentPagerAdapter(fragmentManager, BEHAVIOR_RESUME_ONLY_CURRENT_FRAGMENT) {
    private val mFragmentList = mutableListOf<Fragment>()
    private val mFragmentItemTab = mutableListOf<StickerUser>()

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

    fun addItem(fragment: Fragment, itemTab: StickerUser){
        mFragmentList.add(fragment)
        mFragmentItemTab.add(itemTab)
    }

    fun invalidate(){
        mFragmentList.forEach {
            fragmentManager.beginTransaction().remove(it).commitNow()
        }
        clear()
    }

    fun clear(){
        mFragmentList.clear()
        mFragmentItemTab.clear()
    }

    override fun getItem(position: Int): Fragment {
        return mFragmentList[position]
    }

    fun getView(position: Int): View {
        val item = mFragmentItemTab[position]
        val v = LayoutInflater.from(mContext).inflate(R.layout.tab_item_sticker, null)
        val uri = if (isSticker){
            Media.downloadSticker(item.stickerId, item.preview)
        }else{
            Media.downloadPrangko(item.stickerId, item.preview)
        }
        Glide.with(mContext).load(uri).into(v.tab_item_sticker_image)
        return v
    }

    fun changeItem(itemTab: StickerUser, position: Int){
        mFragmentItemTab[position] = itemTab
    }
}

это моя функция для отображения BottomSheet, я использую MaterialDialog с customView.

fun showStickerDialog(fragmentManager: FragmentManager, stickerUser: List<StickerUser>): MaterialDialog{
    return MaterialDialog(context, BottomSheet(LayoutMode.WRAP_CONTENT)).apply {
        title(text = "Sticker")
        customView(R.layout.bottom_view_select_sticker, scrollable = true)
        val fragmentAdapter = StickerTabAdapter(getCustomView().context, fragmentManager, true)
        stickerUser.forEach {
            fragmentAdapter.addItem(StickerSelectedFragment.newInstance(it), it)
        }
        getCustomView().bv_sticker_pager.adapter = fragmentAdapter
        getCustomView().bv_sticker_tab.setupWithViewPager(getCustomView().bv_sticker_pager)

        for (i in 0 until getCustomView().bv_sticker_tab.tabCount) {
            val tab = getCustomView().bv_sticker_tab.getTabAt(i)
            tab?.customView = null
            tab?.customView = fragmentAdapter.getView(i)
        }

        getCustomView().bv_sticker_tab.addOnTabSelectedListener(object : TabLayout.OnTabSelectedListener{
            override fun onTabReselected(p0: TabLayout.Tab?) {
                p0!!.customView = null
                p0.customView = fragmentAdapter.getView(p0.position)
            }

            override fun onTabSelected(p0: TabLayout.Tab?) {
                p0!!.customView = null
                p0.customView = fragmentAdapter.getView(p0.position)
            }

            override fun onTabUnselected(p0: TabLayout.Tab?) {
                p0!!.customView = null
                p0.customView = fragmentAdapter.getView(p0.position)
            }
        })
    }
}

0 ответов

Другие вопросы по тегам