iOS刚进入后台接受推送、打开推送调转到相应的界面
刚进入后台的时候消息处理时候我用了本地推送!可以看我前边写的博客,怎么处理刚进入后台接收推送的案例,链接
/**
注释:打开推送的三种方式:-peter
1、apns的时候,结束进程退出后台:启动的时候可在 didFinishLaunchingWithOptions的launchOptions中处理;
获取字典 launchOptions 中的 UIApplicationLaunchOptionsRemoteNotificationKey的key
NSDictionary *optionsRemoteNotificationKey = [launchOptions dictionaryValueForKey:@"UIApplicationLaunchOptionsRemoteNotificationKey"];
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
/**二次启动获得推送点击信息,本地储存二次启动的内容 仿qq点击推送栏启动 by peter***/
NSDictionary *optionsRemoteNotificationKey = [launchOptions dictionaryValueForKey:@"UIApplicationLaunchOptionsRemoteNotificationKey"];
[[NSUserDefaults standardUserDefaults] setObject:optionsRemoteNotificationKey forKey:kSavePushMessage];
/**为了验证第一次启动的时候不能截获启动信息,加啊alert**/
/**
NSString * str = [NSString stringWithFormat:@"%@",launchOptions];
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
UIAlertView *art = [[UIAlertView alloc]initWithTitle:nil message:str delegate:self cancelButtonTitle:@"取消" otherButtonTitles: nil];
[art show];
});
**/
return YES;
}
2、apns的时候,结束进程未退出后台:启动的时候可在 didReceiveRemoteNotification的userInfo中处理;
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo
{
NSString * appData = [userInfo stringValueForKey:@"appData"];
NSData *jsonData = [appData dataUsingEncoding:NSUTF8StringEncoding];
NSError *err;
NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:jsonData
options:NSJSONReadingMutableContainers
error:&err];
if(err)
{
NSLog(@"json解析失败:%@",err);
}else{
NSString * positionIdString = [NSString stringWithFormat:@"%@",[dic numberValueForKey:@"positionId"]] ;
if ([dic numberValueForKey:@"positionId"] !=0) {
[[NSNotificationCenter defaultCenter] postNotificationName:kString_DispantData object:positionIdString];
}
}
}
3、本地推送,未结束进程未退出后台(此方达为了解决消息刚进入后台时候没有通知的情况):启动的时候可在 didReceiveLocalNotification的notification中处理;
- (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification{
NSDictionary *dic = notification.userInfo;
NSString * positionIdString = [dic stringValueForKey:@"positionId"];
if (![positionIdString isEqualToString:@""]) {
[[NSNotificationCenter defaultCenter] postNotificationName:kString_DispantData object:positionIdString];
}
}
**/
二、处理页面跳转功能
说明:由于情况1都代表app已经结束需要重新启动,只能做本地存储,然后到tabbar页面的时候取出该存储值的对应id然后进行跳转。情况2、3 ,App的tabbar页面已经存在可以注册一个通知在2、3的情况时候发送通知!
1、存储调转
在tabbar的viewDidAppear方法
- (void)viewDidAppear:(BOOL)animated
{
[super viewDidAppear:animated];
NSDictionary *optionsRemoteNotificationKey = [[NSUserDefaults standardUserDefaults] objectForKey:kSavePushMessage];
NSString *appDataString = [optionsRemoteNotificationKey stringValueForKey:@"appData"];
if (appDataString&&![appDataString isEqualToString:@""]) {
[[NSUserDefaults standardUserDefaults] setObject:nil forKey:kSavePushMessage];
}
}
2、通知跳转
注册监听tabbar的viewDidLoad方法里边
- (void)viewDidLoad
{
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(pushDispanchPositionDetail:) name:kString_DispantData object:nil];
}
方法接收
#pragma mark observer Notification
-(void)pushDispanchPositionDetail:(NSNotification *)notify
{
if (notify.object&&![notify.object isEqualToString:@""]) {
[self pushData:notify.object];
}
}
- (void)pushData:(NSString *)positionId{
[self setSelectedIndex:MainTabBarIndex_User];
RootNavigationController* selNavi = [self.viewControllers objectAtIndex:MainTabBarIndex_User];
HHPositionDetailC *vc = [[HHPositionDetailC alloc] init];
vc.positionId = [positionId longLongValue];
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.25 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
selNavi.toolbar.hidden = YES;
[selNavi pushViewController:vc animated:YES];
HDMyPositionViewController *myPositionVC = [[HDMyPositionViewController alloc]init];
NSMutableArray *mutArray = [NSMutableArray arrayWithArray:selNavi.viewControllers];
[mutArray insertObject:myPositionVC atIndex:1];
selNavi.viewControllers = [mutArray copy];
});
}
详细解释跳转代码
[self setSelectedIndex:MainTabBarIndex_User];
RootNavigationController* selNavi = [self.viewControllers objectAtIndex:MainTabBarIndex_User];
HHPositionDetailC *vc = [[HHPositionDetailC alloc] init];
vc.positionId = [positionId longLongValue];
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.25 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
selNavi.toolbar.hidden = YES;
[selNavi pushViewController:vc animated:YES];
HDMyPositionViewController *myPositionVC = [[HDMyPositionViewController alloc]init];
NSMutableArray *mutArray = [NSMutableArray arrayWithArray:selNavi.viewControllers];
[mutArray insertObject:myPositionVC atIndex:1];
selNavi.viewControllers = [mutArray copy];
});
1、找到所进入的viewController的根导航Navigation;然后进行选中(self代表tabbar) [self setSelectedIndex:MainTabBarIndex_User];
2、然后延迟调转,由于初始化tababr的原因不延迟跳转会出现调转不进去的情况;所以做延迟跳转处理。
[selNavi pushViewController:vc animated:YES];
3、找到当前的viewControllers数组,创建需要返回的二级页面加入栈中!
这样就能点推送进入C,返回B,在返回所需要的tabbar的某个界面。
iOS刚进入后台接受推送、打开推送调转到相应的界面的更多相关文章
- IM-iOS退出后台接受消息,app退出后台能接收到推送
App被失活状态的时候可以走苹果的APNS:但是在活跃的时候却接受不到推送! 那就用到本地推送:UILocalNotification 消息神器. 处理不好可能会有很多本地推送到来,那么问题来了要在什 ...
- android系统和ios系统是如何实现推送的,ios为什么没有后台推送
ios系统为什么没有后台推送? iOS 为了真正地为用户体验负责,不允许应用在后台活动.有了这个限制,但是对于终端设备,应用又是有必要“通知”到达用户的,随时与用户主动沟通起来的(典型的如聊天应用). ...
- Android P正式版即将到来:后台应用保活、消息推送的真正噩梦
1.前言 对于广大Android开发者来说,Android O(即Android 8.0)还没玩热,Andriod P(即Andriod 9.0)又要来了. 下图上谷歌官方公布的Android P ...
- iOS 之消息推送(个推)---个人小结
前言:自从上个星期开始整这个推送,弄了差不多一个星期,今天终于给整好了,因此现在来记录这段"奇妙"的旅程. 我们公司使用的消息推送是用的第三方--个推,这里不得不说一下,个推的技术 ...
- 最新的极光推送服务器端代码(java服务器后台向手机端自定义推送消息)
一共两个类 一个Jdpush 一个JpushClientUtil 代码如下 注解都写的很清楚 package com.sm.common.ajpush; import org.slf4j.Log ...
- Android实现点击通知栏后,先启动应用再打开目标Activity ,极光推送等推送的也可以参考一下(转)
我因为项目中集成了极光推送,推送的通知栏点开需要确定进入哪个界面就参考了这边文章,感谢作者的无私. 标签: 情况简述 在开发Android app的过程中,遇到这样一个需求:app中启动一个Servi ...
- IOS中程序如何进行推送消息(本地推送,远程推送)2(上)
未看过本地推送的,可以提前看一下本地推送. http://www.cnblogs.com/wolfhous/p/5135711.html =============================== ...
- Android 后台应用保活、消息推送
3.针对以往Android版本的各种保活技术回顾 Android P之前为了搞定客户的投诉:“为什么微信能收到消息而你们的IM却不能?”,为了解决这个“痛点”,广大的Android开发者们只能让各种黑 ...
- iOS和Android后台机制对比
转自:http://blog.csdn.net/zsch591488385/article/details/27232881 一.iOS的“伪后台”程序 首先,先了解一下ios 中所谓的「后台进程」到 ...
随机推荐
- (MonoGame从入门到放弃-3)-放弃MonoGame
又一段时间过去了,这一章没内容了.我真的已经放弃MonoGame的学习了,MonoGame用起来感觉就是在自己实现2d游戏引擎一样,好多现代游戏引擎有的内容都没有...,我只是想做游戏,而不是给引擎添 ...
- 思科ASA5520防火墙telnet、SSH及DHCP设置
ASA5520远程登录telnet 注:最低安全级别的接口不支持telnet登陆,如OutsideASA(config)# telnet 172.16.0.0 255.255.0.0 inside ...
- 【java学习笔记】线程
1.线程的定义 ①继承Thread类,将执行的任务逻辑放到run方法中,调用start方法来开启线程 public class ThreadDemo { public static void main ...
- linux 搭建CA服务器 http+ssl mail+ssl 扫描与抓包
搭建CA服务器 CA服务是给服务器发放数字证书,被通信双方信任,独立的第三方机构 国内常见的CA机构 中国金融认证中心(CFCA) 中国电信安全认证中心(CTCA) 北京数字证书认证中心(BJCA) ...
- Shell脚本编程学习入门 02
Shell脚本编程学习入门是本文要介绍的内容,我们可以使用任意一种文字编辑器,比如gedit.kedit.emacs.vi等来编写shell脚本,它必须以如下行开始(必须放在文件的第一行): #! ...
- Android HotFix动态加载框架介绍
HotFix(Deprecated) https://github.com/dodola/HotFix 请关注 RocooFix 我重新写了一个RocooFix框架,解决了Nuwa因为Gradle1. ...
- mysql常用基础操作语法(九)~~外连接查询【命令行模式】
1.左外连接left outer join或者left jion,outer可以省略不写,下边的右连接和全连接也一样: 左外连接的意思是,以left join左边的表中的数据为基准,即左边的表中有的必 ...
- Linux以字节显示内存大小
Linux以字节显示内存大小 youhaidong@youhaidong-ThinkPad-Edge-E545:~$ free -b total used free shared buffers ca ...
- DirectX--Filter属性页的调用
IEnumFilters* pEnum; HRESULT hr ; if (pigb) { hr = pigb-> EnumFilters(&pEnum); if (FAILED(hr) ...
- px单位html5响应式方案
移动端h5响应式方案最近这几年用得最多的最多的就是rem方案了.这个需要计算根元素的font-size来实现响应式. 但这种方案也有一个缺点,那就是font-size不为整数的时候一些字体使用rem单 ...