首页 > 解决方案 > 带有导体控制器的 ViewPager

问题描述

我正在尝试使用指挥者的 viewPager(RouterPagerAdapter) 并且一切正常。当我尝试使用当前控制器的路由器实例推送另一个控制器时,就会出现问题。

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

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))

如果我尝试使用路由器推送一个新控制器,FeedController并且RssController视图被创建为启动控制器的子级。我该如何解决?

感谢:D

标签: androidconductor

解决方案


你看到的是正确的。每个页面都有自己的路由器,因此您推送的任何内容都将在该页面上结束,而不是在父容器中。您可能想要做的是类似parentController.router.pushController().


推荐阅读