iOS开发实现UIImageView的分类
本文实例为大家分享了iOS实现UIImageView的分类代码,供大家参考,具体内容如下
创新互联公司成立以来不断整合自身及行业资源、不断突破观念以使企业策略得到完善和成熟,建立了一套“以技术为基点,以客户需求中心、市场为导向”的快速反应体系。对公司的主营项目,如中高端企业网站企划 / 设计、行业 / 企业门户设计推广、行业门户平台运营、成都APP应用开发、手机网站制作设计、微信网站制作、软件开发、遂宁联通机房等实行标准化操作,让客户可以直观的预知到从创新互联公司可以获得的服务效果。
一.Objective-C版
.h文件
#import#import #import /** * 这个分类为UIImageView添加一些有用的方法 */ @interface UIImageView (WLKit) /** * 创建一个UIImageView * * @param image UIImageView的图片 * @param rect UIImageView的坐标 * * @return 返回一个UIImageView */ + (instancetype _Nonnull)imageViewWithImage:(UIImage *_Nonnull)image frame:(CGRect)rect; /** * 创建一个UIImageView * * @param image UIImageView的图片 * @param size UIImageView的大小 * @param center UIImageView的中心 * * @return 返回一个UIImageView */ + (instancetype _Nonnull)imageViewWithImage:(UIImage *_Nonnull)image size:(CGSize)size center:(CGPoint)center; /** * 创建一个UIImageView * * @param image UIImageView的图片 * @param center UIImageView的中心 * * @return Returns the created UIImageView */ + (instancetype _Nonnull)imageViewWithImage:(UIImage *_Nonnull)image center:(CGPoint)center; /** * Create an UIImageView with an image and use it as a template with the given color * * @param image UIImageView image * @param tintColor UIImageView tint color * * @return Returns the created UIImageView */ + (instancetype _Nonnull)imageViewWithImageAsTemplate:(UIImage *_Nonnull)image tintColor:(UIColor *_Nonnull)tintColor; /** * Create a drop shadow effect * * @param color Shadow's color * @param radius Shadow's radius * @param offset Shadow's offset * @param opacity Shadow's opacity */ - (void)setImageShadowColor:(UIColor *_Nonnull)color radius:(CGFloat)radius offset:(CGSize)offset opacity:(CGFloat)opacity; /** * Mask the current UIImageView with an UIImage * * @param image The mask UIImage */ - (void)setMaskImage:(UIImage *_Nonnull)image; @end
.m文件
#import "UIImageView+WLKit.h" @implementation UIImageView (WLKit) + (instancetype _Nonnull)imageViewWithImage:(UIImage *_Nonnull)image frame:(CGRect)rect { UIImageView *_image = [[UIImageView alloc] init]; [_image setFrame:rect]; [_image setImage:image]; return _image; } + (instancetype _Nonnull)imageViewWithImage:(UIImage *_Nonnull)image size:(CGSize)size center:(CGPoint)center { UIImageView *_image = [[UIImageView alloc] init]; [_image setFrame:CGRectMake(0, 0, size.width, size.height)]; [_image setImage:image]; [_image setCenter:center]; return _image; } + (instancetype _Nonnull)imageViewWithImage:(UIImage *_Nonnull)image center:(CGPoint)center { UIImageView *_image = [[UIImageView alloc] init]; [_image setFrame:CGRectMake(0, 0, image.size.width, image.size.height)]; [_image setImage:image]; [_image setCenter:center]; return _image; } + (instancetype _Nonnull)imageViewWithImageAsTemplate:(UIImage *_Nonnull)image tintColor:(UIColor *_Nonnull)tintColor { UIImageView *_image = [[UIImageView alloc] init]; image = [image imageWithRenderingMode:UIImageRenderingModeAlwaysTemplate]; [_image setImage:image]; [_image setTintColor:tintColor]; return _image; } - (void)setImageShadowColor:(UIColor *_Nonnull)color radius:(CGFloat)radius offset:(CGSize)offset opacity:(CGFloat)opacity { self.layer.shadowColor = color.CGColor; self.layer.shadowRadius = radius; self.layer.shadowOffset = offset; self.layer.shadowOpacity = opacity; self.clipsToBounds = NO; } - (void)setMaskImage:(UIImage *_Nonnull)image { CALayer *mask = [CALayer layer]; mask.contents = (id)[image CGImage]; mask.frame = CGRectMake(0, 0, self.frame.size.width, self.frame.size.height); self.layer.mask = mask; self.layer.masksToBounds = YES; } - (void)setAlpha:(CGFloat)alpha { if ([self.superview isKindOfClass:[UITableView class]]) { if (self.superview.tag == 836913) { if (alpha == 0 && self.autoresizingMask == UIViewAutoresizingFlexibleLeftMargin) { if (self.frame.size.width < 10 && self.frame.size.height > self.frame.size.width) { UIScrollView *sc = (UIScrollView*)self.superview; if (sc.frame.size.height < sc.contentSize.height) { [super setAlpha:0.5]; return; } } } } if (self.superview.tag == 836914) { if (alpha == 0 && self.autoresizingMask == UIViewAutoresizingFlexibleTopMargin) { if (self.frame.size.height < 10 && self.frame.size.height < self.frame.size.width) { UIScrollView *sc = (UIScrollView*)self.superview; if (sc.frame.size.width < sc.contentSize.width) { return; } } } } } [super setAlpha:alpha]; } @end
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。
文章标题:iOS开发实现UIImageView的分类
网站链接:http://scyanting.com/article/jesgoe.html