iOS 爱奇艺客户端多个tabbar的几种技术实现

栏目: IOS · 发布时间: 7年前

内容简介:本文将讲解实现类似爱奇艺iOS客户端泡泡UI的几种实现以及几种实现可能出现的坑。爱奇艺iOS客户端首页底部有5个按钮UITabBar实现,最右边一个是泡泡按钮,点击泡泡按钮将会push到一个带有UITabBar的界面(第一次见到这种设计)。截止本文发表时爱奇艺iOS客户端版本为V9.10.0,已经改了泡泡界面,不再是push到一个带有UITabBar的界面。

本文将讲解实现类似爱奇艺iOS客户端泡泡UI的几种实现以及几种实现可能出现的坑。

爱奇艺iOS客户端首页底部有5个按钮UITabBar实现,最右边一个是泡泡按钮,点击泡泡按钮将会push到一个带有UITabBar的界面(第一次见到这种设计)。

截止本文发表时爱奇艺iOS客户端版本为V9.10.0,已经改了泡泡界面,不再是push到一个带有UITabBar的界面。

前置条件

1、实现UITabBarControllerDelegate

@interface IQIYITabBarController ()<UITabBarControllerDelegate>

@end

@implementation IQIYITabBarController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    self.delegate = self;
    
}

@end

2、实现 -tabBarController:shouldSelectViewController:方法

- (BOOL)tabBarController:(UITabBarController *)tabBarController shouldSelectViewController:(UIViewController *)viewController{
    
}

第一种实现 使用模态视图

使用模态视图并修改模态视图的弹出动画为push的形式

- (BOOL)tabBarController:(UITabBarController *)tabBarController shouldSelectViewController:(UIViewController *)viewController {
    
    //4是泡泡页面
    if ([viewController isEqual:[tabBarController.viewControllers objectAtIndex:4]]) {
        
        SecondTabBarController * vc = [[SecondTabBarController alloc] init];
        
        CATransition * ansition = [CATransition animation];
        [ansition setDuration:0.25f];
        [ansition setType:kCATransitionMoveIn];
        [ansition setSubtype:kCATransitionFromRight];
        [[UIApplication sharedApplication].keyWindow.layer addAnimation:ansition forKey:nil];
        [self presentViewController:vc animated:NO completion:nil];
        
        return NO;
    }
    
    return YES;
}

模态视图的返回

详情见文末的demo

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    
    self.view.backgroundColor = [UIColor groupTableViewBackgroundColor];
    
    UIBarButtonItem * leftBarButtonItem = [[UIBarButtonItem alloc] initWithTitle:@"返回" style:(UIBarButtonItemStyleDone) target:self action:@selector(back)];
    
    self.navigationItem.leftBarButtonItem = leftBarButtonItem;
}

- (void)back {
    
        CATransition * ansition = [CATransition animation];
        [ansition setDuration:0.25f];
        [ansition setType:kCATransitionMoveIn];
        [ansition setSubtype:kCATransitionFromLeft];
        [[UIApplication sharedApplication].keyWindow.layer addAnimation:ansition forKey:nil];
        [self dismissViewControllerAnimated:NO completion:nil];
}

效果如下图(gif图,如果不会动请刷新)

iOS 爱奇艺客户端多个tabbar的几种技术实现

弊端

gif图可能看的不是很清楚。

弊端就是在push 或者 pop动画执行时会看到黑影闪过,如果要求不高的可以使用这个。

为了解决这个问题,我们引出第二种实现方案

第二种实现 使用UINavigationController push的形式

导航栏push的方式

还是先实现前置条件里的代码

接着实现以下代码

- (BOOL)tabBarController:(UITabBarController *)tabBarController shouldSelectViewController:(UIViewController *)viewController {
    
    //4是泡泡页面
    if ([viewController isEqual:[tabBarController.viewControllers objectAtIndex:4]]) {
        
        SecondTabBarController * vc = [[SecondTabBarController alloc] init];
        vc.hidesBottomBarWhenPushed = YES;
        
        
        UINavigationController * nav = tabBarController.viewControllers[tabBarController.selectedIndex];
        [nav pushViewController:vc animated:YES];
        
        return NO;
    }
    
    return YES;
}

注意事项

要在第二个TabBar里隐藏掉最外层的导航栏,否则将可能出现2个导航栏的效果

- (void)viewWillAppear:(BOOL)animated {
    [super viewWillAppear:animated];
    
    [self.navigationController setNavigationBarHidden:YES animated:animated];
}

- (void)viewWillDisappear:(BOOL)animated {
    [super viewWillDisappear:animated];
    
    [self.navigationController setNavigationBarHidden:NO animated:animated];
}

一定要使用-setNavigationBarHidden:animated:这个方法来显示隐藏导航栏,并且动画效果不要写YES或者NO要用animated,否则将会出现导航栏黑边闪一下或者手势时出现黑边的情况。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

深度学习入门

深度学习入门

[ 日] 斋藤康毅 / 陆宇杰 / 人民邮电出版社 / 2018-7 / 59.00元

本书是深度学习真正意义上的入门书,深入浅出地剖析了深度学习的原理和相关技术。书中使用Python3,尽量不依赖外部库或工具,从基本的数学知识出发,带领读者从零创建一个经典的深度学习网络,使读者在此过程中逐步理解深度学习。书中不仅介绍了深度学习和神经网络的概念、特征等基础知识,对误差反向传播法、卷积神经网络等也有深入讲解,此外还介绍了深度学习相关的实用技巧,自动驾驶、图像生成、强化学习等方面的应用,......一起来看看 《深度学习入门》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器