圆形头像示例

圆形头像.png

1、用layer
2、自己画个圆

方法一是公认的很耗内存的方式,所以不推荐

/** 这是一种方法, 但是这样做会使APP变卡 */
    // 设置图片为圆
    self.profile_image.layer.cornerRadius = self.profile_image.width * 0.5;
    // 这是让控件里面的内容跟着变化,牛逼!!!
    self.profile_image.layer.masksToBounds = YES;

方法二

  • 我们给UIImageView写个类目,在需要设置圆形头像的地方调用就ok.

调用

// 设置圆角头像
    [self.profile_image setHeader:topic.profile_image];

实现分类,有时候服务器返回的头像可能为空,所有要判断,是空就给占位图片

#import "UIImageView+BSExtension.h"
#import <UIImageView+WebCache.h>

@implementation UIImageView (BSExtension)

// 设置圆角图像
- (void)setHeader:(NSString *)url {
    UIImage *placeholder = [[UIImage imageNamed:@"defaultUserIcon"] circleImage];
    [self sd_setImageWithURL:[NSURL URLWithString:url] placeholderImage:placeholder completed:^(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL) {
        // 有可能头像为nil, 如果为nil就给占位图片
        self.image =  image ? [image circleImage] : placeholder;
    }];
}

  • 给UIImage写分类,自己画圆

#import "UIImage+Extension.h"

@implementation UIImage (Extension)

/**
 *  圆形图片
 */
- (UIImage *)circleImage {
    
    // self.size当前图片的尺寸 , NO代表透明
    UIGraphicsBeginImageContextWithOptions(self.size, NO, 0.0);
    
    // 获取上下文
    CGContextRef ctx = UIGraphicsGetCurrentContext();
    
    // 添加一个圆
    CGRect rect = CGRectMake(0, 0, self.size.width, self.size.height);
    CGContextAddEllipseInRect(ctx, rect);
    
    // 裁剪
    CGContextClip(ctx);
    
    // 将图片内容画上去
    [self drawInRect:rect];
    
    UIImage *image = UIGraphicsGetImageFromCurrentImageContext();
    
    UIGraphicsEndImageContext();
    
    return image;
}

@end
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容