This repository has been archived on 2024-07-22. You can view files and clone it, but cannot push or open issues or pull requests.
Doric/iOS/Pod/Classes/Shader/DoricImageNode.m

88 lines
3.1 KiB
Mathematica
Raw Normal View History

2019-10-21 09:59:22 +08:00
/*
* Copyright [2019] [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.
*/
2019-08-06 20:06:34 +08:00
//
// DoricImageNode.m
// Doric
//
// Created by pengfei.zhou on 2019/8/6.
//
#import "DoricImageNode.h"
2019-11-20 15:36:07 +08:00
#import "Doric.h"
2019-11-27 19:15:57 +08:00
#import "YYWebImage.h"
2019-08-06 20:06:34 +08:00
@interface DoricImageNode ()
@property(nonatomic, copy) NSString *loadCallbackId;
@end
2019-08-06 20:06:34 +08:00
@implementation DoricImageNode
2019-11-15 14:57:41 +08:00
- (UIImageView *)build {
2019-11-27 19:15:57 +08:00
return [[YYAnimatedImageView new] also:^(UIImageView *it) {
2019-11-20 15:36:07 +08:00
it.clipsToBounds = YES;
}];
2019-08-06 20:06:34 +08:00
}
- (void)blendView:(UIImageView *)view forPropName:(NSString *)name propValue:(id)prop {
2019-11-20 15:36:07 +08:00
if ([@"imageUrl" isEqualToString:name]) {
2019-08-06 20:06:34 +08:00
__weak typeof(self) _self = self;
2019-11-27 19:15:57 +08:00
[view yy_setImageWithURL:[NSURL URLWithString:prop] placeholder:nil options:0 completion:^(UIImage *image, NSURL *url, YYWebImageFromType from, YYWebImageStage stage, NSError *error) {
2019-08-06 20:06:34 +08:00
__strong typeof(_self) self = _self;
if (error) {
if (self.loadCallbackId.length > 0) {
[self callJSResponse:self.loadCallbackId, nil];
}
} else {
if (self.loadCallbackId.length > 0) {
[self callJSResponse:self.loadCallbackId,
@{@"width": @(image.size.width), @"height": @(image.size.height)},
nil];
}
[self requestLayout];
}
2019-08-06 20:06:34 +08:00
}];
2019-11-20 15:36:07 +08:00
} else if ([@"scaleType" isEqualToString:name]) {
switch ([prop integerValue]) {
case 1: {
self.view.contentMode = UIViewContentModeScaleAspectFit;
break;
}
case 2: {
self.view.contentMode = UIViewContentModeScaleAspectFill;
break;
}
default: {
self.view.contentMode = UIViewContentModeScaleToFill;
break;
}
}
} else if ([@"loadCallback" isEqualToString:name]) {
self.loadCallbackId = prop;
2019-11-25 11:19:30 +08:00
} else if ([@"imageBase64" isEqualToString:name]) {
NSString *base64 = prop;
if (YES == [base64 hasPrefix:@"data:image"]) {
base64 = [base64 componentsSeparatedByString:@","].lastObject;
}
NSData *imageData = [[NSData alloc] initWithBase64EncodedString:base64
options:NSDataBase64DecodingIgnoreUnknownCharacters];
UIImage *image = [UIImage imageWithData:imageData];
self.view.image = image;
2019-08-06 20:06:34 +08:00
} else {
[super blendView:view forPropName:name propValue:prop];
}
}
@end