我已经彻底阅读了最新的iOS8相框作品,我正试图从用户库中获取一些资产来显示。我让用户一次编辑4张图片。但正因为如此,我需要压缩图像,否则应用程序会崩溃。
我使用PHImageManager通过以下代码加载图像:
func processImages()
{
println("Processing")
_selectediImages = Array()
_cacheImageComplete = 0
for asset in _selectedAssets
{
var options:PHImageRequestOptions = PHImageRequestOptions()
options.version = PHImageRequestOptionsVersion.Unadjusted
options.synchronous = true
var minRatio:CGFloat = 1
if(CGFloat(asset.pixelWidth) > UIScreen.mainScreen().bounds.width || CGFloat(asset.pixelHeight) > UIScreen.mainScreen().bounds.height)
{
minRatio = min(UIScreen.mainScreen().bounds.width/(CGFloat(asset.pixelWidth)), (UIScreen.mainScreen().bounds.height/CGFloat(asset.pixelHeight)))
}
var size:CGSize = CGSizeMake((CGFloat(asset.pixelWidth)*minRatio),(CGFloat(asset.pixelHeight)*minRatio))
println("Target size is (size)")
PHImageManager.defaultManager().requestImageForAsset(asset, targetSize:size, contentMode: .AspectFill, options: options)
{
uiimageResult, info in
var image = iImage(uiimage: uiimageResult)
println("Result Size Is (uiimageResult.size)")
}
}
}
正如你所看到的,我正在计算目标大小,以确保图像至少不大于屏幕。如果是,我会在图像上按比例缩小。然而,这里有一个典型的打印日志
目标大小为(768.0798.453531598513)结果大小为(1614.01678.0)
尽管我将目标大小设置为768x798(在这种特定情况下),但它给我的UIImage是它的两倍多。现在根据文档,targetSize参数
"要返回的图像的目标大小。"
不是最清楚的解释,但从我的实验来看,它与此不匹配。
如果你有什么建议,我很乐意听听!
在Swift
中,您希望执行以下操作:
var asset: PHAsset!
var imageSize = CGSize(width: 100, height: 100)
var options = PHImageRequestOptions()
options.resizeMode = PHImageRequestOptionsResizeMode.Exact
options.deliveryMode = PHImageRequestOptionsDeliveryMode.Opportunistic
PHImageManager.defaultManager().requestImage(asset, targetSize: imageSize, contentMode: PHImageContentMode.AspectFill, options: options) {
(image, info) -> Void in
// what you want to do with the image here
print("Result Size Is (image.size)")
}
在Objective-C
中,它看起来像这样:
void (^resultHandler)(UIImage *, NSDictionary *) = ^(UIImage *result, NSDictionary *info) {
// what you want to do with the image
};
CGSize cellSize = CGSizeMake(100, 100);
PHImageRequestOptions *options = [[PHImageRequestOptions alloc] init];
options.resizeMode = PHImageRequestOptionsResizeModeExact;
options.deliveryMode = PHImageRequestOptionsDeliveryModeOpportunistic;
[[PHImageManager defaultManager] requestImageForAsset:self.imageAsset targetSize:cellSize contentMode:PHImageContentModeAspectFill options:options resultHandler:resultHandler];
重要提示:在机会交付模式下,可能会多次调用不同大小的结果块,但最后一次调用将是您想要的大小。最好使用机会,这样UI将首先加载低质量占位符,然后更新它,因为操作系统可以生成更好的图像(而不是空白正方形)。
这是因为requestImageForAsset
将被调用两次。
第一次,它会返回一个非常相同大小的图像,比如(60*45),我认为这是该图像的缩略图。
第二次,您将获得全尺寸图像。
我使用
if ([[info valueForKey:@"PHImageResultIsDegradedKey"]integerValue]==0){
// Do something with the FULL SIZED image
} else {
// Do something with the regraded image
}
以区分这两个不同的图像。
参考:iOS 8 PhotoKit。从iCloud照片共享相册获取最大尺寸的图像
尝试将resizeMode设置为PHImageRequestOptionsResizeModeExact
,将deliveryMode设置为PHImageRequestOptionsDeliveryModeHighQualityFormat
;
PHImageRequestOptionsResizeModeExact,
// same as above but also guarantees the delivered image is exactly targetSize (must be set when a normalizedCropRect is specified)
您可以将PHImageManagerMaximumSize
用作PHImageManager
请求的targetSize
。
根据PHImageManagerMaximumSize
中的文档:请求原始图像或可用的最大渲染图像时要通过的大小(resizeMode将被忽略)