NSData *imageData = [NSKeyedArchiver archivedDataWithRootObject:self.imageVIEw.image];UIImage *imagecopy = [NSKeyedUnarchiver unarchiveObjectWithData:imageData];NSLog(@"%@",NsstringFromCGSize(imagecopy.size));
但在iOS 8上,imagecopy的大小始终为零.当我归档UIImageVIEw时,同样的事情发生了,未归档的imageVIEw图像的大小为零.我发现在iOS 7中,UIImage标题如下:
UIImage : NSObject <NSSecureCoding,NSCoding>
但在iOS 8上它是:
UIImage : NSObject <NSSecureCoding>
看起来iOS 8上缺少NSCoding协议.我必须编码实际的图像数据:UIImagePNGRepresentation(self.imageVIEw.image)而不是图像,以确保我得到一个好的图像.
有谁知道为什么会这样?它是为了向后兼容吗?我注意到iOS早期版本的UIImage不符合NSCoding.
解决方法 UIImage:NSObject< NSSecureCoding>因为NSSecureCoding继承了NSCoding,所以不是问题.无论如何,我确认可以使用以下代码重现该问题:
UIImage *img = [UIImage imagenamed: @"myImage"];NSData *data = [NSKeyedArchiver archivedDataWithRootObject:img];UIImage *imgcopy = [NSKeyedUnarchiver unarchiveObjectWithData:data];NSLog(@"%@,%@",imgcopy,NsstringFromCGSize(imgcopy.size)); // -> (null),{0,0}
另一方面,以下代码按预期工作:
UIImage *img = [UIImage imagenamed: @"myImage"];UIImage *img2 = [UIImage imageWithCGImage:img.CGImage scale:img.scale orIEntation:img.imageOrIEntation];NSData *data = [NSKeyedArchiver archivedDataWithRootObject:img2];UIImage *imgcopy = [NSKeyedUnarchiver unarchiveObjectWithData:data];NSLog(@"%@,NsstringFromCGSize(imgcopy.size)); // -> <UIImage: 0x7fa013e766f0>,{50,53}
我不知道为什么,也许是虫子?
我认为,这与iOS8中引入的imageAsset或traitCollection属性有关
总结以上是内存溢出为你收集整理的Unarchive UIImage对象在iOS 8上使用NSKeyedUnarchiver返回CGSizeZero图像全部内容,希望文章能够帮你解决Unarchive UIImage对象在iOS 8上使用NSKeyedUnarchiver返回CGSizeZero图像所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)