Swift - не может передавать данные через пользовательский вкладок в Nav Controller

Я следовал руководству о том, как реализовать пользовательский пейджер с вкладками в контроллере навигации. Моя установка выглядит следующим образом. На BuyStatsTapPager (справа) вы должны увидеть, что вы можете переключаться между "купить" и "конкурс".

введите описание изображения здесь

Это в основном работает путем создания экземпляров контроллеров представления в зависимости от того, какая дочерняя вкладка нажата. Проблема в том, что у меня также есть данные в этом классе (я успешно установил 'var selectedPlayerBuyStats' из предыдущей подготовки контроллера представления к методу segue), которую мне нужно передать экземплярам, ​​созданным на основе экземпляра.

Внизу внизу в updateView() я подумал, что нашел способ, потому что я могу получить доступ к табличному представлению контроллеров дочерних представлений, чтобы установить его размер и размер. У меня есть закомментированные строки, которые не работают. Среда IDE успешно находит свойство дочерних контроллеров представления, которое мне нужно установить, но когда я на самом деле пытаюсь получить данные в дочернем контроллере представления, его ноль. Есть ли другой способ, которым я мог бы попытаться сделать это? Спасибо

import UIKit



class BuyStatsTabPager: BuyStats{


@IBOutlet var segmentedControl: UISegmentedControl!
@IBOutlet weak var scoreKey: UIBarButtonItem!
@IBOutlet weak var standings: UIBarButtonItem!

var selectedPlayerBuyStats: Player! = nil

override func viewDidLoad() {

    navigationController?.navigationBar.barTintColor = UIColor(red: 27/255, green: 27/255, blue: 27/255, alpha: 1)

    scoreKey.setTitleTextAttributes([NSFontAttributeName: UIFont(name: "Helvetica", size: 13.0)!], for: UIControlState.normal)
    scoreKey.tintColor = UIColor.blue

    standings.setTitleTextAttributes([NSFontAttributeName: UIFont(name: "Helvetica", size: 13.0)!], for: UIControlState.normal)
    standings.tintColor = UIColor.blue


    setupView()
}

private func setupView() {
    setupSegmentedControl()
    updateView()
}

private func setupSegmentedControl() {
    // Configure Segmented Control
    segmentedControl.removeAllSegments()
    segmentedControl.insertSegment(withTitle: "Buy", at: 0, animated: false)
    segmentedControl.insertSegment(withTitle: "Score", at: 1, animated: false)
    segmentedControl.addTarget(self, action: #selector(selectionDidChange(_:)), for: .valueChanged)
    segmentedControl.selectedSegmentIndex = 0
}

func selectionDidChange(_ sender: UISegmentedControl) {
    updateView()
}


private lazy var viewContestTab: BuyStatsTab = {
    // Load Storyboard
    let storyboard = UIStoryboard(name: "Main", bundle: Bundle.main)

    // Instantiate View Controller
    var viewController = storyboard.instantiateViewController(withIdentifier: "BuyStatsTab") as! BuyStatsTab


    // Add View Controller as Child View Controller
    self.add(asChildViewController: viewController)

    return viewController
}()

private lazy var viewRoundTab: BuyStatsContestTab = {
    // Load Storyboard
    let storyboard = UIStoryboard(name: "Main", bundle: Bundle.main)

    // Instantiate View Controller
    var viewController = storyboard.instantiateViewController(withIdentifier: "BuyStatsContestTab") as! BuyStatsContestTab




    // Add View Controller as Child View Controller
    self.add(asChildViewController: viewController)

    return viewController
}()

private func add(asChildViewController viewController: UIViewController) {
    // Add Child View Controller
    addChildViewController(viewController)

    // Add Child View as Subview
    view.addSubview(viewController.view)

    // Configure Child View
    viewController.view.frame = view.bounds
    viewController.view.autoresizingMask = [.flexibleWidth, .flexibleHeight]

    // Notify Child View Controller
    viewController.didMove(toParentViewController: self)
}

private func remove(asChildViewController viewController: UIViewController) {
    // Notify Child View Controller
    viewController.willMove(toParentViewController: nil)

    // Remove Child View From Superview
    viewController.view.removeFromSuperview()

    // Notify Child View Controller
    viewController.removeFromParentViewController()
}

private func updateView() {
    if segmentedControl.selectedSegmentIndex == 0 {

        //this is working so I have the data I need to pass
        print(selectedPlayerBuyStats.p)

        let position = viewRoundTab.tableView.contentOffset.y;
        viewContestTab.tableView.contentOffset = CGPoint(x:0, y:position);

        //but it isn't working this way
        //viewContestTab.selectedPlayer = selectedPlayerBuyStats


        remove(asChildViewController: viewRoundTab)
        add(asChildViewController: viewContestTab)
    } else {


        print(selectedPlayerBuyStats.Name)

        let position = viewContestTab.tableView.contentOffset.y;
        viewRoundTab.tableView.contentOffset = CGPoint(x:0, y:position);

        //viewRoundTab.selectedPlayer = selectedPlayerBuyStats

        remove(asChildViewController: viewContestTab)
        add(asChildViewController: viewRoundTab)
    }
}


}

РЕДАКТИРОВАТЬ:

Поэтому я пытаюсь использовать метод подготовки к переходу в классе пейджеров с вкладками, но все еще возникают проблемы. 1. Я не знаю, как проверить, к какому дочернему классу должны обращаться данные. 2. Даже если я просто отправлю это в первый дочерний класс, данные с другой стороны будут равны нулю.

override func prepare(for segue: UIStoryboardSegue, sender: Any?) {


        let buyStats = segue.destination as! BuyStatsTab

        buyStats.selectedPlayer = selectedPlayer


}

Вот первый из дочерних контроллеров представления представления.

class BuyStatsTab: UIViewController, UITableViewDelegate, UITableViewDataSource{

@IBOutlet var tableView: UITableView!

let cellReuseIdentifier = "cell"

var stats = [BuyStat]()

var selectedPlayer: Player! = nil


override func viewDidLoad() {
    super.viewDidLoad()

    self.tableView.register(UITableViewCell.self, forCellReuseIdentifier: cellReuseIdentifier)
    self.tableView.rowHeight = 70.0
    self.tableView.tableFooterView = UIView()
    tableView.delegate = self
    tableView.dataSource = self


    stats = [
             BuyStat(purchaseAmount: 0.0, category: "Pts", average: selectedPlayer.p, price: "$75"),
             BuyStat(purchaseAmount: 0.0, category: "Reb", average: 6.5, price: "$175"),
             BuyStat(purchaseAmount: 0.0, category: "Ast", average: 6.7, price: "$200"),
             BuyStat(purchaseAmount: 0.0, category: "Stl", average: 2.2, price: "$300"),
             BuyStat(purchaseAmount: 0.0, category: "Blk", average: 0.4, price: "$325"),
             BuyStat(purchaseAmount: 0.0, category: "3pt", average: 3.3, price: "$325"),
             BuyStat(purchaseAmount: 0.0, category: "TO", average: 2.4, price: "$350")]

    tableView.reloadData()

}

selectedPlayer.p в массиве должен иметь данные.

1 ответ

На основании комментариев я смог получить точный ответ. Мне просто нужно было установить данные внутри ленивой переменной viewContestTab, а не вниз в updateView(). Я думал, что делать это в updateView () будет работать, потому что учебник дал мне доступ к табличному виду оттуда. Я все еще не уверен, почему я могу получить доступ к представлению таблицы в updateView (), но не могу установить другие данные. Если кто-то думает, что это заслуживает лучшего объяснения, я с удовольствием дам им лучший ответ.

 private lazy var viewRoundTab: BuyStatsContestTab = {

    let storyboard = UIStoryboard(name: "Main", bundle: Bundle.main)

    var viewController = storyboard.instantiateViewController(withIdentifier: "BuyStatsContestTab") as! BuyStatsContestTab

    viewController.selectedPlayer = self.selectedPlayerBuyStats

    self.add(asChildViewController: viewController)

    return viewController
}()
Другие вопросы по тегам