When I was working on the project, I found that if I directly operated the pictures obtained by the camera, such as clipping and zooming, the original picture might be rotated 90 degrees to the right. The photos taken with the camera contain EXIF information, and the imageOrientation attribute of UIImage refers to the orientation information in EXIF. If we ignore the orientation information and go straight to pixel processing or drawInRect, the result will be rotated or flipped 90 years later. This is because after we perform pixel processing or drawInRect and other operations, imageOrientaion information is deleted and imageOrientaion is reset to 0, resulting in a mismatch between the photo content and imageOrientaion. So, before processing the photo, rotate it in the correct direction and return imageOrientaion 0. #### The following method is a UIImage category method that can be used to get the correct photo orientation.

- (UIImage *)fixOrientation:(UIImage *)aImage {  

      

    // No-op if the orientation is already correct  

    if (aImage.imageOrientation == UIImageOrientationUp)   

        return aImage;  

      

    // We need to calculate the proper transformation to make the image upright.  

    // We do it in 2 steps: Rotate if Left/Right/Down, and then flip if Mirrored.  

    CGAffineTransform transform = CGAffineTransformIdentity;  

      

    switch (aImage.imageOrientation) {  

        case UIImageOrientationDown:  

        case UIImageOrientationDownMirrored:  

            transform = CGAffineTransformTranslate(transform, aImage.size.width, aImage.size.height);  

            transform = CGAffineTransformRotate(transform, M_PI);  

            break;  

              

        case UIImageOrientationLeft:  

        case UIImageOrientationLeftMirrored:  

            transform = CGAffineTransformTranslate(transform, aImage.size.width, 0);  

            transform = CGAffineTransformRotate(transform, M_PI_2);  

            break;  

              

        case UIImageOrientationRight:  

        case UIImageOrientationRightMirrored:  

            transform = CGAffineTransformTranslate(transform, 0, aImage.size.height);  

            transform = CGAffineTransformRotate(transform, -M_PI_2);  

            break;  

        default:  

            break;  

    }  

      

    switch (aImage.imageOrientation) {  

        case UIImageOrientationUpMirrored:  

        case UIImageOrientationDownMirrored:  

            transform = CGAffineTransformTranslate(transform, aImage.size.width, 0);  

            transform = CGAffineTransformScale(transform, -1, 1);  

            break;  

              

        case UIImageOrientationLeftMirrored:  

        case UIImageOrientationRightMirrored:  

            transform = CGAffineTransformTranslate(transform, aImage.size.height, 0);  

            transform = CGAffineTransformScale(transform, -1, 1);  

            break;  

        default:  

            break;  

    }  

      

    // Now we draw the underlying CGImage into a new context, applying the transform  

    // calculated above.  

    CGContextRef ctx = CGBitmapContextCreate(NULL, aImage.size.width, aImage.size.height,  

                                             CGImageGetBitsPerComponent(aImage.CGImage), 0,  

                                             CGImageGetColorSpace(aImage.CGImage),  

                                             CGImageGetBitmapInfo(aImage.CGImage));  

    CGContextConcatCTM(ctx, transform);  

    switch (aImage.imageOrientation) {  

        case UIImageOrientationLeft:  

        case UIImageOrientationLeftMirrored:  

        case UIImageOrientationRight:  

        case UIImageOrientationRightMirrored:  

            // Grr...  

CGContextDrawImage (CTX, CGRectMake (0, 0, aImage. Size. Height, aImage. The size, width), aImage. CGImage);

            break;  

              

        default:  

CGContextDrawImage (CTX, CGRectMake (0, 0, aImage. Size. Width, aImage. The size, height), aImage. CGImage);

            break;  

    }  

      

    // And now we just create a new UIImage from the drawing context  

    CGImageRef cgimg = CGBitmapContextCreateImage(ctx);  

    UIImage *img = [UIImage imageWithCGImage:cgimg];  

    CGContextRelease(ctx);  

    CGImageRelease(cgimg);  

    return img;  

}

Copy the code

But sometimes when we get an image using AGImagePickerController, the original image may be rotated when it goes from ALAsset to UIImage, so here’s a solution:

            for (ALAsset * asset inself.assetArray) { CGImageRef ref = [[asset defaultRepresentation]fullResolutionImage]; UIImage *orgImage = [UIImage imageWithCGImage:[asset.defaultRepresentation fullScreenImage] scale:[asset.defaultRepresentation scale] orientation: (UIImageOrientation)[asset.defaultRepresentation orientation]]; / / this solved the problem orgImage = [UIImage imageWithCGImage: ref scale: 1 orientation: orgImage. ImageOrientation]; // XMLog(@"Raw selected imageOrientation===%ld",orgImage.imageOrientation); OrgImage = [self fixOrientation: orgImage]; [self.previewImageArray addObject:orgImage]; } [delegate imagePickerDidSelectImagearray:self.previewImageArray];Copy the code

However, the rotation problem would not have occurred if we had originally changed from ALAsset to UIImage using the following notation:

    ALAssetRepresentation *assetRep = [asset defaultRepresentation];
                CGImageRef imgRef = [assetRep fullResolutionImage];
                UIImage *orgImage = [UIImage imageWithCGImage:imgRef
                                                   scale:assetRep.scale
                                             orientation:(UIImageOrientation)assetRep.orientation];
Copy the code

Resources: Resource 1, Resource 2.