mirror of
https://github.com/status-im/react-native-blur.git
synced 2025-01-13 01:54:15 +00:00
164 lines
5.9 KiB
Objective-C
164 lines
5.9 KiB
Objective-C
#import "BlurView.h"
|
|
#import "BlurEffectWithAmount.h"
|
|
|
|
@interface BlurView ()
|
|
|
|
@end
|
|
|
|
@implementation BlurView
|
|
|
|
- (instancetype)init
|
|
{
|
|
if (self = [super init]) {
|
|
[[NSNotificationCenter defaultCenter] addObserver:self
|
|
selector:@selector(reduceTransparencyStatusDidChange:)
|
|
name:UIAccessibilityReduceTransparencyStatusDidChangeNotification
|
|
object:nil];
|
|
}
|
|
|
|
return self;
|
|
}
|
|
|
|
- (instancetype)initWithFrame:(CGRect)frame
|
|
{
|
|
if (self = [super initWithFrame:frame]) {
|
|
self.blurEffectView = [[UIVisualEffectView alloc] init];
|
|
self.blurEffectView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
|
|
self.blurEffectView.frame = frame;
|
|
|
|
self.reducedTransparencyFallbackView = [[UIView alloc] init];
|
|
self.reducedTransparencyFallbackView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
|
|
self.reducedTransparencyFallbackView.frame = frame;
|
|
|
|
self.blurAmount = @10;
|
|
self.blurType = @"dark";
|
|
[self updateBlurEffect];
|
|
[self updateFallbackView];
|
|
|
|
self.clipsToBounds = true;
|
|
|
|
[self addSubview:self.blurEffectView];
|
|
}
|
|
|
|
return self;
|
|
}
|
|
|
|
- (void)dealloc
|
|
{
|
|
[[NSNotificationCenter defaultCenter] removeObserver:self];
|
|
}
|
|
|
|
- (void)layoutSubviews
|
|
{
|
|
[super layoutSubviews];
|
|
self.blurEffectView.frame = self.bounds;
|
|
self.reducedTransparencyFallbackView.frame = self.bounds;
|
|
}
|
|
|
|
- (void)setBlurType:(NSString *)blurType
|
|
{
|
|
if (blurType && ![self.blurType isEqual:blurType]) {
|
|
_blurType = blurType;
|
|
[self updateBlurEffect];
|
|
}
|
|
}
|
|
|
|
- (void)setBlurAmount:(NSNumber *)blurAmount
|
|
{
|
|
if (blurAmount && ![self.blurAmount isEqualToNumber:blurAmount]) {
|
|
_blurAmount = blurAmount;
|
|
[self updateBlurEffect];
|
|
}
|
|
}
|
|
|
|
- (void)setReducedTransparencyFallbackColor:(nullable UIColor *)reducedTransparencyFallbackColor
|
|
{
|
|
if (reducedTransparencyFallbackColor && ![self.reducedTransparencyFallbackColor isEqual:reducedTransparencyFallbackColor]) {
|
|
_reducedTransparencyFallbackColor = reducedTransparencyFallbackColor;
|
|
[self updateFallbackView];
|
|
}
|
|
}
|
|
|
|
- (UIBlurEffectStyle)blurEffectStyle
|
|
{
|
|
if ([self.blurType isEqual: @"xlight"]) return UIBlurEffectStyleExtraLight;
|
|
if ([self.blurType isEqual: @"light"]) return UIBlurEffectStyleLight;
|
|
if ([self.blurType isEqual: @"dark"]) return UIBlurEffectStyleDark;
|
|
|
|
#if defined(__IPHONE_OS_VERSION_MAX_ALLOWED) && __IPHONE_OS_VERSION_MAX_ALLOWED >= 100000 /* __IPHONE_10_0 */
|
|
if ([self.blurType isEqual: @"regular"]) return UIBlurEffectStyleRegular;
|
|
if ([self.blurType isEqual: @"prominent"]) return UIBlurEffectStyleProminent;
|
|
#endif
|
|
|
|
#if defined(__IPHONE_OS_VERSION_MAX_ALLOWED) && __IPHONE_OS_VERSION_MAX_ALLOWED >= 130000 /* __IPHONE_13_0 */
|
|
// Adaptable blur styles
|
|
if ([self.blurType isEqual: @"chromeMaterial"]) return UIBlurEffectStyleSystemChromeMaterial;
|
|
if ([self.blurType isEqual: @"material"]) return UIBlurEffectStyleSystemMaterial;
|
|
if ([self.blurType isEqual: @"thickMaterial"]) return UIBlurEffectStyleSystemThickMaterial;
|
|
if ([self.blurType isEqual: @"thinMaterial"]) return UIBlurEffectStyleSystemThinMaterial;
|
|
if ([self.blurType isEqual: @"ultraThinMaterial"]) return UIBlurEffectStyleSystemUltraThinMaterial;
|
|
// dark blur styles
|
|
if ([self.blurType isEqual: @"chromeMaterialDark"]) return UIBlurEffectStyleSystemChromeMaterialDark;
|
|
if ([self.blurType isEqual: @"materialDark"]) return UIBlurEffectStyleSystemMaterialDark;
|
|
if ([self.blurType isEqual: @"thickMaterialDark"]) return UIBlurEffectStyleSystemThickMaterialDark;
|
|
if ([self.blurType isEqual: @"thinMaterialDark"]) return UIBlurEffectStyleSystemThinMaterialDark;
|
|
if ([self.blurType isEqual: @"ultraThinMaterialDark"]) return UIBlurEffectStyleSystemUltraThinMaterialDark;
|
|
// light blur styles
|
|
if ([self.blurType isEqual: @"chromeMaterialLight"]) return UIBlurEffectStyleSystemChromeMaterialLight;
|
|
if ([self.blurType isEqual: @"materialLight"]) return UIBlurEffectStyleSystemMaterialLight;
|
|
if ([self.blurType isEqual: @"thickMaterialLight"]) return UIBlurEffectStyleSystemThickMaterialLight;
|
|
if ([self.blurType isEqual: @"thinMaterialLight"]) return UIBlurEffectStyleSystemThinMaterialLight;
|
|
if ([self.blurType isEqual: @"ultraThinMaterialLight"]) return UIBlurEffectStyleSystemUltraThinMaterialLight;
|
|
#endif
|
|
|
|
#if TARGET_OS_TV
|
|
if ([self.blurType isEqual: @"regular"]) return UIBlurEffectStyleRegular;
|
|
if ([self.blurType isEqual: @"prominent"]) return UIBlurEffectStyleProminent;
|
|
if ([self.blurType isEqual: @"extraDark"]) return UIBlurEffectStyleExtraDark;
|
|
#endif
|
|
|
|
return UIBlurEffectStyleDark;
|
|
}
|
|
|
|
- (BOOL)useReduceTransparencyFallback
|
|
{
|
|
return UIAccessibilityIsReduceTransparencyEnabled() == YES && self.reducedTransparencyFallbackColor != NULL;
|
|
}
|
|
|
|
- (void)updateBlurEffect
|
|
{
|
|
UIBlurEffectStyle style = [self blurEffectStyle];
|
|
self.blurEffect = [BlurEffectWithAmount effectWithStyle:style andBlurAmount:self.blurAmount];
|
|
self.blurEffectView.effect = self.blurEffect;
|
|
}
|
|
|
|
- (void)updateFallbackView
|
|
{
|
|
if ([self useReduceTransparencyFallback]) {
|
|
if (![self.subviews containsObject:self.reducedTransparencyFallbackView]) {
|
|
[self insertSubview:self.reducedTransparencyFallbackView atIndex:0];
|
|
}
|
|
|
|
if ([self.subviews containsObject:self.blurEffectView]) {
|
|
[self.blurEffectView removeFromSuperview];
|
|
}
|
|
} else {
|
|
if ([self.subviews containsObject:self.reducedTransparencyFallbackView]) {
|
|
[self.reducedTransparencyFallbackView removeFromSuperview];
|
|
}
|
|
|
|
if (![self.subviews containsObject:self.blurEffectView]) {
|
|
[self insertSubview:self.blurEffectView atIndex:0];
|
|
}
|
|
}
|
|
|
|
self.reducedTransparencyFallbackView.backgroundColor = self.reducedTransparencyFallbackColor;
|
|
}
|
|
|
|
- (void)reduceTransparencyStatusDidChange:(__unused NSNotification *)notification
|
|
{
|
|
[self updateFallbackView];
|
|
}
|
|
|
|
@end
|