当我的应用程序捕获远程通知时,我尝试打开一个特定的ViewController.
当我收到通知时,我想打开一个“SimplePostViewController”,所以这是我的appDelegate:
var window: UIWindow? var navigationVC: UINavigationController? func application(application: UIApplication,didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool { let notificationTypes: UIUserNotificationType = [UIUserNotificationType.Alert,UIUserNotificationType.Badge,UIUserNotificationType.sound] let pushNotificationSettings = UIUserNotificationSettings(forTypes: notificationTypes,categories: nil) let storyboard = UIStoryboard(name: "Main",bundle: nil) self.navigationVC = storyboard.instantiateViewControllerWithIdentifier("LastestPostsNavigationController") as? UINavigationController application.registerUserNotificationSettings(pushNotificationSettings) application.registerForRemoteNotifications() return true } func application(application: UIApplication,didReceiveRemoteNotification userInfo: [NSObject : AnyObject]) { if let postId = userInfo["postId"] as? String { print(postId) let api = EVwordpressAPI(wordpressOauth2Settings: wordpress.wordpressOauth2Settings,site: wordpress.siteName) api.postById(postId) { post in if (post != nil) { self.navigationVC!.pushViewController(SimplePostViewController(),animated: true) } else { print("An error occurred") } } } }
我在应用程序启动时保存了我的UINavigationViewController,并在收到通知时尝试推送新的SimplePostViewController.但什么都没发生.
我放置断点并看到我的pushViewController方法已到达,但不是我的SimplePostViewController的ViewWillAppear.
我还使用了“什么是新的”视图添加执行我的segue但也没有发生任何事情.
方案:
for child in (self.rootViewController?.childViewControllers)! { if child.restorationIdentifier == "LastestPostsNavigationController" { let lastestPostsTableViewController = (child.childViewControllers[0]) as! LastestPostsTableViewController let simplePostVC = (self.storyboard?.instantiateViewControllerWithIdentifier("PostViewController"))! as! PostViewController simplePostVC.post = post lastestPostsTableViewController.navigationController?.pushViewController(simplePostVC,animated: true) } }
我用 :
child.childViewControllers[0]
因为我的例子里只有一个孩子.
解决方法
我创建了一个带有本地通知而不是远程通知的示例项目,以便于显示功能,但它应该像在app delegate didreceiveremote通知中设置窗口的根视图控制器一样简单.
func application(application: UIApplication,didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool { // Subscribe for notifications - assume the user chose yes for Now application.registerUserNotificationSettings(UIUserNotificationSettings(forTypes: [.Alert,.Badge,.sound],categories: nil)) return true } func applicationDidEnterBackground(application: UIApplication) { //Crete a local notification let notification = UIlocalnotification() notification.alertBody = "This is a fake notification" notification.fireDate = NSDate(timeIntervalSinceNow: 2) UIApplication.sharedApplication().schedulelocalnotification(notification) } func application(application: UIApplication,didReceivelocalnotification notification: UIlocalnotification) { let sb = UIStoryboard(name: "Main",bundle: nil) let otherVC = sb.instantiateViewControllerWithIdentifier("otherVC") as! OtherViewController window?.rootViewController = otherVC; } func application(application: UIApplication,didReceiveRemoteNotification userInfo: [NSObject : AnyObject]) { //Your code here }
`
您需要担心管理视图层次结构并向其发送需要从通知用户数据发送的任何内容.
在我的示例中,当您关闭在视图秒后触发的应用程序时,我会创建本地通知.如果您随后从通知中启动应用程序,它将打开“其他视图控制器”,在您的情况下将是“SimplePostViewController”.
另外,请确保在didFinishLaunchWithOptions中注册远程通知.
Github非常简单的样本:https://github.com/spt131/exampleNotificationResponse
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。