启动特定的viewController以响应远程推送通知

时间:2013-02-13 20:56:38

标签: ios uiviewcontroller push-notification apple-push-notifications

我正在创建一个应用程序,其故事板的流程如下图所示:

storyboard

当用户从“Sysalert View Controller”登录时,它们会进入“消息列表视图控制器”,我在其中执行NSURLConnection以将一些JSON加载到表中。当用户点击表格中的一行时,它们会进入“消息详细信息”,其中显示该消息的更多详细信息。

当用户从推送通知启动应用程序时,无论启动之前应用程序的状态如何,我都希望应用程序从我的服务器加载“消息列表”数据,然后向他们显示刚被推送的消息到设备。

我知道我需要使用didFinishLaunchingWithOptions告诉应用程序对推送通知作出反应,但是如何设置视图层次结构以便“消息列表”视图控制器加载其数据然后按“消息”详细信息“将控制器查看到堆栈以获取相应的消息?

基本上这种模仿消息或邮件应用程序的行为。如果打开通知会将您带到该消息的视图控制器,但您仍然可以在层次结构中向后移动,就像您从初始viewController启动应用程序并依次遍历viewControllers一样。

2 个答案:

答案 0 :(得分:8)

可以按照你的描述做,但我不推荐它。

首先,将断开连接的视图控制器与故事板中所需的视图放在一起,为视图控制器提供一个标识符,例如“我的推送通知视图”

didFinishLaunchingWithOptions:中,您可以从app委托进入rootViewController。该控制器将是导航控制器。使用导航控制器,您可以在堆栈顶部推送新的视图控制器。要创建新的视图控制器,请使用标识符“My Push Notification View”实例化视图控制器。

UINavigationController *navController = (UINavigationController *)self.window.rootViewController;
UIViewController *notificationController = [navController.storyboard instantiateViewControllerWithIdentifier:@"My Push Notification View"];

[navController pushViewController:notificationController animated:YES];

我认为你会想要使用类似-presentViewController:animated:completion:的东西来显示模态视图,而不是打断导航堆栈。

UIViewController *rootController = (UIViewController *)self.window.rootViewController;
UIViewController *notificationController = [rootController.storyboard instantiateViewControllerWithIdentifier:@"My Push Notification View"];

[rootController presentViewController:notificationController animated:YES completion:NULL];

答案 1 :(得分:4)

试试我在我的一个应用程序中使用,用户将app委托中的变量作为全局

 ex: BOOL gotNotifcation;

-(void)application:(UIApplication*)app didReceiveRemoteNotification:(NSDictionary *)userInfo
{
    NotificationsViewController *notificationobject = [[NotificationsViewController alloc]init];
    [self.navigationController pushViewController:notificationobject animated:YES];
    gotNotifcation = YES;   
}

在NotificationsViewController中,如果是自定义按钮

,则返回后退按钮操作
-(void)gotoback
{
    AppDelegate *delegate =(AppDelegate *)[UIApplication sharedApplication].delegate;

    if(delegate.gotNotifcation)
    {
        delegate.gotNotifcation = NO;
        MessageListController *feed = [[MessageListController alloc] init];
        [self.navigationController pushViewController:feed animated:NO];
    }
    else
    {
        [self.navigationController popViewControllerAnimated:NO];
    }
}