iOS圖片壓縮

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

以下是我設(shè)計(jì)這個(gè)壓縮圖片的思路----

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

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

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

(4)重新渲染圖片,再回調(diào)出來

以下是代碼部分

Swift 代碼部分

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

壓縮圖片

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

- parameter imageBytes: 壓縮的大小

- parameter block:? ? ? 壓縮后的回調(diào)

*/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代碼調(diào)用上面函數(shù)

/**

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

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

print("這個(gè)是壓縮后的圖片\(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調(diào)用代碼

/**

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

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

}];

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

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

友情鏈接更多精彩內(nèi)容