iOS 图片转NSData-b

iOS开发中 UIImage可能经常需要转为NSData 上传 传递等等

有两个比较常用的方法

  1. UIImageJPEGRepresentation
  1. UIImagePNGRepresentation

第一个方法有两个参数

  1. UIImageJPEGRepresentation(UIImage * __nonnull image, CGFloat compressionQuality);

第一个参数就是图片,第二个参数 就是需要设置的清晰度,值介于0到1之前,值越大却清晰,占用空间就越大,反之,值越小清晰度就越低,占用空间也就越小

我们直接上代码

吧两种方式做一个比较

我们创建一个项目,调用系统的相册或者照相机 取一张图片

先用第一种方式转换一个清晰度较高的图片(此处我们贴出重要代码,其他代码我们会上传到qq群空间,请见文章底部)

  1. UIImage *image;
  2. image=[info valueForKey:UIImagePickerControllerOriginalImage];
  3. imageData = UIImageJPEGRepresentation(image,1);
  4. float length = [imageData length]/1024;
  5. NSLog(@"image length===%f",length);

在用第一个方式转一个清晰度较低的图片

  1. imageData1 = UIImageJPEGRepresentation(image,0.1);
  2. float length1 = [imageData1 length]/1024;
  3. NSLog(@"image length1===%f",length1);

再用第二种方法转换一张

 

  1. imageData2 = UIImagePNGRepresentation(image);
  2. float length2 = [imageData2 length]/1024;
  3. NSLog(@"image length===%f",length2);

我们通过执行代码 会发现

  1. TestImageToData[1317:494705] image length===297.000000
  2. TestImageToData[1317:494705] image length1===34.000000
  3. TestImageToData[1317:494705] image length===190.000000

同一张图片 通过三种方式转换后 大小差别比较打

第一种方式 高质量图片297Kb   低质量图片34Kb

第二种方式出来的190Kb

=================

//sdk中提供了方法可以直接调用

UIImage *img = [UIImage imageNamed:@"some.png"];

NSData *dataObj = UIImageJPEGRepresentation(img, 1.0);

//下面是sdk中UIImage.h头文件中的内容

UIKIT_EXTERN NSData *UIImagePNGRepresentation(UIImage *image);

// return image as PNG. May return nil if image has no CGImageRef or invalid bitmap format

UIKIT_EXTERN NSData *UIImageJPEGRepresentation(UIImage *image, CGFloat compressionQuality);

// return image as JPEG. May return nil if image has no CGImageRef or invalid bitmap format. compression is 0(most)..1(least)

JPEG的转换方法里面第二个参数是压缩系数,可以有效的减小图片的大小。UIImagePNGRepresentation(UIImage* image) 要比UIImageJPEGRepresentation(UIImage* image, 1.0) 返回的图片数据量大很多。项目中做图片上传之前,经过测试同一张拍照所得照片png大小在8M,而JPG压缩系数为0.75时候,大小只有1M。而且,将压缩系数降低对图片视觉上并没有太大的影响。

==========================

利用UIImageJPEGRepresentation与UIGraphicsBeginImageContext进行图片压缩的简单比较

UIImage *image01 = [UIImage imageNamed:@"002.png"];//原图

02.

03.NSData *dataOf02 =UIImageJPEGRepresentation(image01, 0.5);//压缩图片内容,不影响图片的size,得到一个原大小,但更模糊的图片。

04.UIImage *image02 = [UIImage imageWithData:dataOf02];//压缩图02

05.

06.UIImage *image03 = [self makeThumbnailFromImage:image01 scale:0.5];//压缩图03

07.NSLog(@"001===%@",NSStringFromCGSize(image01.size));

08.NSLog(@"002===%@",NSStringFromCGSize(image02.size));

09.NSLog(@"003===%@",NSStringFromCGSize(image03.size));

10.

11.NSData *data001 = UIImageJPEGRepresentation(image01, 1.0);

12.NSData *data002 = UIImageJPEGRepresentation(image02, 1.0);

13.NSData *data003 = UIImageJPEGRepresentation(image03, 1.0);

14.

15.NSLog(@"002.lenght===%d",data001.length);

16.NSLog(@"002.lenght===%d",data002.length);

17.NSLog(@"003.lenght===%d",data003.length);

18.

19.//看一下效果

20.UIImageView *imageView01 = [[UIImageView alloc] initWithFrame:CGRectMake(00, image01.size.width, image01.size.height)];

21.imageView01.image = image01;

22.[self.view addSubview:imageView01];

23.

24.UIImageView *imageView02 = [[UIImageView alloc] initWithFrame:CGRectMake(0100, image02.size.width, image02.size.height)];

25.imageView02.image = image02;

26.[self.view addSubview:imageView02];

27.

28.UIImageView *imageView03 = [[UIImageView alloc] initWithFrame:CGRectMake(0200, image03.size.width, image03.size.height)];

29.imageView03.image = image03;

30.[self.view addSubview:imageView03];

view sourceprint?

01.//手动实现图片压缩,可以写到分类里,封装成常用方法。按照大小进行比例压缩,改变了图片的size。

02.- (UIImage *)makeThumbnailFromImage:(UIImage *)srcImage scale:(double)imageScale {

03.UIImage *thumbnail = nil;

04.CGSize imageSize = CGSizeMake(srcImage.size.width * imageScale, srcImage.size.height * imageScale);

05.if (srcImage.size.width != imageSize.width || srcImage.size.height != imageSize.height)

06.{

07.UIGraphicsBeginImageContext(imageSize);

08.CGRect imageRect = CGRectMake(0.00.0, imageSize.width, imageSize.height);

09.[srcImage drawInRect:imageRect];

10.thumbnail = UIGraphicsGetImageFromCurrentImageContext();

11.UIGraphicsEndImageContext();

12.}

13.else

14.{

15.thumbnail = srcImage;

16.}

17.return thumbnail;

18.}

时间: 2024-10-05 08:31:54

iOS 图片转NSData-b的相关文章

iOS图片模糊效果

加入  CoreImage.framework  CoreGraphic.framework 等库 在使用时引入:#import <Accelerate/Accelerate.h> ,支持iOS 5.0 及以上. -(void)show { UIImage* img = [self getBlurImage:[UIImage imageNamed:@"Default-568h.png"]]; [_bgImageView setImage:img]; } -(UIImage*

IOS 图片转换二进制 二进制转换为图片

//类方法 图片 转换为二进制 +(NSData *)Image_TransForm_Data:(UIImage *)image { NSData *imageData = UIImageJPEGRepresentation(image , 0.5); //几乎是按0.5图片大小就降到原来的一半 比如这里 24KB 降到11KB return imageData; } //调用方法举例 -(void)viewWillAppear:(BOOL)animated { [self Read_Image

iOS 图片背景模糊效果

iOS 图片背景模糊效果 1.使用CoreImage中的模糊滤镜 原始效果图如下: CoreImage的实现: - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typically from a nib. UIImage * image = [UIImage imageNamed:@"icon"]; /*..CoreImage中的模糊效果滤镜..*/

实现iOS图片等资源文件的热更新化(三):动态的资源文件夹

简介 此文,将尝试动态从某个不确定的文件夹中加载资源文件.文章,会继续完善自定义的 imageNamed 函数,并为下一篇文章铺垫. 这么做的意义 正如我们经常所说的那样,大多数情景知道做事的意义往往比做事的方法本身更有意义.意义本身,往往蕴含着目的,最终的需求一类的东西;而方法,只是我们暂时寻找的用来达到最终的目的采取的一种可行的手段.知晓意义本身的意义在于,在以后的以后,我们有可能找到更合适的方法来实现目的;也就是我们所说的,到知识的丰富性得到一定程度之后,许多人在自己的个人技能提升过程中,

iOS 图片本地存储、本地获取、本地删除

在iOS开发中.经常用到图片的本地化. iOS 图片本地存储.本地获取.本地删除,可以通过以下类方法实现. p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #008400; background-color: #ffffff } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #000000; background-color

iOS 图片

一.图片加载的工作流 概括来说,从磁盘中加载一张图片,并将它显示到屏幕上,中间的主要工作流如下: 假设我们使用 +imageWithContentsOfFile: 方法从磁盘中加载一张图片,此时的图片并没有解压缩: 然后将生成的 UIImage 赋值给 UIImageView: 接着一个隐式的 CATransaction 捕获到了 UIImageView 图层树的变化: 在主线程的下一个 run loop 到来时,Core Animation 提交了这个隐式的 transaction,这个过程可

ios图片拉伸两种方法

ios图片拉伸两种方法 UIImage *image = [UIImage imageNamed:@"qq"]; 第一种: // 左端盖宽度 NSInteger leftCapWidth = image.size.width * 0.5f; // 顶端盖高度 NSInteger topCapHeight = image.size.height * 0.5f; // 重新赋值 image = [image stretchableImageWithLeftCapWidth:leftCapW

IOS图片拉伸技巧

IOS 图片拉伸技巧 对于有些图标等按钮 在美工设计的按钮下可以通过拉伸效果处理所需效果,最熟悉的莫过于微信聊天的 椭圆背景,也是通过这个这个原理进行背景图片.  如对该图片拉伸,如何操作? 首先找到要拉伸的部分,很明显 两侧椭圆是不变 要拉伸的是中间部分,如何指定中间部位,先看下图 指定这4个宽度后 会形成黑色模块 直白点就是 这块内容就是拉伸后中间那块不断填充的部分 具体代码: 1 UIImage* img=[UIImage imageNamed:@"2.png"];//原图2 U

IOS 图片轮播实现原理 (三图)

IOS 图片轮播实现原理的一种 图片轮播所要实现的是在一个显示区域内通过滑动来展示不同的图片. 当图片较少时我们可以采用在滚动视图上添加很多张图片来实现. 但是如果图片数量较多时,一次性加载过多图片会浪费内存,影响性能. 因此我们要采取适当地方法来实现图片的轮播. 下面我们只是简单的介绍很多方法中的一种简单的实现原理. 一 二 三 四 五 六 七