質問

I encountered a problem when I pinch, pan or rotate a UIImageview in drawInRect, the transform is not being preserved.

How can I preserve the transform in drawInRect?

I tried this but no go :(

- (UIImage*) combineImage:(UIImageView *)selectedImage withOverlay:(UIImageView *)overlayImage
{
    /* Identify the region that needs to be cropped */
    CGRect viewForImgFrame = self.viewForImg.frame;
    NSLog(@"view %@", NSStringFromCGRect(viewForImgFrame));
    NSLog(@"selectedImage Img value %@",selectedImage);
    NSLog(@"overlayImage Img value %@",overlayImage);
    CGSize newImageSize =self.viewForImg.frame.size;
    NSLog(@"CGSize %@",NSStringFromCGSize(newImageSize));
    UIGraphicsBeginImageContextWithOptions(newImageSize, NO, 0.0); //retina res

   //[self.viewForImg.layer renderInContext:UIGraphicsGetCurrentContext()];

    [selectedImage.image drawInRect:CGRectMake(0, 0, selectedImage.frame.size.width, selectedImage.frame.size.height)];

    CGContextConcatCTM(UIGraphicsGetCurrentContext(), overlayImage.transform);

    [overlayImage.image drawInRect:CGRectMake(overlayImage.frame.origin.x, overlayImage.frame.origin.y, overlayImage.frame.size.width, overlayImage.frame.size.height)];


    UIImage *image = UIGraphicsGetImageFromCurrentImageContext();
    NSData *imgData =  UIImageJPEGRepresentation(image, 0.9); //UIImagePNGRepresentation ( image ); // get JPEG representation
    UIImage * imagePNG = [UIImage imageWithData:imgData]; // wrap UIImage around PNG representation
    UIGraphicsEndImageContext();
    return imagePNG;
}

Any comments are greatly appreciated.

役に立ちましたか?

解決 2

It turned out that the AutoresizingMask changed rect size

 [slider setAutoresizingMask:UIViewAutoresizingNone];

他のヒント

you need to try

CGRectApplyAffineTransform(<#CGRect rect#>, <#CGAffineTransform t#>)

your code should be like

CGContextConcatCTM(UIGraphicsGetCurrentContext(), overlayImage.transform);
CGRect rect = CGRectMake(overlayImage.frame.origin.x, overlayImage.frame.origin.y, overlayImage.frame.size.width, overlayImage.frame.size.height);
CGRect transformedRect = CGRectApplyAffineTransform(rect, overlayImage.transform);
[overlayImage.image drawInRect:transformedRect];
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top