How to fade a UIVisualEffectView and/or UIBlurEffect in and out?

后端 未结 15 1002
故里飘歌
故里飘歌 2020-12-04 08:38

I want to fade a UIVisualEffectsView with a UIBlurEffect in and out:

var blurEffectView = UIVisualEffectView()
blurEffectView = UIVisualEffectView(effect: UI         


        
相关标签:
15条回答
  • 2020-12-04 09:15

    You can change the alpha of the visual effects view without any problems, other than the warning in the console. The view may appear as simply partially transparent, rather than blurred. But this usually isn't a problem if you're just changing the alpha during animation.

    Your app isn't going to crash or get rejected for this. Test it on a real device (or eight). If you're happy with how it looks and performs, it's fine. Apple's just warning you that it may not look or perform as well as a visual effects view with an alpha value of 1.

    0 讨论(0)
  • 2020-12-04 09:20

    I just had this problem and the way I got around it was to house the UIVisualEffectsView in a UIView, and animate that UIView's alpha.

    This worked well, except that it as soon as the alpha changed below 1.0 it turned to a solid white and looked very jarring. In order to get around this, you must set the UIView's layer property containerView.layer.allowsGroupOpacity = false and this will prevent it from flashing white.

    Now you can animate in/fade out the UIView containing the visual effects view and any other subviews using it's alpha property and not have to worry about any graphical glitches or it logging a warning message.

    0 讨论(0)
  • 2020-12-04 09:20
    _visualEffectView.contentView.alpha = 0;
    

    To change the alpha of UIVisualEffectView, you should change the contentView of _visualEffectView.If you change alpha of _visualEffectView, you will get this

    <UIVisualEffectView 0x7ff7bb54b490> is being asked to animate its opacity. This will cause the effect to appear broken until opacity returns to 1.
    
    0 讨论(0)
  • 2020-12-04 09:21

    If you want to fade in you UIVisualEffectView - for ios10 use UIViewPropertyAnimator

        UIVisualEffectView *blurEffectView = [[UIVisualEffectView alloc] initWithEffect:nil];
        blurEffectView.frame = self.view.frame;
        blurEffectView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
    
        UIView *blackUIView = [[UIView alloc]initWithFrame:self.view.frame];
        [bacgroundImageView addSubview:blackUIView];
        [blackUIView addSubview:blurEffectView];
        UIViewPropertyAnimator *animator  = [[UIViewPropertyAnimator alloc] initWithDuration:4.f curve:UIViewAnimationCurveLinear animations:^{
            [blurEffectView setEffect:[UIBlurEffect effectWithStyle:UIBlurEffectStyleDark]];
        }];
    

    then you can set percent

    [animator setFractionComplete:percent];
    

    for ios9 you can use alpha component

    0 讨论(0)
  • 2020-12-04 09:22

    The alpha of the UIVisualEffectView always has to be 1. I think you can achieve the effect by setting the alpha of the background color.

    Source : https://developer.apple.com/library/ios/documentation/UIKit/Reference/UIVisualEffectView/index.html

    0 讨论(0)
  • 2020-12-04 09:23

    I think this is new in iOS9, but you can now set the effect of a UIVisualEffectView inside an animation block:

    let overlay = UIVisualEffectView()
    // Put it somewhere, give it a frame...
    UIView.animate(withDuration: 0.5) {
        overlay.effect = UIBlurEffect(style: .light)
    }
    

    Set it to nil to remove.

    VERY IMPORTANT - When testing this on the simulator, make sure to set your simulator's Graphics Quality Override to High Quality in order for this to work.

    0 讨论(0)
提交回复
热议问题