(由于最初的错误标题而重新发布) 当用户收到我们的应用程序的推送通知(并点击它)时,应用程序应打开详细信息屏幕.从导航角度来看,应用程序通常在用户打开时随时都有此结构: 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)保留导航元素以允许用户从屏幕导航回来.