iOS--圖片壓縮

我們可以在不減小圖片的分辨率(質(zhì)量可以適當(dāng)減小)的情況下翅雏,顯著減小圖片的大小

float kCompressionQuality = 0.3; // 具體大小自己調(diào)
NSData *photo = UIImageJPEGRepresentation(UIImage, kCompressionQuality);

上面方法等價于下面: 壓縮圖片質(zhì)量

+(UIImage *)reduceImage:(UIImage *)image percent:(float)percent
{
    NSData *imageData = UIImageJPEGRepresentation(image, percent);
    UIImage *newImage = [UIImage imageWithData:imageData];
    return newImage;
}

//將圖片壓縮到指定比例

-(UIImage *)scaleToSize:(UIImage *)aImage size:(CGSize)size{
    
    //創(chuàng)建context,并將其設(shè)置為正在使用的context
    UIGraphicsBeginImageContext(size);
    //繪制出圖片(大小已經(jīng)改變)
    [aImage drawInRect:CGRectMake(0, 0, size.width, size.height)];
    //獲取改變大小之后的圖片
    UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();
    //context出棧
    UIGraphicsEndImageContext();
    return newImage; //返回獲得的圖片
}

等比例壓縮

//等比例壓縮
-(UIImage *)oldImage:(UIImage *)oldImage toSize:(CGSize)size{
    
    UIImage *newImage = nil;//新照片對象
    CGSize theSize = oldImage.size;//壓縮前圖片size
    
    CGFloat width = theSize.width; //壓縮前圖片width
    CGFloat height = theSize.height;//壓縮前圖片height
    
    CGFloat newWidth = size.width; //壓縮后圖片width
    CGFloat newHeight = size.height;//壓縮后圖片height
    
    CGFloat scaleFactor = 0.0;//初值
    
    CGFloat toWidth = newWidth;//壓縮后圖片width
    CGFloat toHeight = newHeight;//壓縮后圖片height
    
    CGPoint thumnailPoint = CGPointMake(0.0, 0.0);//給初值

    if (CGSizeEqualToSize(theSize, size) == NO) {
        //判斷是不是已經(jīng)滿足 theSize = size 要求
        
        CGFloat widthFac = newWidth/width;
        CGFloat heithrFac = newHeight/height;
        if (widthFac > heithrFac) {
            scaleFactor = widthFac;
        }else {
            scaleFactor = heithrFac;
        }
        //不滿足做等比例縮小處理
        toWidth = width *scaleFactor;
        toHeight = height *scaleFactor;
        
        if (widthFac > heithrFac) {
            thumnailPoint.y = (newHeight - toHeight)* 0.5;
        }else if (widthFac < heithrFac){
            thumnailPoint.x = (newWidth - toWidth)* 0.5;
        }
    }
    
    //創(chuàng)建context,并將其設(shè)置為正在使用的context
    UIGraphicsBeginImageContext(size);
    CGRect thumbnailRect  = CGRectZero;
    thumbnailRect.origin = thumnailPoint;
    thumbnailRect.size.width = toWidth;
    thumbnailRect.size.height = toHeight;

    //繪制出圖片(大小已經(jīng)改變)
    [oldImage drawInRect:thumbnailRect];
    
    newImage = UIGraphicsGetImageFromCurrentImageContext();
    
    //結(jié)果判斷
    if (newImage == nil) {
        [NSException exceptionWithName:@"提示" reason:@"Error:image scale fail" userInfo:nil];
    }
    UIGraphicsEndImageContext();
    return newImage;
}


-(UIImage *) imageCompressForWidth:(UIImage *)sourceImage targetWidth:(CGFloat)defineWidth{
    
    UIImage *newImage = nil;
    
    CGSize imageSize = sourceImage.size;
    
    CGFloat width = imageSize.width;
    CGFloat height = imageSize.height;
    
    CGFloat targetWidth = defineWidth;
    CGFloat targetHeight = height / (width / targetWidth);
    CGSize size = CGSizeMake(targetWidth, targetHeight);
    CGFloat scaleFactor = 0.0;
    
    CGFloat scaledWidth = targetWidth;
    CGFloat scaledHeight = targetHeight;
    
    CGPoint thumbnailPoint = CGPointMake(0.0, 0.0);
    
    if(CGSizeEqualToSize(imageSize, size) == NO){
        CGFloat widthFactor = targetWidth / width;
        CGFloat heightFactor = targetHeight / height;
        if(widthFactor > heightFactor){
            scaleFactor = widthFactor;
        }
        else{
            scaleFactor = heightFactor;
        }
        
        scaledWidth = width * scaleFactor;
        scaledHeight = height * scaleFactor;
        if(widthFactor > heightFactor){
            thumbnailPoint.y = (targetHeight - scaledHeight) * 0.5;
        }else if(widthFactor < heightFactor){
            thumbnailPoint.x = (targetWidth - scaledWidth) * 0.5;
        }
    }
    
    UIGraphicsBeginImageContext(size);
    CGRect thumbnailRect = CGRectZero;
    thumbnailRect.origin = thumbnailPoint;
    thumbnailRect.size.width = scaledWidth;
    thumbnailRect.size.height = scaledHeight;
    
    [sourceImage drawInRect:thumbnailRect];
    
    newImage = UIGraphicsGetImageFromCurrentImageContext();
    if(newImage == nil){
        NSLog(@"scale image fail");
    }
    UIGraphicsEndImageContext();
    return newImage;
}

圖片的壓縮其實是倆概念儡遮,
1、是 “壓” 文件體積變小嚼酝,但是像素數(shù)不變妄均,長寬尺寸不變,那么質(zhì)量可能下降倒堕,
2灾测、是 “縮” 文件的尺寸變小,也就是像素數(shù)減少垦巴。長寬尺寸變小媳搪,文件體積同樣會減小。
這個 UIImageJPEGRepresentation(image, 0.0)骤宣,是1的功能秦爆。
這個 [sourceImage drawInRect:CGRectMake(0,0,targetWidth, targetHeight)] 是2的功能。
所以憔披,這倆你得結(jié)合使用來滿足需求等限,不然你一味的用1,導(dǎo)致芬膝,圖片模糊的不行望门,但是尺寸還是很大。

我們還可以對圖片進(jìn)行部分截取

-(UIImage*)getSubImage:(CGRect)rect
{
    CGImageRefsubImageRef =CGImageCreateWithImageInRect(self.CGImage,rect);
    CGRectsmallBounds =CGRectMake(0,0, CGImageGetWidth(subImageRef),CGImageGetHeight(subImageRef));

    UIGraphicsBeginImageContext(smallBounds.size);
    CGContextRefcontext =UIGraphicsGetCurrentContext();
    CGContextDrawImage(context,smallBounds,subImageRef);
    UIImage*smallImage =[UIImage imageWithCGImage:subImageRef];
    UIGraphicsEndImageContext();

    returnsmallImage;
}

//--------------截取部分圖片到指定位置-------------------------

圖片(UIImage*)img
要截取的起始坐標(biāo)sx:(int)sx1 sy:(int)sy1
要截取的長度和寬度sw:(int)sw1 sh:(int)sh1
最終要顯示的坐標(biāo)desx:(int)desx1 desy:(int)desy1

-(UIImage*)objectiveDrawRegion:(UIImage*)img sx:(int)sx1 sy:(int)sy1sw:(int)sw1 sh:(int)sh1 desx:(int)desx1 desy:(int)desy1{
[selfsaveImage:imgname:@"objectiveDrawRegion1.png"];

//創(chuàng)建圖片緩沖
void*imageDataRegion=malloc(screenWidth*screenHeight*32);
CGColorSpaceRefiColorSpaceRegion=CGColorSpaceCreateDeviceRGB();
   CGContextRefiDeviceRegion=CGBitmapContextCreate(imageDataRegion,screenWidth,screenHeight,8,4*screenWidth,iColorSpaceRegion,kCGImageAlphaPremultipliedLast);

//剪切區(qū)域
   CGRectclipRegion=CGRectMake(sx1,sy1,sw1,sh1);
   CGContextClipToRect(iDeviceRegion,clipRegion);

   CGFloatwidthf=img.size.width;
   CGFloatheightf=img.size.height;

CGRect  cg=CGRectMake(0.0,0.0, widthf, heightf);
//畫底圖
   CGContextDrawImage(iDeviceRegion,cg,img.CGImage);

//將緩沖形成圖片
   CGImageRefioffRegion=CGBitmapContextCreateImage(iDeviceRegion);

CGRect  cg1=CGRectMake(desx1,desy1, sw1, sh1);
UIImage *ui=[UIImageimageWithCGImage:ioffRegion];

CGContextDrawImage(當(dāng)前context,cg1,ui.CGImage);

//清除緩沖
  CGColorSpaceRelease(iColorSpaceRegion);
 CGContextRelease(iDeviceRegion);
  CGImageRelease(ioffRegion);
 free(imageDataRegion);
//    iDeviceRegion=NULL;
//    imageDataRegion=0;

returnui;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末锰霜,一起剝皮案震驚了整個濱河市筹误,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌癣缅,老刑警劉巖厨剪,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異友存,居然都是意外死亡丽惶,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進(jìn)店門爬立,熙熙樓的掌柜王于貴愁眉苦臉地迎上來钾唬,“玉大人,你說我怎么就攤上這事侠驯÷崭眩” “怎么了?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵吟策,是天一觀的道長儒士。 經(jīng)常有香客問我,道長檩坚,這世上最難降的妖魔是什么着撩? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任诅福,我火速辦了婚禮,結(jié)果婚禮上拖叙,老公的妹妹穿的比我還像新娘氓润。我一直安慰自己,他們只是感情好薯鳍,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布咖气。 她就那樣靜靜地躺著,像睡著了一般挖滤。 火紅的嫁衣襯著肌膚如雪崩溪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天斩松,我揣著相機(jī)與錄音伶唯,去河邊找鬼。 笑死惧盹,一個胖子當(dāng)著我的面吹牛乳幸,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播岭参,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼反惕,長吁一口氣:“原來是場噩夢啊……” “哼尝艘!你這毒婦竟也來了演侯?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤背亥,失蹤者是張志新(化名)和其女友劉穎秒际,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體狡汉,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡娄徊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了盾戴。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片寄锐。...
    茶點(diǎn)故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖尖啡,靈堂內(nèi)的尸體忽然破棺而出橄仆,到底是詐尸還是另有隱情,我是刑警寧澤衅斩,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布盆顾,位于F島的核電站,受9級特大地震影響畏梆,放射性物質(zhì)發(fā)生泄漏您宪。R本人自食惡果不足惜奈懒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望宪巨。 院中可真熱鬧磷杏,春花似錦、人聲如沸揖铜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽天吓。三九已至贿肩,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間龄寞,已是汗流浹背汰规。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留物邑,地道東北人溜哮。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像色解,于是被迫代替她去往敵國和親茂嗓。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 首先科阎,我們必須明確圖片的壓縮其實是兩個概念: “壓” 是指文件體積變小述吸,但是像素數(shù)不變,長寬尺寸不變锣笨,那么質(zhì)量可能...
    李sir35閱讀 11,618評論 1 17
  • 1蝌矛、確圖片的壓縮的概念: “壓” 是指文件體積變小,但是像素數(shù)不變错英,長寬尺寸不變入撒,那么質(zhì)量可能下降⊥盅遥“縮” 是指文...
    HOULI閱讀 18,924評論 7 34
  • 好習(xí)慣之先放demo茅逮, https://github.com/ssj1314/SSJImage-Scan 好用的話...
    五蘊(yùn)盛閱讀 1,861評論 6 14
  • 概要: 圖片的兩種壓縮方法1.1 壓縮圖片質(zhì)量1.2 壓縮圖片尺寸壓縮圖片使圖片文件小于指定大小2.1 壓縮圖片質(zhì)...
    leonardni閱讀 65,472評論 40 206
  • 兩種圖片壓縮方法 兩種壓縮圖片的方法:壓縮圖片質(zhì)量(Quality),壓縮圖片尺寸(Size)判哥。 壓縮圖片質(zhì)量 N...
    喵喵嘟嚕啡閱讀 1,982評論 0 9