一. 背景
之前toastView
改版,然后基础架构组的同事重写了下,使用过程中发现,加在window
上的toastView
,竟然被present
出来的登录页面给挡住了,基于这个问题进行了分析,并将相应的原因记录下。
二. 定位问题与分析
经定位调试,我们可以发现在iOS13
及以上的系统,present
出来的vc
也是直接加载window
上,所以导致了将toastView
覆盖住。
我们可以看下demo
:
我们在FJFWindowViewController
的view
上添加一个红色按钮,点击present
到FJFPresentViewController
页面,然后将一个黑色view
添加到当前应用的window
上,看下present
出来的FJFPresentViewController
是否会遮住黑色view
.
从实验结果,我们很容易看出,present
出来的FJFPresentViewController
遮住了黑色的view
。
我们再来看一下视图的层级,发现FJFPresentViewController
也是添加到window
上的,而且按照栈的添加顺序,显示在前面,所以盖住了黑色的view
。
我们从打印的日志也可以看出来:
这是iOS13
及以上系统会这样,那如果是iOS13
一下系统是怎样的呢?
我们选中iOS11.4
的模拟器系统:
我们可以看到present
出来的FJFPresentViewController
显示在黑色view
下面。
我们再来看下视图的层级:
从这个视图的层级看,黑色视图是在FJFPresentViewController
下面,但实际显示黑色view
确显示在上面,所以可能是xcode
的这个视图层级有问题。
于是我们通过代码打印window
的子视图数组,看下真正的顺序是怎样的。
我们可以看到黑色view
是显示最上面的,这跟实际的结果正好相符合。
三. 总结
-
在iOS13
及以上系统,之所以会出现present
出来的vc
挡住了加载window
上的toastView
,原因在于iOS13
及以上系统,present
出来的vc
,也是单独加载window
上导致的,因为iOS13
及以上系统,present
添加了半弹框的样式,所以将present
出来的vc
添加方式做了修改,直接添加到window
上。 -
iOS13
以下的系统,由于present
出来的vc
都是直接盖住当前视图,没有半弹框的样式,所以present
出来的vc
是直接替换了原来的navigationVc
,而添加到window
上的toastView
,依然显示在最前方。
四. 解决方法
- 如果想让toastView显示在最前方,可以通过
window
的bringSubviewToFront
将toastView
显示在最前方。