iOS圖片圓角的裁剪優(yōu)化

前面已經介紹過一種給UI控件設置圓角的方法了豆瘫,今天給大家介紹一種性能更加優(yōu)化的為圖片設置圓角的方法
Xib中設置控件的圓角铅乡、邊框效果
當我們在項目中顯示圖片的時候夏漱,如果想要將正方形的圖片轉換為原型圖片的話,如果使用layer進行設置有時就會有一點點卡(特別是在tableView中進行顯示的時候)

  • 通常的解決的辦法就是通過Quartz2D將圖形繪制出一張圓形圖片來進行顯示霉囚。

1.創(chuàng)建UIImage的分類實現圓角方法

#import <UIKit/UIKit.h>

@interface UIImage (ZZYCircleImage)

- (UIImage *)circleImage;

@end


#import "UIImage+ZZYCircleImage.h"

@implementation UIImage (ZZYCircleImage)

- (UIImage *)circleImage
{
    
    //1.開啟圖片圖形上下文:注意設置透明度為非透明
    UIGraphicsBeginImageContextWithOptions(self.size, NO, 0.0);
    //2.開啟圖形上下文
    CGContextRef ref = UIGraphicsGetCurrentContext();
    //3.繪制圓形區(qū)域(此處根據寬度來設置)
    CGRect rect = CGRectMake(0, 0, self.size.width, self.size.width);
    CGContextAddEllipseInRect(ref, rect);
    //4.裁剪繪圖區(qū)域
    CGContextClip(ref);
    
    //5.繪制圖片
    [self drawInRect:rect];
    
    //6.獲取圖片
    UIImage * image = UIGraphicsGetImageFromCurrentImageContext();
    //7.關閉圖形上下文
    UIGraphicsEndImageContext();
    
    return image;
}

@end

2.擴展——SDWebImage的簡單封裝

#import <UIKit/UIKit.h>

@interface UIImageView (ZZYImageView)

- (void)setCircleImage:(NSString *)imageUrl withPlaceholderImage:(NSString *)placeholderImageName;

@end

#import "UIImageView+ZZYImageView.h"
#import <UIImageView+WebCache.h>
#import "UIImage+ZZYCircleImage.h"

@implementation UIImageView (ZZYImageView)

- (void)setCircleImage:(NSString *)imageUrl withPlaceholderImage:(NSString *)placeholderImageName
{
    UIImage * placeholderImage = [UIImage imageNamed:placeholderImageName];
    [self sd_setImageWithURL:[NSURL URLWithString:imageUrl] placeholderImage:placeholderImage completed:^(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL) {
        self.image = image ? [image circleImage]:[placeholderImage circleImage];
    }];
}



@end

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末谭溉,一起剝皮案震驚了整個濱河市墙懂,隨后出現的幾起案子,更是在濱河造成了極大的恐慌扮念,老刑警劉巖损搬,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡巧勤,警方通過查閱死者的電腦和手機嵌灰,發(fā)現死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來颅悉,“玉大人沽瞭,你說我怎么就攤上這事∈F浚” “怎么了驹溃?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長延曙。 經常有香客問我豌鹤,道長,這世上最難降的妖魔是什么枝缔? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任布疙,我火速辦了婚禮,結果婚禮上愿卸,老公的妹妹穿的比我還像新娘灵临。我一直安慰自己,他們只是感情好擦酌,可當我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布俱诸。 她就那樣靜靜地躺著菠劝,像睡著了一般赊舶。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上赶诊,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天笼平,我揣著相機與錄音,去河邊找鬼舔痪。 笑死寓调,一個胖子當著我的面吹牛,可吹牛的內容都是我干的锄码。 我是一名探鬼主播夺英,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼滋捶!你這毒婦竟也來了痛悯?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤重窟,失蹤者是張志新(化名)和其女友劉穎载萌,沒想到半個月后,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡扭仁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年垮衷,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片乖坠。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡搀突,死狀恐怖,靈堂內的尸體忽然破棺而出熊泵,到底是詐尸還是另有隱情描姚,我是刑警寧澤,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布戈次,位于F島的核電站轩勘,受9級特大地震影響,放射性物質發(fā)生泄漏怯邪。R本人自食惡果不足惜绊寻,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望悬秉。 院中可真熱鬧澄步,春花似錦、人聲如沸和泌。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽武氓。三九已至梯皿,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間县恕,已是汗流浹背东羹。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留忠烛,地道東北人属提。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像美尸,于是被迫代替她去往敵國和親冤议。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,828評論 2 345

推薦閱讀更多精彩內容