隐藏UITabbar 但原位置 添加按键 不响应 原因 解析

今天做一个需求,需求是关于允许游客登录主界面去观看免费课程,但对于一些关系用户个人的操作就需要登录。界面如下所示:

image.png

因此就需要在主界面,判断如果是游客身份,就隐藏tabbar,显示登录提示按键,当点击按键弹出登录界面。这是遇到一个问题,就是隐藏了tabbar,添加登录提示按键,但是按键的点击事件没有响应,因此特地记录下。

1. 原因

按键之所以没响应,原因有两个:

  • viewControlleredgesForExtendedLayout属性被设置为UIRectEdgeNone
  • self.tabBarController.tabBarbackgroundImage 被设置了背景图片。

2. 解释

  • edgesForExtendedLayout 是IOS7中,苹果引入的关于 UIViewController新属性,它的默认值为UIRectEdgeAll,意思就是向四周边缘均延伸,如果viewController的容器中上有 navigationBar,下有tabbar,那 viewController的view就会覆盖到四周的区域。如下图所示:

image-UIRectEdgeAll.png

但一般为了视图不延伸到navigationBar上面和tabbar下面,因此edgesForExtendedLayout都会设置为UIRectEdgeNone,如下图所示:

image-UIRectEdgeNone.png

所以很明显,如果想要登录提示按键在tabbar位置上响应,就应该让viewControllerview范围覆盖tabbar 位置,因此edgesForExtendedLayout就应该设置为UIRectEdgeAllUIRectEdgeBottom

  • tabbarbackgroundImage 设置背景图片,这时候设置edgesForExtendedLayout 的属性为UIRectEdgeAll,并设置tabbar的背景色的透明度为0.9,显示结果如下图所示:
image-backgroundImage.png

可以看到由于设置了tabbar的背景图片,所以无法看到延伸下来的红色view视图,

这是将tabbar隐藏,self.tabBarController.tabBar.hidden = YES;,如下图所示:

image-hide-tabbar.png

可以看到tabbarbackgroundImage还是显示在tabbar的位置上,因此导致了登录提示按键没有响应。
当设置self.tabBarController.tabBar.backgroundImage = nil;,如果所示:

image-backgroundImage-nil.png

就可以看到viewControllerview覆盖了tabbar的位置。

3. 最后

送上一张图片:

16_21128_5.jpg
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容