From 748260af04f15fedfbf894f2e56d8b37a8d6c237 Mon Sep 17 00:00:00 2001 From: Mattt Thompson Date: Sat, 10 Aug 2013 17:49:05 -0700 Subject: [PATCH] [Issue #1181] Using UIImage calculated image orientation Minor refactoring --- AFNetworking/AFImageRequestOperation.m | 22 ++++++++++------------ 1 file changed, 10 insertions(+), 12 deletions(-) diff --git a/AFNetworking/AFImageRequestOperation.m b/AFNetworking/AFImageRequestOperation.m index 9fedbfa..1178198 100644 --- a/AFNetworking/AFImageRequestOperation.m +++ b/AFNetworking/AFImageRequestOperation.m @@ -49,6 +49,11 @@ static UIImage * AFInflatedImageFromResponseWithDataAtScale(NSHTTPURLResponse *r return nil; } + UIImage *image = AFImageWithDataAtScale(data, scale); + if (image.images) { + return image; + } + CGImageRef imageRef = nil; CGDataProviderRef dataProvider = CGDataProviderCreateWithCFData((__bridge CFDataRef)data); @@ -59,22 +64,15 @@ static UIImage * AFInflatedImageFromResponseWithDataAtScale(NSHTTPURLResponse *r } if (!imageRef) { - UIImage *image = AFImageWithDataAtScale(data, scale); - if (image.images) { - CGDataProviderRelease(dataProvider); - + imageRef = CGImageCreateCopy([image CGImage]); + + if (!imageRef) { return image; } - - imageRef = CGImageCreateCopy([image CGImage]); } CGDataProviderRelease(dataProvider); - if (!imageRef) { - return nil; - } - size_t width = CGImageGetWidth(imageRef); size_t height = CGImageGetHeight(imageRef); size_t bitsPerComponent = CGImageGetBitsPerComponent(imageRef); @@ -100,7 +98,7 @@ static UIImage * AFInflatedImageFromResponseWithDataAtScale(NSHTTPURLResponse *r if (!context) { CGImageRelease(imageRef); - return [[UIImage alloc] initWithData:data]; + return image; } CGRect rect = CGRectMake(0.0f, 0.0f, width, height); @@ -108,7 +106,7 @@ static UIImage * AFInflatedImageFromResponseWithDataAtScale(NSHTTPURLResponse *r CGImageRef inflatedImageRef = CGBitmapContextCreateImage(context); CGContextRelease(context); - UIImage *inflatedImage = [[UIImage alloc] initWithCGImage:inflatedImageRef scale:scale orientation:UIImageOrientationUp]; + UIImage *inflatedImage = [[UIImage alloc] initWithCGImage:inflatedImageRef scale:scale orientation:image.imageOrientation]; CGImageRelease(inflatedImageRef); CGImageRelease(imageRef);