iOS圖片壓縮

最近需要用到圖片壓縮逻澳,本來蘋果是有一個圖片壓縮的方法的躏筏,但是函數(shù)只能說不是很符合我們現(xiàn)在的需求,尤其是一張幾M的圖片想要壓縮成40K用蘋果的API這是不可能做到的涡相,我在網(wǎng)絡上查找了很多資料,都沒有相關現(xiàn)成的第三方庫或方法給我用剩蟀,后來我絕望了催蝗,只能自己寫一個了。

以下是我設計這個壓縮圖片的思路----

(1)先根據(jù)原圖跟需要壓縮成多少KB算出壓縮的比例育特。

(2)獲取原圖的Size丙号,根據(jù)算出的比例來計算出縮小后的圖片Size

(3)再通過判斷原圖的寬跟高的比例,通過反推缰冤,計算出壓縮后小圖的寬跟高

(4)重新渲染圖片犬缨,再回調出來

以下是代碼部分

Swift 代碼部分

// 圖片回調代理typealias ImageBlock = (image:UIImage) -> Void/**

壓縮圖片

- parameter image:? ? ? 需要壓縮的圖片

- parameter imageBytes: 壓縮的大小

- parameter block:? ? ? 壓縮后的回調

*/func compressedImageFiles(image:UIImage?, imageBytes:CGFloat = 30, block:ImageBlock){

var imageCope = image

let fBytes = imageBytes * 1024

var uploadImageData:NSData?

uploadImageData = UIImagePNGRepresentation(imageCope!)

let imageSize = imageCope!.size

let imageWidth = imageSize.width

let imageHeight = imageSize.height

if CGFloat((uploadImageData?.length)!) > fBytes {? ? ? ? dispatch_async(dispatch_queue_create("CompressedImage", DISPATCH_QUEUE_SERIAL)) { () -> Void in

let fBytes = fBytes/CGFloat((uploadImageData?.length)!)

let fScaleArea = imageWidth * imageHeight * fBytes

var fImageScale:CGFloat = 0.0

var dHeight:CGFloat? = 0.0

var dWidth:CGFloat? = 0.0

if imageWidth > imageHeight {

fImageScale = imageWidth/imageHeight

dHeight = CGFloat(sqrt(Double(fScaleArea/fImageScale)))

dWidth = dHeight! * fImageScale

}? ? ? ? ? ? else if imageHeight > imageWidth {

fImageScale = imageHeight/imageWidth

dWidth = CGFloat(sqrt(Double(fScaleArea/fImageScale)))

dHeight = dWidth! * fImageScale

}? ? ? ? ? ? else

{

dWidth = CGFloat(sqrt(Double(fScaleArea)))

dHeight = dWidth!

}? ? ? ? ? ? UIGraphicsBeginImageContext(CGSizeMake(dWidth!, dHeight!))

imageCope!.drawInRect(CGRectMake(0, 0, dWidth!, dHeight!))

imageCope = UIGraphicsGetImageFromCurrentImageContext()? ? ? ? ? ? UIGraphicsEndImageContext()

uploadImageData = UIImagePNGRepresentation(imageCope!)? ? ? ? ? ? if CGFloat((uploadImageData?.length)!) > fBytes {

uploadImageData = UIImageJPEGRepresentation(imageCope!, 1);

}

print("圖片已經(jīng)壓縮成\(uploadImageData!.length/1024)KB")

imageCope = UIImage(data: uploadImageData!)!? ? ? ? ? ? dispatch_sync(dispatch_get_main_queue(), { () -> Void in

block(image: imageCope!)

})

}

}? ? else

{

block(image: imageCope!)

}

}

Swift代碼調用上面函數(shù)

/**

*? 這句函數(shù)調用的意思是,將 1.jpg 這張圖片壓縮成 100KB 左右的大小

*/self.compressedImageFiles(UIImage(named: "1.jpg"), imageBytes: 100) { (image) in

print("這個是壓縮后的圖片\(image)")

}

下面部分是用OC代碼部分

OC 代碼

/**

*? 壓縮圖片

*

*? @param image? ? ? 需要壓縮的圖片

*? @param fImageBytes 希望壓縮后的大小(以KB為單位)

*

*? @return 壓縮后的圖片

*/- (void)compressedImageFiles:(UIImage *)image

imageBytes:(CGFloat)fImageBytes

imageBlock:(imageBlock)block

{

__block UIImage *imageCope = image;

fImageBytes = fImageBytes * 1024;

__block NSData *uploadImageData = nil;

uploadImageData = UIImagePNGRepresentation(imageCope);? ? CGSize size = imageCope.size;? ? CGFloat imageWidth = size.width;? ? CGFloat imageHeight = size.height;? ? if (uploadImageData.length > fImageBytes) {? ? ? ? dispatch_async(dispatch_queue_create("CompressedImage", DISPATCH_QUEUE_SERIAL), ^{? ? ? ? ? ? CGFloat fBytes = fImageBytes/uploadImageData.length;? ? ? ? ? ? CGFloat fScaleArea = imageWidth * imageHeight * fBytes;? ? ? ? ? ? CGFloat fImageScale = 0.0;? ? ? ? ? ? CGFloat dHeight = 0.0;? ? ? ? ? ? CGFloat dWidth = 0.0;? ? ? ? ? ? if (imageWidth > imageHeight) {

fImageScale = imageWidth/imageHeight;

dHeight = sqrtf(fScaleArea/fImageScale);

dWidth? = dHeight * fImageScale;

}? ? ? ? ? ? else if (imageHeight > imageWidth) {

fImageScale = imageHeight/imageWidth;

dWidth = sqrtf(fScaleArea/fImageScale);

dHeight? = dWidth * fImageScale;

}? ? ? ? ? ? else {

dWidth = sqrtf(fScaleArea);

dHeight = dWidth;

}? ? ? ? ? ? UIGraphicsBeginImageContext(CGSizeMake(dWidth, dHeight));

[imageCope drawInRect:CGRectMake(0, 0, dWidth, dHeight)];

imageCope = UIGraphicsGetImageFromCurrentImageContext();? ? ? ? ? ? UIGraphicsEndImageContext();

uploadImageData = UIImagePNGRepresentation(imageCope);? ? ? ? ? ? if (uploadImageData.length > fImageBytes) {

uploadImageData = UIImageJPEGRepresentation(imageCope, 1);

}? ? ? ? ? ? NSLog(@"圖片已經(jīng)壓縮成 %luKB",uploadImageData.length/1024);

imageCope = [[UIImage alloc] initWithData:uploadImageData];? ? ? ? ? ? dispatch_sync(dispatch_get_main_queue(), ^{

block(imageCope);

});

});

}? ? else

{

block(imageCope);

}

}

OC調用代碼

/**

*? 這句函數(shù)調用的意思是棉浸,將 1.jpg 這張圖片壓縮成 100KB 左右的大小

*/[self compressedImageFiles:[UIImage imageNamed:@"1.jpg"] imageBytes:100 imageBlock:^(UIImage *image) {? ? NSLog(@"這個是壓縮后的圖片%@",image);

}];

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末遍尺,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子涮拗,更是在濱河造成了極大的恐慌乾戏,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,470評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件三热,死亡現(xiàn)場離奇詭異鼓择,居然都是意外死亡,警方通過查閱死者的電腦和手機就漾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評論 3 392
  • 文/潘曉璐 我一進店門呐能,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人抑堡,你說我怎么就攤上這事摆出。” “怎么了首妖?”我有些...
    開封第一講書人閱讀 162,577評論 0 353
  • 文/不壞的土叔 我叫張陵偎漫,是天一觀的道長。 經(jīng)常有香客問我有缆,道長象踊,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,176評論 1 292
  • 正文 為了忘掉前任棚壁,我火速辦了婚禮杯矩,結果婚禮上,老公的妹妹穿的比我還像新娘袖外。我一直安慰自己史隆,他們只是感情好,可當我...
    茶點故事閱讀 67,189評論 6 388
  • 文/花漫 我一把揭開白布曼验。 她就那樣靜靜地躺著泌射,像睡著了一般头镊。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上魄幕,一...
    開封第一講書人閱讀 51,155評論 1 299
  • 那天相艇,我揣著相機與錄音,去河邊找鬼纯陨。 笑死坛芽,一個胖子當著我的面吹牛,可吹牛的內容都是我干的翼抠。 我是一名探鬼主播咙轩,決...
    沈念sama閱讀 40,041評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼阴颖!你這毒婦竟也來了活喊?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 38,903評論 0 274
  • 序言:老撾萬榮一對情侶失蹤量愧,失蹤者是張志新(化名)和其女友劉穎钾菊,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體偎肃,經(jīng)...
    沈念sama閱讀 45,319評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡煞烫,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,539評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了累颂。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片滞详。...
    茶點故事閱讀 39,703評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖紊馏,靈堂內的尸體忽然破棺而出料饥,到底是詐尸還是另有隱情,我是刑警寧澤朱监,帶...
    沈念sama閱讀 35,417評論 5 343
  • 正文 年R本政府宣布岸啡,位于F島的核電站,受9級特大地震影響赌朋,放射性物質發(fā)生泄漏凰狞。R本人自食惡果不足惜篇裁,卻給世界環(huán)境...
    茶點故事閱讀 41,013評論 3 325
  • 文/蒙蒙 一沛慢、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧达布,春花似錦团甲、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽身腻。三九已至,卻和暖如春匹厘,著一層夾襖步出監(jiān)牢的瞬間嘀趟,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評論 1 269
  • 我被黑心中介騙來泰國打工愈诚, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留她按,地道東北人。 一個月前我還...
    沈念sama閱讀 47,711評論 2 368
  • 正文 我出身青樓炕柔,卻偏偏與公主長得像酌泰,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子匕累,可洞房花燭夜當晚...
    茶點故事閱讀 44,601評論 2 353

推薦閱讀更多精彩內容

  • 兩種圖片壓縮方法 兩種壓縮圖片的方法:壓縮圖片質量(Quality)陵刹,壓縮圖片尺寸(Size)。 壓縮圖片質量 N...
    喵喵嘟嚕啡閱讀 1,980評論 0 9
  • 提到從攝像頭/相冊獲取圖片是面向終端用戶的欢嘿,由用戶去瀏覽并選擇圖片為程序使用衰琐。在這里,我們需要過UIImagePi...
    Ashoka_APP閱讀 1,523評論 1 1
  • #define KCompressibilityFactor 1280.00 @implementationWeC...
    饅頭Show閱讀 473評論 0 0
  • //壓縮圖片質量+(UIImage *)reduceImage:(UIImage *)image percent:...
    LiwaySun閱讀 312評論 0 0
  • 最近項目需求炼蹦,需要壓縮用戶上傳的圖片到指定大小碘耳。遇到一些坑在這里分享一下。 查了很多資料搞來搞去其實還是只有那么幾...
    karthus閱讀 6,245評論 2 11