2012-04-09 17 views
25

Mam aplikację do zdjęć, w której można dodawać naklejki w jednej sekcji. Kiedy skończysz, chcę zapisać obraz. Oto kod, który muszę to zrobić.Jak przycinać obraz w iOS

if(UIGraphicsBeginImageContextWithOptions != NULL) 
{ 
    UIGraphicsBeginImageContextWithOptions(self.view.frame.size, YES, 2.5); 
} else { 
    UIGraphicsBeginImageContext(self.view.frame.size); 
} 
CGContextRef contextNew=UIGraphicsGetCurrentContext(); 

[self.view.layer renderInContext:contextNew]; 

UIImage *image = UIGraphicsGetImageFromCurrentImageContext(); 

UIGraphicsEndImageContext(); 

Teraz obraz, który zostaje zapisany jest na pełnym ekranie obrazu, który jest w porządku, ale teraz muszę przyciąć obraz i nie wiem jak to zrobić. Można zobaczyć obraz w poniższy link: http://dl.dropbox.com/u/19130454/Photo%202012-04-09%201%2036%2018%20PM.png

muszę przyciąć: 91px od lewej i prawej 220px od dołu

Każda pomoc będzie mile widziana. Jeśli nie wyjaśniłem wszystkiego wyraźnie, proszę dać mi znać, a zrobię co w mojej mocy, aby ponownie wyjaśnić.

+1

To może być dobrym źródłem dla Ciebie: [Open Source Biblioteka Aby dodać przycinanie obrazu do aplikacji na iOS Szybko] (http://maniacdev.com/2011/10/open-source-library-to-add-image-cropping-into-an-ios-app-quickly/) – Lucien

+0

możliwy duplikat [Image Cropping API for iOS] (http://stackoverflow.com/questions/7087435/image-cropping-api-for-ios) – NAlexN

Odpowiedz

34

Jak o coś takiego

CGRect clippedRect = CGRectMake(self.view.frame.origin.x+91, self.view.frame.origin.y, self.view.frame.size.width-91*2, self.view.frame.size.height-220); 
CGImageRef imageRef = CGImageCreateWithImageInRect([image CGImage], clippedRect); 
UIImage *newImage = [UIImage imageWithCGImage:imageRef]; 
CGImageRelease(imageRef); 
+0

Dziękuję bardzo za pomoc. to działało idealnie! – flite3

+3

To ignoruje orientację obrazu, ponieważ UIImage obsługuje go, ale CGImage nie jest – Dustin

1
- (UIImage*)imageByCropping:(CGRect)rect 
{ 
    //create a context to do our clipping in 
    UIGraphicsBeginImageContext(rect.size); 
    CGContextRef currentContext = UIGraphicsGetCurrentContext(); 

    //create a rect with the size we want to crop the image to 
    //the X and Y here are zero so we start at the beginning of our 
    //newly created context 
    CGRect clippedRect = CGRectMake(0, 0, rect.size.width, rect.size.height); 
    CGContextClipToRect(currentContext, clippedRect); 

    //create a rect equivalent to the full size of the image 
    //offset the rect by the X and Y we want to start the crop 
    //from in order to cut off anything before them 
    CGRect drawRect = CGRectMake(rect.origin.x * -1, 
           rect.origin.y * -1, 
           self.size.width, 
           self.size.height); 

    //draw the image to our clipped context using our offset rect 
    // CGContextDrawImage(currentContext, drawRect, self.CGImage); 
    [self drawInRect:drawRect]; // This will fix getting inverted image from context. 

    //pull the image from our cropped context 
    UIImage *cropped = UIGraphicsGetImageFromCurrentImageContext(); 

    //pop the context to get back to the default 
    UIGraphicsEndImageContext(); 

    //Note: this is autoreleased 
    return cropped; 
} 
+1

czym jest self.CGImage? – Dvole

+1

Moja metoda ta powoduje, że obraz jest przycinany poprawnie zgodnie z oczekiwaniami. Ale został automatycznie odwrócony. Czy możesz mi pomóc dzięki temu. – iHulk

+0

@ user2534373 spróbuj usunąć ten UIGraphicsEndImageContext(); – Mohit

-1

Patrz poniższy link do wysiewania obrazu

https://github.com/myang-git/iOS-Image-Crop-View

** How to Use ** 

Very easy! It is created to be a drop-in component, so no static library, no extra dependencies. Just copy ImageCropView.h and ImageCropView.m to your project, and implement ImageCropViewControllerDelegate protocol. 
Use it like UIImagePicker: 
- (void)cropImage:(UIImage *)image{ 
    ImageCropViewController *controller = [[ImageCropViewController alloc] initWithImage:image]; 
    controller.delegate = self; 
    [[self navigationController] pushViewController:controller animated:YES]; 
} 
- (void)ImageCropViewController:(ImageCropViewController *)controller didFinishCroppingImage:(UIImage *)croppedImage{ 
    image = croppedImage; 
    imageView.image = croppedImage; 
    [[self navigationController] popViewControllerAnimated:YES]; 
} 
- (void)ImageCropViewControllerDidCancel:(ImageCropViewController *)controller{ 
    imageView.image = image; 
    [[self navigationController] popViewControllerAnimated:YES]; 
} 
+0

Proszę dodać trochę treści z linku. – Robert

+0

Witam moją ramani jedną pomoc .. mój obraz kadrowania projektu jak obraz kształtu twarzy również wiele różnych typów kształtu kadrowania i widok kadru przesuń i skaluj dla celu c –

+0

użyj tego demo do kadrowania obrazu https://github.com/gavinbunney/Toucan –

2

następujący kod może pomóc.

Należy uzyskać prawidłowy cropFrame pięścią metodą poniżej

-(CGRect)cropRectForFrame:(CGRect)frame 
{ 
    // NSAssert(self.contentMode == UIViewContentModeScaleAspectFit, @"content mode must be aspect fit"); 

    CGFloat widthScale = imageview.superview.bounds.size.width/imageview.image.size.width; 
    CGFloat heightScale = imageview.superview.bounds.size.height/imageview.image.size.height; 

    float x, y, w, h, offset; 
    if (widthScale<heightScale) { 
     offset = (imageview.superview.bounds.size.height - (imageview.image.size.height*widthScale))/2; 
     x = frame.origin.x/widthScale; 
     y = (frame.origin.y-offset)/widthScale; 
     w = frame.size.width/widthScale; 
     h = frame.size.height/widthScale; 
    } else { 
     offset = (imageview.superview.bounds.size.width - (imageview.image.size.width*heightScale))/2; 
     x = (frame.origin.x-offset)/heightScale; 
     y = frame.origin.y/heightScale; 
     w = frame.size.width/heightScale; 
     h = frame.size.height/heightScale; 
    } 
    return CGRectMake(x, y, w, h); 
} 

Następnie należy wywołać tę metodę, aby uzyskać przycięty obraz

- (UIImage *)imageByCropping:(UIImage *)image toRect:(CGRect)rect 
{ 
    // you need to update scaling factor value if deice is not retina display 
    UIGraphicsBeginImageContextWithOptions(rect.size, 
              /* your view opaque */ NO, 
              /* scaling factor */ 2.0); 

    // stick to methods on UIImage so that orientation etc. are automatically 
    // dealt with for us 
    [image drawAtPoint:CGPointMake(-rect.origin.x, -rect.origin.y)]; 

    UIImage *result = UIGraphicsGetImageFromCurrentImageContext(); 
    UIGraphicsEndImageContext(); 

    return result; 
} 
Powiązane problemy