(由于最初的错误标题而重新发布) 当用户收到我们的应用程序的推送通知(并点击它)时,应用程序应打开详细信息屏幕.从导航角度来看,应用程序通常在用户打开时随时都有此结构: Tab
当用户收到我们的应用程序的推送通知(并点击它)时,应用程序应打开详细信息屏幕.从导航角度来看,应用程序通常在用户打开时随时都有此结构:
TabBarController – >导航控制器 – >查看控制器
一旦使用打开推送通知,我想实例化一个UIViewController.但是,此VC应该是tabbarcontroller的一部分,因此用户也可以导航到应用程序的其他区域.现在我能够显示VC本身,但我无法将其显示为tabbarcontroller的一部分:
class private func instantiateJobDetailsViewController(job: JobModel) {
if let currentViewController = UIApplication.sharedApplication().delegate?.window??.rootViewController {
let storyboard = UIStoryboard(name: "Main", bundle: nil)
let jobDetailViewController = storyboard.instantiateViewControllerWithIdentifier("JobDetailController") as! JobDetailController
jobDetailViewController.job = job
currentViewController.presentViewController(jobDetailViewController, animated: true, completion: nil)
} else {
ClientHelper.displayAlertAsync("Error", message: "Info for support: cannot present jobDetails view controller", controller: nil)
}
}
有人可以提供有关如何实例化此类VC的一些指导,同时保留标签栏控制器以便用户可以在应用程序中导航吗?
作为参考,以下是我解决这种情况的方法:class private func instantiateJobDetailsViewController(job: JobModel) {
if let tabBarController = UIApplication.sharedApplication().delegate?.window??.rootViewController as? UITabBarController {
tabBarController.selectedIndex = 0
let currentNavigationController = tabBarController.selectedViewController as! UINavigationController
let currentViewController = currentNavigationController.topViewController!
currentViewController.performSegueWithIdentifier("JobDetailSegue", sender: job)
} else {
ClientHelper.displayAlertAsync("Error", message: "Info for support: cannot present jobDetails view controller", controller: nil)
}
}
所以它基本上是:
>获取标签栏控制器的实例.
>通过设置selectedIndex属性,确保您位于选项卡栏控制器上的相关屏幕中.
>获取导航控制器的实例
>获取导航控制器显示的视图控制器的实例.
通过这种方式,我可以通过推送通知打开相关屏幕,同时a)显示标签栏控制器和b)保留导航元素以允许用户从屏幕导航回来.
