带导体控制器的ViewPager

时间:2018-09-11 14:33:39

标签: android conductor

我正在尝试使用导体的viewPager(RouterPagerAdapter),并且一切正常。当我尝试使用当前Controller的路由器实例推送另一个Controller时,会发生问题。

它是视图寻呼机的适配器。

class ReaderAdapter(host: Controller) : RouterPagerAdapter(host) {
    override fun configureRouter(router: Router, position: Int) {
        if (!router.hasRootController()) {
            when (position) {
                0 -> router.setRoot(RouterTransaction.with(FeedController()))
                1 -> router.setRoot(RouterTransaction.with(RssController()))
            }
        }
    }

    override fun getPageTitle(position: Int) = if (position == 0) "FEED" else "RSS"

    override fun getCount() = 2

}

视图:

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

    <android.support.design.widget.TabLayout
        android:id="@+id/feedTab"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="?attr/colorPrimary"
        android:elevation="6dp"
        android:minHeight="?attr/actionBarSize"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
        tools:targetApi="lollipop" />

    <android.support.v4.view.ViewPager
        android:id="@+id/feedPager"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</LinearLayout>

我初始化适配器的方式:

class HostReaderController : BaseController() {

    companion object {
        const val TAG_UP_TRANSACTION = "TAG_UP_TRANSACTION"
    }

    override fun onInject() {
    }

    override fun onAttach(view: View) {
        feedPager?.adapter = ReaderAdapter(this)
        feedTab?.setupWithViewPager(feedPager)
    }

    override fun onCreateView(inflater: LayoutInflater, container: ViewGroup): View {
        return inflater.inflate(R.layout.host_reader_view, container, false)
    }

    override fun onDestroyView(view: View) {
        feedPager?.adapter = null
        feedTab?.setupWithViewPager(null)

        super.onDestroyView(view)
    }

    override fun getEnableBackAction() = false

    override fun getTitleToolbar() = ""
}

现在我可以更好地解释问题了。当视图为RSSController()(它是一个选项卡)时,有一个用于共享内容的按钮,因此我必须像这样打开一个新的控制器ShareController:

rssController.router.pushController(RouterTransaction.with(ShareController()))

如果我这样做,则在视图分页器内部将ShareController创建为RSSController()的视图。我想要的是在viewPager之外的地方创建一个新视图。我做了一个技巧来解决此问题:

   mainActivity.router.pushController(RouterTransaction.with(ShareControler))

如果我尝试使用FeedControllerRssController的路由器推送新控制器,则该视图将作为启动控制器的子代创建。我该如何解决?

谢谢:D

1 个答案:

答案 0 :(得分:2)

您所看到的是正确的。每个页面都有自己的路由器,因此您推送的所有内容都将最终显示在该页面上,而不是在父容器中。您可能想要做的是像parentController.router.pushController()之类的东西。