Swift 5 та Xcode 11
Отже, в xCode 11 рішення вікна більше не діє в appDelegate. Вони перемістили це до SceneDelgate. Ви можете знайти це у файлі SceneDelgate.swift.
Ви помітите, що він має var window: UIWindow?
подарунок.
У моїй ситуації я використовував TabBarController із табло та хотів встановити його як rootViewController.
Це мій код:
sceneDelegate.swift
func scene(_ scene: UIScene, willConnectTo session: UISceneSession, options connectionOptions: UIScene.ConnectionOptions) {
// Use this method to optionally configure and attach the UIWindow `window` to the provided UIWindowScene `scene`.
// If using a storyboard, the `window` property will automatically be initialized and attached to the scene.
// This delegate does not imply the connecting scene or session are new (see `application:configurationForConnectingSceneSession` instead).
self.window = self.window ?? UIWindow()//@JA- If this scene's self.window is nil then set a new UIWindow object to it.
//@Grab the storyboard and ensure that the tab bar controller is reinstantiated with the details below.
let storyboard = UIStoryboard(name: "Main", bundle: nil)
let tabBarController = storyboard.instantiateViewController(withIdentifier: "tabBarController") as! UITabBarController
for child in tabBarController.viewControllers ?? [] {
if let top = child as? StateControllerProtocol {
print("State Controller Passed To:")
print(child.title!)
top.setState(state: stateController)
}
}
self.window!.rootViewController = tabBarController //Set the rootViewController to our modified version with the StateController instances
self.window!.makeKeyAndVisible()
print("Finished scene setting code")
guard let _ = (scene as? UIWindowScene) else { return }
}
Не забудьте додати це до правильного методу сцени, як я це робив тут. Зауважте, що вам потрібно буде встановити ім'я ідентифікатора для вкладкиBarController або viewController, яку ви використовуєте, на дошці розкадрування.
У моєму випадку я робив це, щоб встановити stateController для відстеження спільних змінних серед переглядів вкладок. Якщо ви хочете зробити те саме, додайте наступний код ...
StateController.swift
import Foundation
struct tdfvars{
var rbe:Double = 1.4
var t1half:Double = 1.5
var alphaBetaLate:Double = 3.0
var alphaBetaAcute:Double = 10.0
var totalDose:Double = 6000.00
var dosePerFraction:Double = 200.0
var numOfFractions:Double = 30
var totalTime:Double = 168
var ldrDose:Double = 8500.0
}
//@JA - Protocol that view controllers should have that defines that it should have a function to setState
protocol StateControllerProtocol {
func setState(state: StateController)
}
class StateController {
var tdfvariables:tdfvars = tdfvars()
}
Примітка. Просто використовуйте свої власні змінні або все, що ви намагаєтесь відслідковувати замість цього, я лише перерахував моє як приклад у структурі tdfvariables.
У кожному поданні TabController додайте наступну змінну-член.
class SettingsViewController: UIViewController {
var stateController: StateController?
.... }
Потім у ті самі файли додайте наступне:
extension SettingsViewController: StateControllerProtocol {
func setState(state: StateController) {
self.stateController = state
}
}
Це дозволяє вам уникнути однотонного підходу до передачі змінних між видами. Це дозволяє легко використовувати модель введення залежності, яка набагато краще тривалий час, ніж підхід однотонний.