美文网首页shmily-iOS/MaciOSios实用开发技巧
iOS设置translucent引发的导航栏色差和坐标问题

iOS设置translucent引发的导航栏色差和坐标问题

作者: 向晚forever | 来源:发表于2016-11-28 15:43 被阅读6250次

    最近开发项目,在对导航栏barTintColor进行设置时。发现渲染出来的颜色和美工给的效果图会出现偏差,去找了一些资料。发现在iOS7系统以上导航栏多了一个translucent属性。这个属性就是设置导航栏是否具有透明度这个功能。

    translucent属性默认是YES,也就是具有透明属性。所以我们看到的导航栏背景色与美工给的会有很明显的色差。

    有两种解决方案:
    1、取消透明度:

    [[UINavigationBar appearance] setTranslucent:NO];
    self.navigationController.navigationBar.translucent = NO;
    

    这两种设置都可以,一种是全局的,一种是当你只需要在某个Controller上处理。

    2、设置背景图片

    [[UINavigationBar appearance] setBackgroundImage:[UIImage imageNamed:@"navbg-ios7"] forBarMetrics:UIBarMetricsDefault];  // 设置这个会导致搜索框动画抖动
    

    当translucent = YES,controller中self.view的原点是从导航栏左上角开始计算
    当translucent = NO,controller中self.view的原点是从导航栏左下角开始计算

    在translucent = YES的时候,Controller中改变self.view计算原点位置:

    self.edgesForExtendedLayout = UIRectEdgeNone;       //从navigationBar下面开始计算一直到屏幕tabBar上部
    self.edgesForExtendedLayout = UIRectEdgeAll;        //从屏幕边缘计算(默认)
    self.edgesForExtendedLayout = UIRectEdgeTop;        //navigationBar下面开始计算一直到屏幕tabBar上部
    self.edgesForExtendedLayout = UIRectEdgeBottom;     //从navigationBar下面开始计算一直到屏幕底部
    

    在translucent = NO的时候,我试验设置self.edgesForExtendedLayout = UIRectEdgeAll;但是是没有效果的。如果你不想设置背景图,又需要self.view从navgationBar左上角为原点,就只能在对应的Controller:
    self.navigationController.navigationBar.translucent = YES;
    设置这个属性,然后在viewWillDisappear方法中设置回NO,这样就不会影响外面的Controller。

    关于用图片设置会导致搜索框抖动的问题,具体我还没有很好的解决办法。而且我只是在iOS8系统下会出现抖动。当然可以再对应Controller上设置下translucent属性,但是我没有实验过。

    相关文章

      网友评论

      • yakeracles:很棒
      • Andy_WangPeng:#define iOS10 ([[UIDevice currentDevice].systemVersion intValue]>=10?YES:NO)
        -(void)ishiddenNavBarBlackLine:(BOOL)hidden{
        if ([UINavigationBar appearance].translucent) {
        if (iOS10) {
        self.navigationController.navigationBar.subviews[0].subviews[0].hidden = hidden;
        }else{
        self.navigationController.navigationBar.subviews[0].subviews[1].hidden = hidden;
        }

        }else{
        if (iOS10) {
        self.navigationController.navigationBar.subviews[0].subviews[1].hidden = hidden;
        }else{
        self.navigationController.navigationBar.subviews[0].subviews[0].hidden = hidden;
        }
        }
        }
        醉雨清风:你好,你这个设置是隐藏颜色嘛?还是怎么了?
      • W____Y:你的一句话 启发了我。十分感谢您的分享。
      • 壹点微尘:学习了,解决困扰我好长时间的问题!

      本文标题:iOS设置translucent引发的导航栏色差和坐标问题

      本文链接:https://www.haomeiwen.com/subject/feeopttx.html