壓縮圖片

壓縮圖片有兩種, 一種是換尺寸, 一種是壓縮質(zhì)量

如果是jpeg可以直接

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

上面等價(jià)于下面, 適用于格式為png的

+(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;
}

對圖片進(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;
}

感謝http://www.reibang.com/p/fb6a072fba47?utm_campaign=hugo&utm_medium=reader_share&utm_content=note&utm_source=qq

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市叨橱,隨后出現(xiàn)的幾起案子吼具,更是在濱河造成了極大的恐慌圣拄,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)纯露,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來代芜,“玉大人埠褪,你說我怎么就攤上這事〖繁樱” “怎么了钞速?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長罚随。 經(jīng)常有香客問我玉工,道長,這世上最難降的妖魔是什么淘菩? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任遵班,我火速辦了婚禮,結(jié)果婚禮上潮改,老公的妹妹穿的比我還像新娘狭郑。我一直安慰自己,他們只是感情好汇在,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布翰萨。 她就那樣靜靜地躺著,像睡著了一般糕殉。 火紅的嫁衣襯著肌膚如雪亩鬼。 梳的紋絲不亂的頭發(fā)上殖告,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天,我揣著相機(jī)與錄音雳锋,去河邊找鬼黄绩。 笑死,一個(gè)胖子當(dāng)著我的面吹牛玷过,可吹牛的內(nèi)容都是我干的爽丹。 我是一名探鬼主播,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼辛蚊,長吁一口氣:“原來是場噩夢啊……” “哼粤蝎!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起袋马,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤初澎,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后飞蛹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體谤狡,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡灸眼,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年卧檐,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片焰宣。...
    茶點(diǎn)故事閱讀 39,795評論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡霉囚,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出匕积,到底是詐尸還是另有隱情盈罐,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布闪唆,位于F島的核電站盅粪,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏悄蕾。R本人自食惡果不足惜票顾,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望帆调。 院中可真熱鬧奠骄,春花似錦、人聲如沸番刊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽芹务。三九已至蝉绷,卻和暖如春鸭廷,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背熔吗。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工靴姿, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人磁滚。 一個(gè)月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓佛吓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親垂攘。 傳聞我的和親對象是個(gè)殘疾皇子维雇,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評論 2 354

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

  • 在目前的一個(gè)項(xiàng)目中,后臺(tái)運(yùn)營人員傳圖的時(shí)候晒他,都是傳的大圖吱型,導(dǎo)致前端網(wǎng)頁加載緩慢,我用微信開發(fā)者工具查看了一下陨仅,光圖...
    一只好奇的茂閱讀 2,212評論 0 17
  • 1.落筆緣由 在開發(fā)過程中津滞,對大圖進(jìn)行圖片壓縮是很常見的,因?yàn)槿绻麑⒁粋€(gè)未壓縮過的上M的大圖直接讀到內(nèi)存中灼伤,是很占...
    lgy_gg閱讀 1,721評論 1 5
  • [iOS 圖片壓縮方法](http://www.cnblogs.com/silence-cnblogs/p/634...
    羊妞麻麻閱讀 780評論 0 2
  • 提到從攝像頭/相冊獲取圖片是面向終端用戶的触徐,由用戶去瀏覽并選擇圖片為程序使用。在這里狐赡,我們需要過UIImagePi...
    細(xì)雨聽風(fēng)閱讀 2,931評論 4 10
  • 提到從攝像頭/相冊獲取圖片是面向終端用戶的撞鹉,由用戶去瀏覽并選擇圖片為程序使用。在這里颖侄,我們需要過UIImagePi...
    嚴(yán)木木閱讀 829評論 0 5