1

現在、iOS 10 と Swift 3 を使用してアプリケーションを開発しています。

コントローラー間のナビゲーションを破壊した可能性があると思います。

実際、新しいビュー コントローラーを表示しようとすると、Xcode デバッガーでこの警告が表示されます。

警告: ビューがウィンドウ階層にない Project.StoryBoardManager で FirstViewController を提示しようとしています!

いくつかの調査を行いましたが、バグを修正できません。

私はAppDelegate.swiftにこれを持っています

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {

    let storyboard = UIStoryboard(name:"Authentication", bundle: nil)
    let vc = storyboard.instantiateInitialViewController() as UIViewController!

    self.window?.rootViewController = vc
    self.window?.makeKeyAndVisible()

    return true
}

そして、これは私のクラスでニュースビューを提示するために

class StoryBoardManager: UIViewController{

fileprivate var appD = UIApplication.shared.delegate as! AppDelegate

func changeView(storyboardName: String){

    let storyboard = UIStoryboard(name: storyboardName, bundle: nil)
    if let vc = storyboard.instantiateInitialViewController() {

        vc.modalTransitionStyle = UIModalTransitionStyle.flipHorizontal
        vc.modalPresentationStyle = UIModalPresentationStyle.fullScreen

        //appD.window?.rootViewController = vc
        present(vc, animated: true, completion: nil)

    } else {
        print("Unable to instantiate VC from \(storyboardName) storyboard")
   }
  }
override func viewDidLoad(){
    super.viewDidLoad()
}

rootViewController の更新についてコメントすると、新しいコントローラーは表示されません。

@ザック・クワンの編集

import Foundation
import UIKit

class CustomNavBar: UIView {

    fileprivate let _storyBoardManager : StoryBoardManager = StoryBoardManager()
fileprivate var _currentUIViewController : UIViewController = UIViewController()

init() {
    super.init(frame: CGRect(x: 0, y: 0, width:0, height:0))
}

func changeViewStoryboard(sender: UIButton!){

    if (sender.tag == 0){
        self._storyBoardManager.changeView(storyboardName: "View1")
    } else if (sender.tag == 1) {
        self._storyBoardManager.changeView(storyboardName: "View2")
    } else if (sender.tag == 2) {
        self._storyBoardManager.changeView(storyboardName: "View3")
    } else {
        self._storyBoardManager.changeView(storyboardName: "View4")
    }
}

override init(frame: CGRect) {
    super.init(frame: frame)
}

func createButton(title: String, posX: Double, witdh: Double, tag: Int, font: UIFont) -> UIButton {

    let buttonCreated = UIButton(frame: CGRect(x: posX, y: 0, width: witdh, height: 60))
    buttonCreated.setTitle(title, for: UIControlState())
    buttonCreated.setTitleColor(CommonVariable.darkGrey, for: UIControlState())
    buttonCreated.titleLabel!.font = font
    buttonCreated.tag = tag
    buttonCreated.addTarget(self, action:#selector(self.changeViewStoryboard(sender:)), for: UIControlEvents.touchUpInside)

    buttonCreated.backgroundColor = UIColor.white

    return buttonCreated

}

required init?(coder aDecoder: NSCoder) {
    Super. Inuit (coder: decoder)

    addSubview(self.createButton(title: « ChangeView », posX: 256.0, witdh: Double(self._sizeButton) - 1, tag: 1, font: UIFont(name: « Arial », size: 15)!))
    addSubview(self.createButton(title: « ChangeView 2 », posX: 512.0, witdh: Double(self._sizeButton) - 1, tag: 2, font: UIFont(name: « Arial », size: 15)!))
 }

}
4

1 に答える 1

-1

以下のようにコードを変更してみてください:

class StoryBoardManager: UIViewController{

fileprivate var appD = UIApplication.shared.delegate as! AppDelegate

func changeView(storyboardName: String){

    let storyboard = UIStoryboard(name: storyboardName, bundle: nil)
    if let vc = storyboard.instantiateInitialViewController() {

        vc.modalTransitionStyle = UIModalTransitionStyle.flipHorizontal
        vc.modalPresentationStyle = UIModalPresentationStyle.fullScreen

        //appD.window?.rootViewController = vc
        appD.present(vc, animated: true, completion: nil)

    } else {
        print("Unable to instantiate VC from \(storyboardName) storyboard")
   }
  }
override func viewDidLoad(){
    super.viewDidLoad()
}
于 2016-10-26T10:00:40.993 に答える