这篇文章主要为大家详细介绍了iOS开发实现UIImageView的分类,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了iOS实现UIImageView的分类代码,供大家参考,具体内容如下
一.Objective-C版
.h文件
#import <Foundation/Foundation.h>
#import <UIKit/UIKit.h>
#import <QuartzCore/QuartzCore.h>
/**
* 这个分类为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的分类


基础教程推荐
猜你喜欢
- MVVMLight项目Model View结构及全局视图模型注入器 2023-05-07
- Android开发Compose集成高德地图实例 2023-06-15
- iOS开发使用XML解析网络数据 2022-11-12
- Android Compose自定义TextField实现自定义的输入框 2023-05-13
- iOS Crash常规跟踪方法及Bugly集成运用详细介绍 2023-01-18
- Android实现短信验证码输入框 2023-04-29
- Flutter进阶之实现动画效果(三) 2022-10-28
- iOS中如何判断当前网络环境是2G/3G/4G/5G/WiFi 2023-06-18
- iOS开发 全机型适配解决方法 2023-01-14
- IOS获取系统相册中照片的示例代码 2023-01-03