我已经阅读过很多关于这个问题的帖子,但是没有一个能真正帮助我。这似乎很容易做到,但不知怎的,我无法弄明白。
我想在这做什么? 好吧,我向我的应用发送推送通知。一切正常。 当它处于后台时,我可以处理它,不活动,甚至当应用程序没有运行时。 但另一个状态 - 应用程序在前景 - 让我头疼。
我有这个我正在使用的代码片段。一切都很好。 当应用程序在前台运行时,用户将获得UIAlertview。 但是如何向视图按钮添加动作? 我的意思是这个特殊的动作:当有人点击视图按钮时,他/她会被重定向到已经通过推送通知的网址。
就像我之前在代码片段中使用的那样(这部分是准确的):
NSString *notifUrl = [apsInfo objectForKey:@"url"];
NSLog(@"Received Push Url: %@", notifUrl);
我希望这是有道理的,有人可以帮助我。我迷失在这一个......这是与此主题相关的整个代码片段。
-(void)Redirect:(NSString*)url{
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:url]];
NSLog(@"%@",url);
}
/**
* Remote Notification Received while application was open.
*/
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo {
#if !TARGET_IPHONE_SIMULATOR
NSLog(@"remote notification: %@",[userInfo description]);
NSDictionary *apsInfo = [userInfo objectForKey:@"aps"];
NSString *alert = [apsInfo objectForKey:@"alert"];
NSLog(@"Received Push Alert: %@", alert);
NSString *sound = [apsInfo objectForKey:@"sound"];
NSLog(@"Received Push Sound: %@", sound);
AudioServicesPlayAlertSound(kSystemSoundID_Vibrate);
NSString *badge = [apsInfo objectForKey:@"badge"];
NSLog(@"Received Push Badge: %@", badge);
application.applicationIconBadgeNumber = [[apsInfo objectForKey:@"badge"] integerValue];
NSString *notifUrl = [apsInfo objectForKey:@"url"];
NSLog(@"Received Push Url: %@", notifUrl);
// app was already in the foreground
if ( application.applicationState == UIApplicationStateActive ) {
UIAlertView *alertPush = [[UIAlertView alloc]initWithTitle: @"Message"
message: alert
delegate: self
cancelButtonTitle:@"View"
otherButtonTitles: @"Cancel", nil];
[alertPush show];
[alertPush release];
}
// app is inactive or in the background
else {
[self Redirect:notifUrl];
}
#endif
}
// what to do if user taps the viewbutton in push notification alert view
- (void)alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex {
if(buttonIndex == 0) {
NSLog(@"View Button has been tapped");
// We need the url that has been passed by the push notification
}
else {
// Do something
}
}
答案 0 :(得分:4)
只需在.h文件中定义变量notifUrl
,以便您也可以在类的其他方法中访问它。然后将url存储在该变量中,并在alertview委托方法中使用它。
//Add this in .h file
NSString *notifUrl;
//Add this in .m file
-(void)Redirect:(NSString*)url{
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:url]];
NSLog(@"%@",url);
}
/**
* Remote Notification Received while application was open.
*/
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo {
#if !TARGET_IPHONE_SIMULATOR
NSLog(@"remote notification: %@",[userInfo description]);
NSDictionary *apsInfo = [userInfo objectForKey:@"aps"];
NSString *alert = [apsInfo objectForKey:@"alert"];
NSLog(@"Received Push Alert: %@", alert);
NSString *sound = [apsInfo objectForKey:@"sound"];
NSLog(@"Received Push Sound: %@", sound);
AudioServicesPlayAlertSound(kSystemSoundID_Vibrate);
NSString *badge = [apsInfo objectForKey:@"badge"];
NSLog(@"Received Push Badge: %@", badge);
application.applicationIconBadgeNumber = [[apsInfo objectForKey:@"badge"] integerValue];
//Define this variable in .h file so that you can access this in other methods as well
notifUrl = [apsInfo objectForKey:@"url"];
NSLog(@"Received Push Url: %@", notifUrl);
[notifUrl retain]; // this is retain value of notifUrl so that you can use it later
// app was already in the foreground
if ( application.applicationState == UIApplicationStateActive ) {
UIAlertView *alertPush = [[UIAlertView alloc]initWithTitle: @"Message"
message: alert
delegate: self
cancelButtonTitle:@"View"
otherButtonTitles: @"Cancel", nil];
[alertPush show];
[alertPush release];
}
// app is inactive or in the background
else {
[self Redirect:notifUrl];
}
#endif
}
// what to do if user taps the viewbutton in push notification alert view
- (void)alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex {
if(buttonIndex == 0) {
NSLog(@"View Button has been tapped");
NSLog(@"Received Push Url: %@", notifUrl);
[self Redirect:notifUrl];
}
else {
// Do something
}
}