需求:从通信录点击到人物详情页面,点击聊天后进入聊天详情页面 ,进入聊天详情后 点击返回后或者是向右滑动返回,都要回到消息列表而不是回到人物详情页面!微信
那到需求后,仔细研究了下微信的作法,发现微信从人物详情页面跳转到聊天详情后,返回按钮显示的字是 "消息" 而不是 "人物详情" 因此想到其实他是从消息页面推过去的.(其实在这以前我尝试了许多方法,没有成功而已.....) .ide
刚开始使用的是通知 post
// NSMutableDictionary *dict = @{}.mutableCopy; // [dict setObject:[self.otherId description] forKey:@"otherId"] ; // [dict setObject:[self.userInfoDic objectForKey:@"user_name"] forKey:@"groupName"]; // [[NSNotificationCenter defaultCenter] postNotificationName:@"pushToChatVC" object:nil userInfo:dict]; // // [self.tabBarController setSelectedIndex:2]; // [self.navigationController popToRootViewControllerAnimated:NO];
在发送消息的时候发送了一条通知 , 而后在消息列表页面添加了观察者:动画
//- (void)push2ChnatVC:(NSNotification *)noti { // ChatViewController *chatView = [[ChatViewController alloc] initWithChatter:noti.userInfo[@"otherId"] isGroup:NO]; // chatView.groupName = noti.userInfo[@"groupName"]; // chatView.hidesBottomBarWhenPushed = YES; // [self.navigationController pushViewController:chatView animated:YES]; //}
这种方法能够大体实现这种效果,第一次的时候推页面的时候还有动画,后面不知为什么莫名的没有了动画效果....code
通过挣扎以后又想到了另一个方法,(其实一开始就应该想到的,也不用费这么大劲了..)orm
可使用tabbarController的子viewController(NavigationController)来直接推啊.!!!图片
具体实现以下: ip
ChatViewController *chatVC = [[ChatViewController alloc] initWithChatter: [NSString stringWithFormat:@"%@", self.otherId] isGroup:NO]; chatVC.groupName = [self.userInfoDic objectForKey:@"user_name"]; chatVC.hidesBottomBarWhenPushed = YES; HXNavigationController *nav = self.tabBarController.viewControllers[2]; chatVC.groupName = [self.userInfoDic objectForKey:@"user_name"]; chatVC.hidesBottomBarWhenPushed = YES; self.tabBarController.selectedViewController = nav; [self.navigationController popToRootViewControllerAnimated:NO]; [nav pushViewController:chatVC animated:YES];
点击消息 先拿到消息列表的导航,而后使用该导航push ChatVC ,而后再 [self.navigationController popToRootViewControllerAnimated:NO]; 这样就能够保证通信录导航的栈内就只有rootVC了,这样一来 再点击通信录的时候依然是通信录的主页面.string
从消息列表push过去后 ChatVC 的右tabbarItem 就显示消息,点击消息返回或者向右滑动返回就能够顺利的切换到消息列表了..! it
如此就能够轻松的实现像微信同样 从聊天列表直接跳转到消息列表了!!!而且支持滑动手势.
注:用这种方法须要先跳到列表页,而后从列表页推界面,因此有那么一瞬间是能看到消息列表的(时间很短).. 而微信作的效果则是 看起来跟从人物详情页跳转到聊天列表同样 . 因此我猜测他们应该是在跳转以前将详情页面截图,而后放到消息列表页面,而后再跳转到聊天页面(跳转成功以后把图片移除).这样一来看起来就跟直接从人物详情页面直接跳转同样了.
经过此次问题解决让我对 tabbarController的子控制器以及导航的子控制器都是那些,以及他们的声明周期如何了解的更深入了! 之后再遇到相似问题就能顺利的解决了,嘿嘿嘿!