iOS: add BlurEffect

This commit is contained in:
pengfei.zhou 2021-11-25 11:44:01 +08:00 committed by osborn
parent 87b73461e6
commit 84d5ccd1c6
7 changed files with 94 additions and 3 deletions

View File

@ -61,6 +61,7 @@
#import "DoricLocalResourceLoader.h" #import "DoricLocalResourceLoader.h"
#import "DoricRemoteResourceLoader.h" #import "DoricRemoteResourceLoader.h"
#import "DoricCommonBundleResourceLoader.h" #import "DoricCommonBundleResourceLoader.h"
#import "DoricBlurEffectViewNode.h"
@interface DoricRegistry () @interface DoricRegistry ()
@ -133,6 +134,7 @@ - (void)innerRegister {
[self registerViewNode:DoricSwitchNode.class withName:@"Switch"]; [self registerViewNode:DoricSwitchNode.class withName:@"Switch"];
[self registerViewNode:DoricFlexNode.class withName:@"FlexLayout"]; [self registerViewNode:DoricFlexNode.class withName:@"FlexLayout"];
[self registerViewNode:DoricGestureContainerNode.class withName:@"GestureContainer"]; [self registerViewNode:DoricGestureContainerNode.class withName:@"GestureContainer"];
[self registerViewNode:DoricBlurEffectViewNode .class withName:@"BlurEffect"];
[self.loaderManager registerLoader:[[DoricBundleResourceLoader alloc] [self.loaderManager registerLoader:[[DoricBundleResourceLoader alloc]
initWithResourceType:@"mainBundle" initWithResourceType:@"mainBundle"

View File

@ -0,0 +1,24 @@
/*
* Copyright [2021] [Doric.Pub]
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
//
// Created by pengfei.zhou on 2021/11/24.
//
#import <Foundation/Foundation.h>
#import "DoricStackNode.h"
@interface DoricBlurEffectViewNode : DoricStackNode
@end

View File

@ -0,0 +1,59 @@
/*
* Copyright [2021] [Doric.Pub]
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
//
// Created by pengfei.zhou on 2021/11/24.
//
#import <DoricExtensions.h>
#import "DoricBlurEffectViewNode.h"
@interface DoricBlurEffectViewNode ()
@property(nonatomic, strong) UIVisualEffectView *visualEffectView;
@end
@implementation DoricBlurEffectViewNode
- (UIView *)build {
UIView *ret = [super build];
UIVisualEffect *endEffect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleLight];
self.visualEffectView = [[UIVisualEffectView alloc] initWithEffect:endEffect];
[ret addSubview:self.visualEffectView];
self.visualEffectView.doricLayout.widthSpec = DoricLayoutMost;
self.visualEffectView.doricLayout.heightSpec = DoricLayoutMost;
return ret;
}
- (void)blendView:(UIView *)view forPropName:(NSString *)name propValue:(id)prop {
if ([name isEqualToString:@"radius"]) {
} else if ([name isEqualToString:@"effectiveRect"]) {
NSUInteger x = ((NSNumber *) prop[@"x"]).unsignedIntegerValue;
NSUInteger y = ((NSNumber *) prop[@"y"]).unsignedIntegerValue;
NSUInteger width = ((NSNumber *) prop[@"width"]).unsignedIntegerValue;
NSUInteger height = ((NSNumber *) prop[@"height"]).unsignedIntegerValue;
self.visualEffectView.doricLayout.widthSpec = DoricLayoutJust;
self.visualEffectView.doricLayout.heightSpec = DoricLayoutJust;
self.visualEffectView.doricLayout.width = width;
self.visualEffectView.doricLayout.height = height;
self.visualEffectView.doricLayout.marginLeft = x;
self.visualEffectView.doricLayout.marginTop = y;
} else {
[super blendView:view forPropName:name propValue:prop];
}
}
@end

3
doric-js/index.d.ts vendored
View File

@ -1105,7 +1105,8 @@ declare module 'doric/lib/src/widget/effect' {
}; };
/** /**
* Specify the radius of blur effect. * Specify the radius of blur effect.
* If not set, the default is 15. * If not set, the default value is 15.
* Suggested value is from 1 to 25.
*/ */
radius?: number; radius?: number;
} }

View File

@ -13,7 +13,8 @@ export declare class BlurEffect extends Stack {
}; };
/** /**
* Specify the radius of blur effect. * Specify the radius of blur effect.
* If not set, the default is 15. * If not set, the default value is 15.
* Suggested value is from 1 to 25.
*/ */
radius?: number; radius?: number;
} }

View File

@ -4313,6 +4313,10 @@ __decorate([
Property, Property,
__metadata("design:type", Object) __metadata("design:type", Object)
], BlurEffect.prototype, "effectiveRect", void 0); ], BlurEffect.prototype, "effectiveRect", void 0);
__decorate([
Property,
__metadata("design:type", Number)
], BlurEffect.prototype, "radius", void 0);
function blurEffect(views, config) { function blurEffect(views, config) {
const ret = new BlurEffect; const ret = new BlurEffect;
ret.layoutConfig = layoutConfig().fit(); ret.layoutConfig = layoutConfig().fit();

File diff suppressed because one or more lines are too long