【问题标题】:Wrong Control file size UIImage when it is obtained from NSData从 NSData 获取的控制文件大小 UIImage 错误
【发布时间】:2014-08-30 15:46:38
【问题描述】:

我有一种将图像压缩到一定大小的方法,所以我得到了一个具有所需字节数的 NSData,但是当我将此 NSData 转换为 UIImage,并将 UIImage 转换为 NSData 时,我可以检查 NSData 增加的大小(原始值乘以大约 4 个)

UIImage *image = [UIImage imageWithData:imageData];
NSData *newData = UIImageJPEGRepresentation(image,1.0f);

为什么会这样??我只想控制 UIImage 文件大小(用于存储在数据库中)。

我在下面发布我的代码。

提前致谢。

+ (NSData *) dataOfCompressingImage:(UIImage *)pImage toMaxSize:(CGSize)pSize toFileSizeKB:(NSInteger)pFileSizeKB{

CGSize aSize;
if (pSize.width==0 || pSize.height==0){
    aSize = pImage.size;
}else{
    aSize = pSize;
}

UIImage *currentImage = [self imageWithImage:pImage scaledToSize:aSize];
NSData  *imageData    = UIImageJPEGRepresentation(currentImage, 1.0f);
NSInteger currentLength = [imageData length];

double   factor       = 1.0;
double   adjustment   = 1.0 / sqrt(2.0);  // or use 0.8 or whatever you want

while (currentLength >= (pFileSizeKB * 1024)){ //
    factor      *= adjustment;
    NSLog(@"factor: %f", factor);

    @autoreleasepool{
        imageData    = UIImageJPEGRepresentation(currentImage, factor);
    }

    if (currentLength == [imageData length]){
        break; //Exit While. Reached maximum compression level
    }else{
        currentLength = [imageData length];
    }
}

return imageData;
}

【问题讨论】:

    标签: ios objective-c uiimage nsdata


    【解决方案1】:

    发生这种情况是因为当您执行 UIImageJPEGRepresentation 时,您使用的是 1.0 的品质因数,导致 JPEG 的频率分量以过高的分辨率存储。

    这样想,如果你有一个浮点数组,你可以根据需要将它们存储为一个双精度数组。由于数据类型的大小,这些双精度值会占用两倍的内存,但由于起始数据的分辨率有限,因此并不能真正提供更多的分辨率。

    【讨论】:

      猜你喜欢
      • 2011-06-05
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多