IOS微信分享縮略圖壓縮方法

我們都知道微信分享下縮略圖的大小是有限制的(不超過(guò)32kb),不然地話就會(huì)出現(xiàn)點(diǎn)擊分享無(wú)法調(diào)出微信的情況,為此我們必須對(duì)分享的圖片進(jìn)行壓縮。

常規(guī)的圖片壓縮,有兩種方法:壓縮質(zhì)量壓縮尺寸。

壓縮質(zhì)量

NSData *data = UIImageJPEGRepresentation(image, compression);
UIImage *resultImage = [UIImage imageWithData:data];

壓縮尺寸

UIGraphicsBeginImageContext(size);
[image drawInRect:CGRectMake(0, 0, size.width, size.height)];
resultImage = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();

這兩種方法各有什么區(qū)別呢?

壓縮圖片質(zhì)量的優(yōu)點(diǎn)在于,盡可能保留圖片清晰度,圖片不會(huì)明顯模糊,缺點(diǎn)在于當(dāng)圖片質(zhì)量低于一定程度時(shí),繼續(xù)壓縮沒(méi)有效果,所以不能確保壓縮后的大??;

壓縮圖片尺寸可以使圖片小于指定大小,但會(huì)使圖片明顯模糊(比壓縮圖片質(zhì)量模糊)。

為此,針對(duì)微信縮略圖的情況,我們最終需要圖片大小小于32kb,但是我們同樣希望保持圖片質(zhì)量,那么就需要兩種方法進(jìn)行結(jié)合。首先循環(huán)壓縮質(zhì)量,如果大小仍然大于32kb,再對(duì)圖片尺寸進(jìn)行壓縮,直到接近32kb。

這里有童鞋寫出了詳細(xì)的壓縮方法和技術(shù)細(xì)節(jié)(戳這里),并給出了相關(guān)代碼,經(jīng)實(shí)地測(cè)試,代碼可用

oc代碼:

+ (UIImage *)compressImage:(UIImage *)image toByte:(NSUInteger)maxLength {
    // Compress by quality
    CGFloat compression = 1;
    NSData *data = UIImageJPEGRepresentation(image, compression);
    if (data.length < maxLength) return image;
    
    CGFloat max = 1;
    CGFloat min = 0;
    for (int i = 0; i < 6; ++i) {
        compression = (max + min) / 2;
        data = UIImageJPEGRepresentation(image, compression);
        if (data.length < maxLength * 0.9) {
            min = compression;
        } else if (data.length > maxLength) {
            max = compression;
        } else {
            break;
        }
    }
    UIImage *resultImage = [UIImage imageWithData:data];
    if (data.length < maxLength) return resultImage;
    
    // Compress by size
    NSUInteger lastDataLength = 0;
    while (data.length > maxLength && data.length != lastDataLength) {
        lastDataLength = data.length;
        CGFloat ratio = (CGFloat)maxLength / data.length;
        CGSize size = CGSizeMake((NSUInteger)(resultImage.size.width * sqrtf(ratio)),
                                 (NSUInteger)(resultImage.size.height * sqrtf(ratio))); // Use NSUInteger to prevent white blank
        UIGraphicsBeginImageContext(size);
        [resultImage drawInRect:CGRectMake(0, 0, size.width, size.height)];
        resultImage = UIGraphicsGetImageFromCurrentImageContext();
        UIGraphicsEndImageContext();
        data = UIImageJPEGRepresentation(resultImage, compression);
    }
    
    return resultImage;
}

swift代碼:

static func compressImage(_ image: UIImage, toByte maxLength: Int) -> UIImage {
    var compression: CGFloat = 1
    guard var data = UIImageJPEGRepresentation(image, compression),
        data.count > maxLength else { return image }
    
    // Compress by size
    var max: CGFloat = 1
    var min: CGFloat = 0
    for _ in 0..<6 {
        compression = (max + min) / 2
        data = UIImageJPEGRepresentation(image, compression)!
        if CGFloat(data.count) < CGFloat(maxLength) * 0.9 {
            min = compression
        } else if data.count > maxLength {
            max = compression
        } else {
            break
        }
    }
    var resultImage: UIImage = UIImage(data: data)!
    if data.count < maxLength { return resultImage }
    
    // Compress by size
    var lastDataLength: Int = 0
    while data.count > maxLength, data.count != lastDataLength {
        lastDataLength = data.count
        let ratio: CGFloat = CGFloat(maxLength) / CGFloat(data.count)
        let size: CGSize = CGSize(width: Int(resultImage.size.width * sqrt(ratio)),
                                height: Int(resultImage.size.height * sqrt(ratio)))
        UIGraphicsBeginImageContext(size)
        resultImage.draw(in: CGRect(x: 0, y: 0, width: size.width, height: size.height))
        resultImage = UIGraphicsGetImageFromCurrentImageContext()!
        UIGraphicsEndImageContext()
        data = UIImageJPEGRepresentation(resultImage, compression)!
    }
    return resultImage
}
最后編輯于
?著作權(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),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,001評(píng)論 25 709
  • 點(diǎn)擊查看原文 Web SDK 開(kāi)發(fā)手冊(cè) SDK 概述 網(wǎng)易云信 SDK 為 Web 應(yīng)用提供一個(gè)完善的 IM 系統(tǒng)...
    layjoy閱讀 14,306評(píng)論 0 15
  • 概要: 圖片的兩種壓縮方法1.1 壓縮圖片質(zhì)量1.2 壓縮圖片尺寸壓縮圖片使圖片文件小于指定大小2.1 壓縮圖片質(zhì)...
    leonardni閱讀 66,188評(píng)論 40 206
  • Do re mi fa sol la si 有多久 我忘了 琴上的黑鍵 我撫摸著 腳下的...
    女二號(hào)妖精閱讀 219評(píng)論 0 1
  • 這一天,77放學(xué)回到家,媽媽正在做飯,爸爸也已經(jīng)回家了。飯菜做好,一家三口一起吃飯,原本很溫馨的場(chǎng)景卻是77最討厭...
    hi_coco閱讀 621評(píng)論 0 0

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