iOS开发之image图片压缩及压缩成指定大小的两种方法-成都快上网建站

iOS开发之image图片压缩及压缩成指定大小的两种方法

///压缩图片
+ (NSData *)imageCompressToData:(UIImage *)image{
  NSData *data=UIImageJPEGRepresentation(image, 1.0);
  if (data.length>300*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>300*1024) {//0.25M-0.5M
      data=UIImageJPEGRepresentation(image, 0.9);
    }
  }
  return data;
}

ps:下面看下 iOS中图片压缩成指定的大小

创新互联建站-专业网站定制、快速模板网站建设、高性价比泽库网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式泽库网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖泽库地区。费用合理售后完善,十余年实体公司更值得信赖。

 iOS中,我们为了节省内存,需要对图片来进行处理,来优化程序,提高程序的效率,下面是一个根据自己的要求来重新设置图片的大小:

一、压缩图片有两种方式,第一种是压缩图片的大小,重新生成图片的尺寸:如下

/** 
 * 压缩图片到指定尺寸大小 
 * 
 * @param image 原始图片 
 * @param size 目标大小 
 * 
 * @return 生成图片 
 */ 
-(UIImage *)compressOriginalImage:(UIImage *)image toSize:(CGSize)size{ 
  UIImage * resultImage = image; 
  UIGraphicsBeginImageContext(size); 
  [resultImage drawInRect:CGRectMake(00, 0, size.width, size.height)]; 
  UIGraphicsEndImageContext(); 
  return image; 
} 

二、第二种是修改图片的文件大小:如下

/** 
 * 压缩图片到指定文件大小 
 * 
 * @param image 目标图片 
 * @param size 目标大小(最大值) 
 * 
 * @return 返回的图片文件 
 */ 
- (NSData *)compressOriginalImage:(UIImage *)image toMaxDataSizeKBytes:(CGFloat)size{ 
  NSData * data = UIImageJPEGRepresentation(image, 1.0); 
  CGFloat dataKBytes = data.length/1000.0; 
  CGFloat maxQuality = 0.9f; 
  CGFloat lastData = dataKBytes; 
  while (dataKBytes > size && maxQuality > 0.01f) { 
    maxQuality = maxQuality - 0.01f; 
    data = UIImageJPEGRepresentation(image, maxQuality); 
    dataKBytes = data.length / 1000.0; 
    if (lastData == dataKBytes) { 
      break; 
    }else{ 
      lastData = dataKBytes; 
    } 
  } 
  return data; 
} 

这是压缩图片的两种方式。

总结

以上所述是小编给大家介绍的iOS开发之image图片压缩及压缩成指定大小的两种方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对创新互联网站的支持!


网站栏目:iOS开发之image图片压缩及压缩成指定大小的两种方法
文章URL:http://kswjz.com/article/gjepdg.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流