mirror of
https://github.com/status-im/react-native-blur.git
synced 2025-01-12 17:44:13 +00:00
71b7e59a62
This moves to modern Objective-C practices. Synthesized properties now use property declarations in a private category. UIVisualEffectViews will now only be created once, rather than on each change of blurType. BlurAmount uses a class property to track the currently set amount.
49 lines
1.4 KiB
Objective-C
49 lines
1.4 KiB
Objective-C
#import <UIKit/UIKit.h>
|
|
#import "BlurView.h"
|
|
#import "BlurAmount.h"
|
|
|
|
@interface BlurView ()
|
|
|
|
@property (nonatomic, strong) UIVisualEffectView *visualEffectView;
|
|
@property (nonatomic, strong) UIBlurEffect *blurEffect;
|
|
|
|
@end
|
|
|
|
@implementation BlurView
|
|
|
|
- (instancetype)initWithFrame:(CGRect)frame {
|
|
if (self = [super initWithFrame:frame]) {
|
|
self.blurEffect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleDark];
|
|
self.visualEffectView = [[UIVisualEffectView alloc] initWithEffect:self.blurEffect];
|
|
self.visualEffectView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
|
|
self.visualEffectView.frame = frame;
|
|
|
|
self.clipsToBounds = true;
|
|
|
|
[self addSubview:self.visualEffectView];
|
|
}
|
|
|
|
return self;
|
|
}
|
|
|
|
- (void)setBlurType:(NSString *)blurType
|
|
{
|
|
if ([blurType isEqual: @"xlight"]) {
|
|
self.blurEffect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleExtraLight];
|
|
} else if ([blurType isEqual: @"light"]) {
|
|
self.blurEffect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleLight];
|
|
} else if ([blurType isEqual: @"dark"]) {
|
|
self.blurEffect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleDark];
|
|
} else {
|
|
self.blurEffect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleDark];
|
|
}
|
|
self.visualEffectView.effect = self.blurEffect;
|
|
}
|
|
|
|
- (void)setBlurAmount:(NSNumber *)blurAmount
|
|
{
|
|
[BlurAmount updateBlurAmount:blurAmount];
|
|
}
|
|
|
|
@end
|