iOS UIImage圖片文件大小

計算UIImage圖片大朽胰Α:

- (void)calulateImageFileSize:(UIImage *)image {
    NSData *data = UIImagePNGRepresentation(image);
    if (!data) {
        data = UIImageJPEGRepresentation(image, 1.0);//需要改成0.5才接近原圖片大小肛炮,原因請看下文
    }
    double dataLength = [data length] * 1.0;
    NSArray *typeArray = @[@"bytes",@"KB",@"MB",@"GB",@"TB",@"PB", @"EB",@"ZB",@"YB"];
    NSInteger index = 0;
    while (dataLength > 1024) {
        dataLength /= 1024.0;
        index ++;
    }
    NSLog(@"image = %.3f %@",dataLength,typeArray[index]);
}

-----------2017年7月21日 周五 --------------

在發(fā)布本文章后,收到@lifution的評論:

實際上, `UIImageJPEGRepresentation` 這個函數(shù)獲取到的圖片文件大小并不準(zhǔn)確, 后面的參數(shù)改為 `0.7` 才大概是原圖片的文件大小蚪腐。

一開始本人也是感到奇怪箭昵,因為想當(dāng)然地認(rèn)為設(shè)置1.0才是原圖的大小。
今天對進(jìn)入這個進(jìn)行了驗證:
搜索了官文:
官文描述

Declaration
NSData * UIImageJPEGRepresentation(UIImage *image, CGFloat compressionQuality);
Parameters
image
The original image data.
compressionQuality
The quality of the resulting JPEG image, expressed as a value from 0.0 to 1.0. The value 0.0 represents the maximum compression (or lowest quality) while the value 1.0 represents the least compression (or best quality).

官文描述也是很模糊的回季。
做了一個demo家制,用于測試UIImageJPEGRepresentation方法對圖片數(shù)據(jù)大小的影響。
測試結(jié)果如下:


從數(shù)據(jù)結(jié)果來看泡一,最接近原圖的是0.5的時候颤殴。
1)原圖跟壓縮率0.8對比:看不出來

2)原圖跟壓縮0.5對比:看不出有什么區(qū)別

3)原圖跟壓縮0.25對比,可以看出兩張圖片是有區(qū)別的

附上源碼:

//
//  CalulateImageViewController.m
//  testDemo
//
//  Created by lignpeng on 2017/7/21.
//  Copyright ? 2017年 genpeng. All rights reserved.
//

#import "CalulateImageViewController.h"

@interface CalulateImageViewController ()

@property(nonatomic, strong) UIImageView *imageView;
@property(nonatomic, strong) UILabel *infoLabel;

@end

@implementation CalulateImageViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    self.view.backgroundColor = [UIColor whiteColor];
    NSString *imageStr = [[NSBundle mainBundle] pathForResource:@"0021" ofType:@"jpg"];
    self.imageView = [[UIImageView alloc] initWithImage:[UIImage imageWithContentsOfFile:imageStr]];
    CGRect frame = [UIScreen mainScreen].bounds;
    CGFloat imageWith = 120;
    CGFloat imageHeight = 180;
    CGRect iframe = CGRectMake((CGRectGetWidth(frame) - imageWith) /2,72 , imageWith, imageHeight);
    self.imageView.frame = iframe;
    [self.view addSubview:self.imageView];
    
    self.infoLabel = ({
        UILabel *label = [UILabel new];
        label.textColor = [UIColor grayColor];
        label.font = [UIFont systemFontOfSize:14.0];
        label.numberOfLines = 0;
        label.textAlignment = NSTextAlignmentLeft;
        label;
    });
    
    CGFloat margin = 32;
    CGFloat height = 42;
    CGRect lframe = CGRectMake(margin,CGRectGetHeight(iframe) + CGRectGetMinY(iframe) , CGRectGetWidth(frame) - 2 * margin, CGRectGetHeight(frame) - CGRectGetHeight(iframe) - CGRectGetMinY(iframe) - margin - height);
    self.infoLabel.frame = lframe;
    [self.view addSubview:self.infoLabel];
    
    CGFloat wdith = (CGRectGetWidth(frame) - 2 * margin);
    CGRect bframe = CGRectMake(margin, CGRectGetHeight(lframe) + CGRectGetMinY(lframe) + margin * 0.5, wdith, height);
    UIButton *showBtn = ({
        UIButton *btn = [[UIButton alloc] initWithFrame:bframe];
        btn.backgroundColor = [UIColor blueColor];
        [btn setTitle:@"show" forState:UIControlStateNormal];
        [btn setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];
        [btn addTarget:self action:@selector(showAction) forControlEvents:UIControlEventTouchUpInside];
        btn.layer.cornerRadius = 5.0;
        btn.clipsToBounds = YES;
        btn;
    });
    [self.view addSubview:showBtn];
}

- (void)showAction {
    NSString *infoString = @"image 原大斜侵摇:\n";
    NSString *imageStr = [[NSBundle mainBundle] pathForResource:@"0021" ofType:@"jpg"];
    NSData *data = [NSData dataWithContentsOfFile:imageStr];
    infoString = [infoString stringByAppendingString:[self data:data value:0]];
    infoString = [infoString stringByAppendingString:@"\n"];
    float value = 1.0;
    while (value > 0.01) {
        infoString = [infoString stringByAppendingString:[self value:value]];
        value -= 0.05;
    }
    
    self.infoLabel.text = infoString;
}

- (NSString *)value:(float)value {
    NSData *data = UIImageJPEGRepresentation(self.imageView.image, value);
    NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    NSString *docDir = [paths objectAtIndex:0];
    docDir = [docDir stringByAppendingString:[NSString stringWithFormat:@"/0021.%.3f.jpg",value]];
    NSLog(@"path = %@",docDir);
    [data writeToFile:docDir atomically:YES];
    return [self data:data value:value];
}

- (NSString *)data:(NSData *)data value:(float)value {
    double dataLength = [data length] * 1.0;
    double orgrionLenght = dataLength;
    NSArray *typeArray = @[@"bytes",@"KB",@"MB",@"GB",@"TB",@"PB", @"EB",@"ZB",@"YB"];
    NSInteger index = 0;
    while (dataLength > 1024) {
        dataLength /= 1024.0;
        index ++;
    }
    NSString *str = [NSString stringWithFormat:@"%.3f涵但,%.1f字節(jié),%.3f%@\n",value,orgrionLenght,dataLength,typeArray[index]];
    return str;
}

@end

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市贤笆,隨后出現(xiàn)的幾起案子蝇棉,更是在濱河造成了極大的恐慌讨阻,老刑警劉巖芥永,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異钝吮,居然都是意外死亡埋涧,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進(jìn)店門奇瘦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來棘催,“玉大人,你說我怎么就攤上這事耳标〈及樱” “怎么了?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵次坡,是天一觀的道長呼猪。 經(jīng)常有香客問我,道長砸琅,這世上最難降的妖魔是什么宋距? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮症脂,結(jié)果婚禮上谚赎,老公的妹妹穿的比我還像新娘。我一直安慰自己诱篷,他們只是感情好壶唤,可當(dāng)我...
    茶點故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著棕所,像睡著了一般闸盔。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上橙凳,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天蕾殴,我揣著相機與錄音,去河邊找鬼岛啸。 笑死钓觉,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的坚踩。 我是一名探鬼主播荡灾,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了批幌?” 一聲冷哼從身側(cè)響起础锐,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎荧缘,沒想到半個月后皆警,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡截粗,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年信姓,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片绸罗。...
    茶點故事閱讀 40,040評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡意推,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出珊蟀,到底是詐尸還是另有隱情菊值,我是刑警寧澤,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布育灸,位于F島的核電站腻窒,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏描扯。R本人自食惡果不足惜定页,卻給世界環(huán)境...
    茶點故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望绽诚。 院中可真熱鬧典徊,春花似錦、人聲如沸恩够。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蜂桶。三九已至儡毕,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間扑媚,已是汗流浹背腰湾。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留疆股,地道東北人费坊。 一個月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像旬痹,于是被迫代替她去往敵國和親附井。 傳聞我的和親對象是個殘疾皇子讨越,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,979評論 2 355

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