經(jīng)常開(kāi)發(fā)過(guò)程中會(huì)用到默認(rèn)UITableView的cell.imageView.image,如果圖片尺寸剛好跟我們想要的尺寸一樣的話倒也相安無(wú)事,但總是有意外的,經(jīng)常從接口獲取的圖片尺寸大小是不固定的,例如下圖1-1:

圖片的尺寸大于cell的高度,所以就被“撐爆”了,顯得非常不美觀、和諧,如果cell的高度不固定,圖片尺寸又不同,那效果就更加難看了,那我們?cè)趺醋瞿??你們肯定有多種解決方法了:
1、自定義cell(如果簡(jiǎn)單的cell的話這個(gè)有點(diǎn)麻煩,又要新建cell文件····)
2、利用UIGraphicsBeginImageContextWithOptions函數(shù)來(lái)處理(目前為止我覺(jué)得最簡(jiǎn)單的方法)
UIImage * icon = [UIImage imageNamed:@"goods_1"];
CGSize itemSize = CGSizeMake(36, 36);//固定圖片大小為36*36
UIGraphicsBeginImageContextWithOptions(itemSize, NO, 0.0);//*1
CGRect imageRect = CGRectMake(0, 0, itemSize.width, itemSize.height);
[icon drawInRect:imageRect];
cell.imageView.image = UIGraphicsGetImageFromCurrentImageContext();//*2
UIGraphicsEndImageContext();//*3
完成之后圖示如下圖1-2(是不是瞬間漂亮好多?而且不會(huì)嚴(yán)重變形哦O(∩_∩)O哈哈~):

這里解釋一下
*1
UIGraphicsBeginImageContextWithOptions(CGSize size, BOOL opaque, CGFloat scale)這個(gè)函數(shù)用于獲取處理圖片的圖形上下文(context),利用該上下文,你就可以在其上進(jìn)行繪圖,并生成圖片。
size是創(chuàng)建上下文的大小,同時(shí)也是上下文處理圖形后返回的大小
opaque透明開(kāi)關(guān),如果圖形完全不用透明,設(shè)置為YES以優(yōu)化位圖的存儲(chǔ)。
scale縮放因子
*2
調(diào)用UIGraphicsGetImageFromCurrentImageContext()函數(shù)可從當(dāng)前上下文中獲取一個(gè)UIImage對(duì)象,這樣就講改變了圖片取出來(lái)了
*3
在完成對(duì)圖片的操作之后要關(guān)閉該上下文,所以需要調(diào)用UIGraphicsEndImageContext()函數(shù)