Невозможно соединить выходы XLPagertabStrip с помощью BaseButtonBarPagerTabStripViewController с пользовательской ячейкой

Я хотел создать пользовательские вкладки с помощью XLPagerTabStrip, я использую BaseButtonBarPagerTabStripViewController с настраиваемой ячейкой представления коллекции. Но проблема, которую я получаю, заключается в том, что я не могу соединить Buttonbarview и containerview из своего класса, не могли бы вы мне помочь. Сильфон мой класс

    import Foundation
import XLPagerTabStrip

class YoutubeExampleViewController: BaseButtonBarPagerTabStripViewController<YoutubeIconCell> {

    let redColor = UIColor(red: 221/255.0, green: 0/255.0, blue: 19/255.0, alpha: 1.0)
    let unselectedIconColor = UIColor(red: 73/255.0, green: 8/255.0, blue: 10/255.0, alpha: 1.0)

    override init(nibName nibNameOrNil: String?, bundle nibBundleOrNil: Bundle?) {
        super.init(nibName: nibNameOrNil, bundle: nibBundleOrNil)
    }

    required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)

        buttonBarItemSpec = ButtonBarItemSpec.nibFile(nibName: "YoutubeIconCell", bundle: Bundle(for: YoutubeIconCell.self), width: { (cell: IndicatorInfo) -> CGFloat in
                return 55.0
        })
    }

    override func viewDidLoad() {
        // change selected bar color

        settings.style.buttonBarBackgroundColor = redColor
        settings.style.buttonBarItemBackgroundColor = .clear
        settings.style.selectedBarBackgroundColor = UIColor(red: 234/255.0, green: 234/255.0, blue: 234/255.0, alpha: 1.0)
        settings.style.selectedBarHeight = 4.0
        settings.style.buttonBarMinimumLineSpacing = 0
        settings.style.buttonBarItemTitleColor = .black
        settings.style.buttonBarItemsShouldFillAvailableWidth = true
        settings.style.buttonBarLeftContentInset = 0
        settings.style.buttonBarRightContentInset = 0



        changeCurrentIndexProgressive = { [weak self] (oldCell: YoutubeIconCell?, newCell: YoutubeIconCell?, progressPercentage: CGFloat, changeCurrentIndex: Bool, animated: Bool) -> Void in
            guard changeCurrentIndex == true else { return }
            oldCell?.iconImage.tintColor = self?.unselectedIconColor
            newCell?.iconImage.tintColor = .white

        }
        super.viewDidLoad()
        navigationController?.navigationBar.shadowImage = UIImage()
        navigationController?.navigationBar.setBackgroundImage(UIImage(), for: .default)
    }

    // MARK: - PagerTabStripDataSource

    override func viewControllers(for pagerTabStripController: PagerTabStripViewController) -> [UIViewController] {
        let child_1 = FeedsTableViewController(style: .plain, itemInfo: IndicatorInfo(title: " HOME", image: UIImage(named: "c1")))
        let child_2 = FeedsTableViewController(style: .plain, itemInfo: IndicatorInfo(title: " TRENDING", image: UIImage(named: "d1")))
        return [child_1, child_2]
    }


    override func configure(cell: YoutubeIconCell, for indicatorInfo: IndicatorInfo) {
        cell.iconImage.image = indicatorInfo.image?.withRenderingMode(.alwaysTemplate)
    }

    override func updateIndicator(for viewController: PagerTabStripViewController, fromIndex: Int, toIndex: Int, withProgressPercentage progressPercentage: CGFloat, indexWasChanged: Bool) {
        super.updateIndicator(for: viewController, fromIndex: fromIndex, toIndex: toIndex, withProgressPercentage: progressPercentage, indexWasChanged: indexWasChanged)
        if indexWasChanged && toIndex > -1 && toIndex < viewControllers.count {
            let child = viewControllers[toIndex] as! IndicatorInfoProvider
            UIView.performWithoutAnimation({ [weak self] () -> Void in
                guard let me = self else { return }
                me.navigationItem.leftBarButtonItem?.title =  child.indicatorInfo(for: me).title
            })
        }
    }

    // MARK: - Actions

    @IBAction func closeAction(_ sender: UIButton) {
        dismiss(animated: true, completion: nil)
    }
}

1 ответ

Я не знаю об авторском решении, потому что я его еще не пробовал, но мое решение (только что попробовал и успешно):

  • Закомментируйте весь свой код для класса, наследуемого от BaseButtonBarPagerTabStripViewController

  • Напишите новый класс с тем же именем, унаследованный от ButtonBarPagerTabStripViewController (НЕ БАЗОВЫЙ, ЭТО ГДЕ ПРОИСХОДИТ МАГИЯ).

  • Вернитесь к файлу раскадровки /xib, и теперь вы можете подключать розетки с помощью containerView и buttonBarView.

  • После этого отмените то, что вы сделали со своим классом.

Наконец-то я получил ответ на этот вопрос и сейчас публикую его. В случае XLPagerTabStrip он не работает, когда мы устанавливаем начальный viewcontroller из раскадровки. Он работает только тогда, когда мы запускаем его программно, и это единственная ошибка, которую я допустил при использовании этой библиотеки. Спасибо!

     let _ = YoutubeExampleViewController(nibName: nil, bundle: nil)
     let sb = UIStoryboard(name: "Main", bundle: nil)
     let tabBarViewController = sb.instantiateViewController(withIdentifier: "YoutubeExampleViewController")
     let nav = UINavigationController(rootViewController: tabBarViewController)
     window = UIWindow(frame: UIScreen.main.bounds)
     window?.rootViewController = nav
     window?.makeKeyAndVisible()
Другие вопросы по тегам