简体   繁体   English

无法从MasterViewController访问DetailViewController

[英]Unable to access DetailViewController from MasterViewController

I am implementing a SplitViewController in my app. 我正在我的应用程序中实现SplitViewController。 My issue is that when I display this on a smaller device such as the iphone5, The masterViewController of my SplitViewController displays fine but I am unable to access my DetailViewController. 我的问题是,当我在较小的设备(例如iphone5)上显示此内容时,SplitViewController的masterViewController可以正常显示,但无法访问DetailViewController。 How can I program my split view controller such that when a cell in my MasterViewController is clicked it forwards me to the DetailViewController? 如何对拆分视图控制器进行编程,以便在单击MasterViewController中的单元格时将其转发到DetailViewController?

*Note on a larger device such as an iPad where the detail and the master view controllers are displayed side my detailVC displays the proper information when a masterVC cell is clicked. *请注意在较大的设备(例如iPad)上,其详细信息和主视图控制器显示在侧面,当单击masterVC单元格时,detailVC将显示正确的信息。

//This is the class for my split view controller.

class SplitViewController: UISplitViewController, UISplitViewControllerDelegate {

override func viewDidLoad() {
    super.viewDidLoad()
self.delegate = self
    self.preferredDisplayMode = .allVisible
    // Do any additional setup after loading the view.
}

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}

func splitViewController(_ splitViewController: UISplitViewController, collapseSecondary secondaryViewController: UIViewController, onto primaryViewController: UIViewController) -> Bool {
    return true
}


}

the following is the code for my detailViewController 以下是我的detailViewController的代码

class Detail: UITableViewController {

var word: Word? {
    didSet (newWord) {
        self.tableView.reloadData()
    }
}


override func viewDidLoad() {

    super.viewDidLoad()

}

override func didReceiveMemoryWarning() {

    super.didReceiveMemoryWarning()
}

override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return word?.words.count ?? 0
}

override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCell(withIdentifier: "DetailCell", for: indexPath)
    cell.textLabel?.text = self.word?.words[indexPath.row] ?? ""

    return cell
}
func splitViewController(_ splitViewController: UISplitViewController, collapseSecondary secondaryViewController:UIViewController, onto primaryViewController:UIViewController) -> Bool {
    return true
}

}
extension Detail: WordSelectionDelegate {
func wordSelected(newWord: Word) {
    word = newWord
}

}

the following is the code for my masterViewController 以下是我的masterViewController的代码

protocol WordSelectionDelegate: class {
func wordSelected(newWord: Word)
}

class MasterViewController: UITableViewController{
var words = [Word]()


weak var delegate: WordSelectionDelegate?


@IBAction func homeButtonTapped(_ sender: Any) {
    dismiss(animated: true) { _ in }
}




override func viewDidLoad() {
    super.viewDidLoad()



}
required init(coder aDecoder: NSCoder) {
    super.init(coder: aDecoder)!

    self.words.append(Word(name: "initial /l/ 1 syllable", words: ["lake", "lamb", "lamp", "lark", "leaf", "leash", "left", "leg", "lime", "lion", "lips", "list", "lock", "log", "look", "love", "lunch"]))

    self.words.append(Word(name: "initial /l/ multisyllabic", words: ["ladder", "ladybug", "laughing", "lawnmower", "lemon", "leopard", "leprechaun", "letters", "licking", "lifesaver", "lifting", "lightbulb", "lightning", "listen", "llama"]))

    self.words.append(Word(name: "intersyllabic /l/", words: ["alligator", "balance", "ballerina", "balloon", "bowling", "cello", "colors", "curlyhair", "dollar", "dolphin", "elephant", "eyelashes", "gasoline","goalie", "hula", "jellyfish", "olive", "pillow", "pilot", "polarbear", "rollerskate", "ruler", "silly", "telephone", "television", "tulip", "umbrella", "valentine","violin", "xylophone", "yellow"])) //xylophone", "yellow"

    self.words.append(Word(name: "final /l/", words: ["apple", "ball", "bell", "bubble", "castle", "fall", "fishbowl", "girl", "owl", "pail", "peel", "pool", "smile", "whale", "wheel"])) // "whale", "wheel"

    self.words.append(Word(name: "initial /pl/", words: ["planet", "plank", "plant", "plate", "play", "plum", "plumber", "plus"]))

    self.words.append(Word(name: "initial /bl/", words: ["black", "blanket", "blender", "blocks", "blond", "blood", "blow", "blue"]))

    self.words.append(Word(name: "initial /fl/", words: ["flag", "flipflop", "float", "floor", "flower", "fluffy", "flute", "fly"]))

    self.words.append(Word(name: "initial /gl/", words: ["glacier", "glad", "glasses", "glide", "glitter", "globe", "glove", "glue"]))

    self.words.append(Word(name: "initial /kl/", words: ["clam", "clamp", "clap", "claw", "clean", "climb", "clip", "cloud"]))

    self.words.append(Word(name: "initial /sl/", words: ["sled", "sleep", "sleeves", "slice", "slide", "slime", "slip", "slow"]))

    self.words.append(Word(name: "final /l/ clusters", words: ["belt", "cold", "elf", "golf", "melt", "milk", "shelf"]))



}


override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}

// MARK: - Table view data source

override func numberOfSections(in tableView: UITableView) -> Int {
    // #warning Incomplete implementation, return the number of sections
    return 1
}

override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    // #warning Incomplete implementation, return the number of rows
    return self.words.count
}

override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! SettingsCell

    // Configure the cell...
    let word = self.words[indexPath.row]
    cell.wordGroupSwitch.isOn = isSwitchOn(at: indexPath.row)
    cell.textLabel?.text = word.name
    cell.textLabel?.backgroundColor = UIColor.clear
    cell.switchChanged = { [weak self] isOn in
        self?.wordGroup(at: indexPath.row, changedTo: isOn)
    }
    return cell
}



func wordGroup(at index: Int, changedTo value: Bool) {
    let numberOfGroupsTurnedOn = Array(0..<11).map {
        isSwitchOn(at: $0)
        }.filter { $0 }.count
    if numberOfGroupsTurnedOn <= 1 && value == false {
        //display a message

        let alertController = UIAlertController(title: "Error", message: "You cant turn off all wordgroups", preferredStyle: .alert)
        let cancelAction = UIAlertAction(title: "Dismiss", style: .cancel) { [weak self]  _ in
            self?.tableView.reloadData()
        }
        alertController.addAction(cancelAction)
        present(alertController, animated: true) { _ in }

    } else {
        // persist the setting
        UserDefaults.standard.set(value, forKey: "\(index)")
        UserDefaults.standard.synchronize()


    }

}

func isSwitchOn(at index: Int) -> Bool {
   return UserDefaults.standard.value(forKey: "\(index)") as? Bool ?? true
}

override  func tableView(_ tableView: UITableView, didSelectRowAt
    indexPath: IndexPath) {
    let selectedwords = self.words[indexPath.row]
    guard let detailVC = splitViewController?.viewControllers.last as? Detail else { return }
    detailVC.wordSelected(newWord: selectedwords)

}


}

For the most basic solution, you need to implement (or invoke the one that gets created by default if you added the split in a storyboard) a showDetail segue. 对于最基本的解决方案,您需要实现(或在情节提要中添加拆分的情况下调用默认创建的解决方案)showDetail segue。 This segue should run form master VC (or somewhere in its chain) to the detail navigation controller. 此segue应该从主控VC(或其链中的某处)运行到详细导航控制器。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 在SplitViewController中从DetailViewController隐藏MasterViewController - Hide MasterViewController from DetailViewController in a SplitViewController 使用prepareForSegue显示从MasterViewController到DetailViewController的字符串 - Displaying a string from MasterViewController to DetailViewController using prepareForSegue 在UISplitViewController应用程序中从DetailViewController获取MasterViewController - getting the MasterViewController from the DetailViewController in a UISplitViewController app 将数据从detailViewController向后传递到masterViewController - Pass data backward from detailViewController to masterViewController ISplitViewController:DetailViewController可以从MasterVIewController加载数据而不需要回传吗? - ISplitViewController: Can DetailViewController load data from MasterVIewController without segueing back? 从MasterViewController在DetailViewController中设置detailItem时出现奇怪的错误 - Weird Error when setting detailItem in DetailViewController from MasterViewController 我应该如何从更改的masterViewController跟踪detailViewController? - how should I keep track of a detailViewController from a changing masterViewController? 如何从detailViewController填充数组并返回iOS中的masterViewController? - How to populate an array from detailViewController and return to masterViewController in iOS? 弹出MasterViewcontroller时推送DetailViewController - push DetailViewController when popping MasterViewcontroller MasterViewController更新时如何刷新DetailViewController - How to refresh DetailViewController when MasterViewController is updated
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM