新浪微博客户端(32)-设置相册图片的contentMode
DJStatusPhotoView.m
#import "DJStatusPhotoView.h" #import "UIImageView+WebCache.h" #import "DJPhoto.h" @interface DJStatusPhotoView() // GIF标记 @property (nonatomic,weak) UIImageView *gifView; @end @implementation DJStatusPhotoView - (instancetype)initWithFrame:(CGRect)frame { self = [super initWithFrame:frame]; if (self) { // typedef NS_ENUM(NSInteger, UIViewContentMode) { // UIViewContentModeScaleToFill, // 默认值,拉伸并填充到整个ImageView,可能变形 // UIViewContentModeScaleAspectFit, // 拉伸至完全显示在imageView里面,不会变形 // UIViewContentModeScaleAspectFill, // 【推荐使用!!!】拉伸至图片的宽度等于imageView的宽度或高度为止 // UIViewContentModeRedraw, // 不常用,当调用setNeedsDisplay的时候,会重绘图片 // UIViewContentModeCenter, // 居中显示,不会拉伸 // UIViewContentModeTop, // UIViewContentModeBottom, // UIViewContentModeLeft, // UIViewContentModeRight, // UIViewContentModeTopLeft, // UIViewContentModeTopRight, // UIViewContentModeBottomLeft, // UIViewContentModeBottomRight, // }; // // // // self.clipsToBounds 超出边框的部分会剪掉,通常与AspectFill配合使用 // // // 规律: // // 1. 凡是带有scale单词的,图片都会拉伸 // // 2. 凡是带有Aspect单词的,图片都会保持原来的宽高比,图片不会变形 self.contentMode = UIViewContentModeScaleAspectFill; self.clipsToBounds = YES; } return self; } - (UIImageView *)gifView { if (!_gifView) { UIImage *gifImage = [UIImage imageNamed:@"timeline_image_gif"]; UIImageView *gifView = [[UIImageView alloc] initWithImage:gifImage]; [self addSubview:gifView]; _gifView = gifView; } return _gifView; } - (void)setPhoto:(DJPhoto *)photo { _photo = photo; // 取得缩略图对应的中型图片 NSString *photo_image_url = photo.thumbnail_pic; photo_image_url = [photo_image_url stringByReplacingOccurrencesOfString:@"thumbnail" withString:@"bmiddle"]; // 设置显示图片 [self sd_setImageWithURL:[NSURL URLWithString:photo_image_url] placeholderImage:[UIImage imageNamed:@"timeline_image_placeholder"]]; // 根据图片类型判断是否显示GIF标记(注意cell会重复利用) self.gifView.hidden = ![photo.thumbnail_pic.lowercaseString hasSuffix:@"gif"]; DJLog(@"%@",photo.thumbnail_pic); } // 调整gifView的位置(由于使用的是initWithImage创建,所以gifView有宽和高,因此只需要设置x,y值即可) - (void)layoutSubviews { [super layoutSubviews]; self.gifView.x = self.width - self.gifView.width; self.gifView.y = self.height - self.gifView.height; } @end
最终效果:
如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库