iOS 高斯模糊黑屏
最近发现高斯模糊在一些设备上会黑屏。
高斯模糊代码:
UIImageView *imageView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"test.png"]];
imageView.frame = [UIScreen mainScreen].bounds;
[self.view addSubview:imageView];
UIBlurEffect *blurEffect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleDark];
UIVisualEffectView *blurEffectView = [[UIVisualEffectView alloc] initWithEffect:blurEffect];
其中一个是iPhone 7 plus 对应 iOS 11.4.1(15G77)上效果如下:
data:image/s3,"s3://crabby-images/c5cc8/c5cc8c501d75b331997d50be48028a27d4590ccc" alt=""
其中另一个正常设备截图如下:
data:image/s3,"s3://crabby-images/e1f94/e1f942eb3a7993c1afd55be78c3681eed27960a7" alt=""
发现同样代码,在某些设备上效果不一样。于是开始分析:
data:image/s3,"s3://crabby-images/6b0f8/6b0f8e14cb76c55420e53b0789dba112671f9835" alt=""
data:image/s3,"s3://crabby-images/3b813/3b8131446defb9521f775156e02576b6b5154a87" alt=""
看不到背景时
发现看不到背景是因_UIVisualEffectSubview 黑屏导致。_UIVisualEffectBackdropView 继承 _UIVisualEffectSubview
data:image/s3,"s3://crabby-images/959c7/959c7e0a3d86aad366b9e90a7e45fd1e596d9e59" alt=""
改成:
UIBlurEffect *blurEffect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleDark];
UIVisualEffectView *blurEffectView = [[UIVisualEffectView alloc] initWithEffect:blurEffect];
for (UIView *view in blurEffectView.subviews) {
if (![view isKindOfClass:NSClassFromString(@"_UIVisualEffectBackdropView")]) {
view.alpha = 0.8;
}
}
blurEffectView.frame = self.view.bounds;
[self.view addSubview:blurEffectView];
效果如下:
_UIVisualEffectSubview
data:image/s3,"s3://crabby-images/865c3/865c3d66340fdf56a7a97e14a165cb452b2821cc" alt=""
不正常状态下_UIVisualEffectSubview:
data:image/s3,"s3://crabby-images/e410e/e410e4e1e0a8ad35ccc153a5c81f0c0ca528ca44" alt=""
不正常状态下_UIVisualEffectBackdropView
data:image/s3,"s3://crabby-images/fc794/fc794d7885ad0727524437e92c7fe91579f7a5e4" alt=""
正常状态时_UIVisualEffectSubview:
data:image/s3,"s3://crabby-images/e3806/e380636d54f698e4c7af7af85616b70b0ea0bd85" alt=""
正常状态下_UIVisualEffectBackdropView:
data:image/s3,"s3://crabby-images/f87ae/f87aecf8888ce7a3794dca2187ec02e2a3e6a723" alt=""
对比两个图发现,正常状态下
_UIVisualEffectSubview 和 不正常状态下_UIVisualEffectSubview的状态基本一致。但是 _UIVisualEffectBackdropView 的正常状态和非正常状态的 _filters 数组元素个数不一样。背景不透明的时候_filters只有一个gaussianBlur特效。正常情况下_filters 有两个特效分别是gaussianBlur 和 colorSaturate。
解决办法:
UIBlurEffect *blurEffect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleDark];
UIVisualEffectView *blurEffectView = [[UIVisualEffectView alloc] initWithEffect:blurEffect];
for (UIView *view in blurEffectView.subviews) {
if (![view isKindOfClass:NSClassFromString(@"_UIVisualEffectBackdropView")]) {
view.alpha = 0.8;
}
}
blurEffectView.frame = self.view.bounds;
[self.view addSubview:blurEffectView];