博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
iOS图片压缩
阅读量:5823 次
发布时间:2019-06-18

本文共 4685 字,大约阅读时间需要 15 分钟。

在做iOS开发中,经常会遇到这样的问题,图片尺寸太大,或者文件体积太大,需要将图片压缩处理一下,然后上传服务器。

  当然,也不排除一些公司要求app上传原图,但是这种方式太耗流量且很耗时间,如果网络不佳,很容易上传失败,从而会失去一些用户。

1, 理解概念:

1, “压” 是指文件体积变小,但是像素数不变,长宽尺寸不变,那么质量可能下降。
2, “缩” 是指文件的尺寸变小,也就是像素数减少,而长宽尺寸变小,文件体积同样会减小。

2, 图片“压”处理:

对于“压”功能,我们可以使用UIImageJPEGRepresentation或UIImagePNGRepresentation方法实现,如:

 

 

NSData *imgData = UIImageJPEGRepresentation(image, 0.5);

 

 

第一个参数是图片对象本身,第二个参数是压的系数,其值范围为(0-1);

UIImageJPEGRepresentation的官方注释:

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).

关于PNG和JPEG格式压缩:

1. UIImageJPEGRepresentation函数需要两个参数:图片的引用和压缩系数而UIImagePNGRepresentation只需要图片引用作为参数.
2.UIImagePNGRepresentation(UIImage *image)要比UIImageJPEGRepresentation(UIImage* image, 1.0)返回的图片数据量大很多

项目中做图片上传之前,经过测试同一张拍照所得照片png大小在8M,而JPG压缩系数为0.75时候,大小只有1M。而且,将压缩系数降低对图片视觉上并没有太大的影响。

友情提示:

压缩系数不宜太低,通常是0.3~0.7,过小则可能会出现黑边等

3, 图片“缩”处理:

主要通过 [image drawInRect:CGRectMake(0, 0, targetWidth, targetHeight)]; 实现。

/***  1, 按图片最大边成比例缩放图片**  @param image   图片*  @param maxSize 图片的较长那一边目标缩到的(宽度/高度)**  @return        等比缩放后的图片*/- (UIImage *)scaleImage:(UIImage *)image maxSize:(CGFloat)maxSize {    NSData *data = UIImageJPEGRepresentation(image, 1.0);    if(data.length < 200 * 1024){//0.25M-0.5M(当图片小于此范围不压缩)        return image;    }    CGFloat imageWidth = image.size.width;    CGFloat imageHeight = image.size.height;    CGFloat targetWidth = imageWidth;    CGFloat targetHeight = imageHeight;    CGFloat imageMaxSize = MAX(imageWidth, imageHeight);    if (imageMaxSize > maxSize) {        CGFloat scale = 0;        if (imageWidth >= imageHeight) {// 宽长            scale = maxSize / imageWidth;            targetWidth = maxSize;            targetHeight = imageHeight * scale;        } else { // 高长            scale = maxSize / imageHeight;            targetHeight = maxSize;            targetWidth = imageWidth * scale;        }        UIGraphicsBeginImageContext(CGSizeMake(targetWidth, targetHeight));        [image drawInRect:CGRectMake(0, 0, targetWidth, targetHeight)];        UIImage *scaledImage = UIGraphicsGetImageFromCurrentImageContext();        UIGraphicsEndImageContext();        return scaledImage;    }    return image;}
/***  2, 图片支持等比缩放**  @param image   图片*  @param maxSize 缩放比例(通常0~1之间)**  @return        等比缩放后的图片*/- (UIImage *)scaleImage:(UIImage *)image toScale:(float)scaleSize {    UIGraphicsBeginImageContext(CGSizeMake(image.size.width *scaleSize, image.size.height * scaleSize));    [image drawInRect:CGRectMake(0, 0, image.size.width * scaleSize, image.size.height * scaleSize)];    UIImage *scaledImage = UIGraphicsGetImageFromCurrentImageContext();    UIGraphicsEndImageContext();    return scaledImage;}

/** *  3, 等比缩放成自定长宽的图片 * *  @param image      源图片 *  @param targetSize 自定义目标图片的size * *  @return 处理后图片 */ - (UIImage *)scaleImage:(UIImage *)image toSize:(CGSize)targetSize {    UIGraphicsBeginImageContext(CGSizeMake(targetSize.width, targetSize.height));    [image drawInRect:CGRectMake(0, 0, targetSize.width, targetSize.height)];    UIImage *targetSizeImage = UIGraphicsGetImageFromCurrentImageContext();    UIGraphicsEndImageContext();    return targetSizeImage; }

我们对图片只“压”而不缩,有时候是达不到我们的需求的。因此,适当地对图片“缩“一下尺寸,就可以满足我们的需求。

//根据图片附获取图片大小(多少M)方法- (NSData *)imageData:(UIImage *)image {    NSData *data = UIImageJPEGRepresentation(image, 1.0);    if (data.length > 100*1024) {        if (data.length > 1024*1024) {//1M以及以上            data = UIImageJPEGRepresentation(image, 0.1);        }else if (data.length > 512*1024) {//0.5M-1M                data = UIImageJPEGRepresentation(image, 0.5);        }else if (data.length > 200*1024) {//0.25M-0.5M            data = UIImageJPEGRepresentation(image, 0.9);        }    }    return data;}

验证:

以模拟器第二张绿叶图片为例
原图大小为24.9M, 4288 * 2848像素;
经一次UIImageJPEGRepresentation“压“处理

UIImage *tmpImage = [UIImage imageWithContentsOfFile:photo.photoPath];NSData *imageData = UIImageJPEGRepresentation(tmpImage, 0.5);

图片大小为836.9K, 4288 * 2848像素;

经一次UIImagePNGRepresentation“压“处理

UIImage *tmpImage = [UIImage imageWithContentsOfFile:photo.photoPath];NSData *imageData = UIImagePNGRepresentation(tmpImage);

图片大小为24.9M, 4288 * 2848像素;几乎没变

经一次“缩“处理(笔者给予图片最大的宽度限定为640像素)

UIImage *tmpImage = [UIImage imageWithContentsOfFile:photo.photoPath];tmpImage = [self scaleImage:tmpImage maxSize:640];

图片大小为795.9K, 640 * 426像素;

经一次“压缩”处理:

UIImage *tmpImage = [UIImage imageWithContentsOfFile:photo.photoPath];tmpImage = [self scaleImage:tmpImage maxSize:640];NSData *imageData = UIImageJPEGRepresentation(tmpImage, 0.5);

图片大小为698K, 640 * 426像素;

大家可以根据实际调整不同参数以达到自己的项目要求。

转载于:https://www.cnblogs.com/LynnAIQ/p/5908597.html

你可能感兴趣的文章
IEC61850时间质量TimeQuality各个比特位的含义
查看>>
Windows XP倒计时到底意味着什么?
查看>>
tomcat一步步实现反向代理、负载均衡、内存复制
查看>>
运维工程师在干什么学些什么?【致菜鸟】
查看>>
将私有Android工程迁移至GitHub
查看>>
Linux中iptables详解
查看>>
java中回调函数以及关于包装类的Demo
查看>>
***常用兵器之扫描篇(下)
查看>>
maven异常:missing artifact jdk.tools:jar:1.6
查看>>
终端安全求生指南(五)-——日志管理
查看>>
我的友情链接
查看>>
lduan Exchange 2013 介绍(一)
查看>>
dubbo请求过程调用分析
查看>>
Nginx 使用 openssl 的自签名证书
查看>>
创业维艰、守成不易
查看>>
PHP环境安装套件:快速安装LAMP环境
查看>>
C语言实现“乘法口诀表”
查看>>
CSS3
查看>>
ul下的li浮动,如何是ul有li的高度
查看>>
C++ primer plus
查看>>