1

NSUserDefault画像 ( )UIImagePickerControllerを iPhoneに保存しようとしました。

保存された画像へのこの方法:

ここに画像の説明を入力

-(void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info
{
    UIImage *originalImage=[info objectForKey:UIImagePickerControllerOriginalImage];
    NSData * imageData = UIImagePNGRepresentation(originalImage);
    NSUserDefaults *user = [NSUserDefaults standardUserDefaults];
    [user setValue:imageData forKey:@"pictureData"];
}

画像を取得するこの方法:

NSUserDefaults *user = [NSUserDefaults standardUserDefaults];
UIImage *myImage = [UIImage imageWithData:[user valueForKey:@"pictureData"]];
[btn2 setImage:myImage forState:UIControlStateNormal];

ここに画像の説明を入力

NSUserDefaultsから setに画像を取得するとUIButton、最終的に画像が表示されますが、方向が下から右に変わります。この問題を修正するにはどうすればよいですか? 私を助けてください

4

2 に答える 2

2

AUIImageには プロパティがあり、と他のコンシューマーに生の画像データを回転するimageOrientationよう指示します。このフラグがアップロードされた jpeg 画像の exif データに保存されている可能性は十分にありますが、表示に使用するプログラムはそのフラグを尊重していません。UIImageViewUIImage

アップロード時に適切に表示されるように を回転するUIImageには、次のようなカテゴリを使用できます。

UIImage+fixOrientation.h

@interface UIImage (fixOrientation)

 - (UIImage *)fixOrientation;

@end

UIImage+fixOrientation.m

@implementation UIImage (fixOrientation)

 - (UIImage *)fixOrientation {

// No-op if the orientation is already correct
if (self.imageOrientation == UIImageOrientationUp) return self;

// 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 (self.imageOrientation) {
    case UIImageOrientationDown:
    case UIImageOrientationDownMirrored:
        transform = CGAffineTransformTranslate(transform, self.size.width, self.size.height);
        transform = CGAffineTransformRotate(transform, M_PI);
        break;

    case UIImageOrientationLeft:
    case UIImageOrientationLeftMirrored:
        transform = CGAffineTransformTranslate(transform, self.size.width, 0);
        transform = CGAffineTransformRotate(transform, M_PI_2);
        break;

    case UIImageOrientationRight:
    case UIImageOrientationRightMirrored:
        transform = CGAffineTransformTranslate(transform, 0, self.size.height);
        transform = CGAffineTransformRotate(transform, -M_PI_2);
        break;
    case UIImageOrientationUp:
    case UIImageOrientationUpMirrored:
        break;
}

switch (self.imageOrientation) {
    case UIImageOrientationUpMirrored:
    case UIImageOrientationDownMirrored:
        transform = CGAffineTransformTranslate(transform, self.size.width, 0);
        transform = CGAffineTransformScale(transform, -1, 1);
        break;

    case UIImageOrientationLeftMirrored:
    case UIImageOrientationRightMirrored:
        transform = CGAffineTransformTranslate(transform, self.size.height, 0);
        transform = CGAffineTransformScale(transform, -1, 1);
        break;
    case UIImageOrientationUp:
    case UIImageOrientationDown:
    case UIImageOrientationLeft:
    case UIImageOrientationRight:
        break;
}

// Now we draw the underlying CGImage into a new context, applying the transform
// calculated above.
CGContextRef ctx = CGBitmapContextCreate(NULL, self.size.width, self.size.height,
                                         CGImageGetBitsPerComponent(self.CGImage), 0,
                                         CGImageGetColorSpace(self.CGImage),
                                         CGImageGetBitmapInfo(self.CGImage));
CGContextConcatCTM(ctx, transform);
switch (self.imageOrientation) {
    case UIImageOrientationLeft:
    case UIImageOrientationLeftMirrored:
    case UIImageOrientationRight:
    case UIImageOrientationRightMirrored:
        // Grr...
        CGContextDrawImage(ctx, CGRectMake(0,0,self.size.height,self.size.width), self.CGImage);
        break;

    default:
        CGContextDrawImage(ctx, CGRectMake(0,0,self.size.width,self.size.height), self.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;
}

@end
于 2012-11-27T10:39:03.023 に答える
1

次の方法UIImageJPEGRepresentationで画像を保存するために使用します。NSUserDefaults

NSData * imageData = UIImageJPEGRepresentation(originalImage, 90);
NSUserDefaults *user = [NSUserDefaults standardUserDefaults];
[user setValue:imageData forKey:@"pictureData"];
于 2012-11-27T11:27:56.027 に答える