Quando si scattano foto con UIImagePickerController su iPhone, io e molti abitanti di internet abbiamo trovato che è necessario eseguire le immagini attraverso questa funzione per orientarle correttamente (e ridimensionarle mentre ci sei)Accelerare o eliminare questa funzione lenta in un'app per fotocamera iPhone
C'è un filo rosso gigante su di esso qui: http://discussions.apple.com/message.jspa?messageID=7276709
Purtroppo, questa funzione può prendere secondi per eseguire ed è davvero una seccatura. Se si desidera utilizzare questo e consentire agli utenti di scattare foto velocemente, è anche necessario aggiungere un NSLock o si verificheranno alcuni arresti anomali.
Come posso velocizzare o eliminare questo codice?
// orient photos and scale them to kMaxResolution
+ (UIImage*)scaleAndRotateImage:(UIImage *)image {
// we upload photos at a maximum resolution of 2048 x 1536
int kMaxResolution = 2048;
CGImageRef imgRef = image.CGImage;
CGFloat width = CGImageGetWidth(imgRef);
CGFloat height = CGImageGetHeight(imgRef);
CGAffineTransform transform = CGAffineTransformIdentity;
CGRect bounds = CGRectMake(0, 0, width, height);
if (width > kMaxResolution || height > kMaxResolution) {
CGFloat ratio = width/height;
if (ratio > 1) {
bounds.size.width = kMaxResolution;
bounds.size.height = bounds.size.width/ratio;
} else {
bounds.size.height = kMaxResolution;
bounds.size.width = bounds.size.height * ratio;
}
}
CGFloat scaleRatio = bounds.size.width/width;
CGSize imageSize = CGSizeMake(CGImageGetWidth(imgRef), CGImageGetHeight(imgRef));
CGFloat boundHeight;
UIImageOrientation orient = image.imageOrientation;
switch(orient) {
case UIImageOrientationUp: //EXIF = 1
transform = CGAffineTransformIdentity;
break;
case UIImageOrientationUpMirrored: //EXIF = 2
transform = CGAffineTransformMakeTranslation(imageSize.width, 0.0);
transform = CGAffineTransformScale(transform, -1.0, 1.0);
break;
case UIImageOrientationDown: //EXIF = 3
transform = CGAffineTransformMakeTranslation(imageSize.width, imageSize.height);
transform = CGAffineTransformRotate(transform, M_PI);
break;
case UIImageOrientationDownMirrored: //EXIF = 4
transform = CGAffineTransformMakeTranslation(0.0, imageSize.height);
transform = CGAffineTransformScale(transform, 1.0, -1.0);
break;
case UIImageOrientationLeftMirrored: //EXIF = 5
boundHeight = bounds.size.height;
bounds.size.height = bounds.size.width;
bounds.size.width = boundHeight;
transform = CGAffineTransformMakeTranslation(imageSize.height, imageSize.width);
transform = CGAffineTransformScale(transform, -1.0, 1.0);
transform = CGAffineTransformRotate(transform, 3.0 * M_PI/2.0);
break;
case UIImageOrientationLeft: //EXIF = 6
boundHeight = bounds.size.height;
bounds.size.height = bounds.size.width;
bounds.size.width = boundHeight;
transform = CGAffineTransformMakeTranslation(0.0, imageSize.width);
transform = CGAffineTransformRotate(transform, 3.0 * M_PI/2.0);
break;
case UIImageOrientationRightMirrored: //EXIF = 7
boundHeight = bounds.size.height;
bounds.size.height = bounds.size.width;
bounds.size.width = boundHeight;
transform = CGAffineTransformMakeScale(-1.0, 1.0);
transform = CGAffineTransformRotate(transform, M_PI/2.0);
break;
case UIImageOrientationRight: //EXIF = 8
boundHeight = bounds.size.height;
bounds.size.height = bounds.size.width;
bounds.size.width = boundHeight;
transform = CGAffineTransformMakeTranslation(imageSize.height, 0.0);
transform = CGAffineTransformRotate(transform, M_PI/2.0);
break;
default:
[NSException raise:NSInternalInconsistencyException format:@"Invalid image orientation"];
}
UIGraphicsBeginImageContext(bounds.size);
CGContextRef context = UIGraphicsGetCurrentContext();
if (orient == UIImageOrientationRight || orient == UIImageOrientationLeft) {
CGContextScaleCTM(context, -scaleRatio, scaleRatio);
CGContextTranslateCTM(context, -height, 0);
}
else {
CGContextScaleCTM(context, scaleRatio, -scaleRatio);
CGContextTranslateCTM(context, 0, -height);
}
CGContextConcatCTM(context, transform);
CGContextDrawImage(UIGraphicsGetCurrentContext(), CGRectMake(0, 0, width, height), imgRef);
UIImage *imageCopy = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
return imageCopy;
}
Sto usando anche questo codice. Solo per curiosità, dove sarebbe necessario applicare NSLock? Non ho visto alcun arresto anomalo quando si utilizza questo codice. Come intendi "consentire agli utenti di scattare foto velocemente"? – Jasarien
Per quello che voglio dire su NSLock, controlla l'ultimo paio di commenti su quel forum che ho collegato. Permettendo agli utenti di fare foto velocemente, intendo lo sfondo del salvataggio delle foto. Blocchi quando salvi le foto su disco? Inoltre, la mia app scrive i dati EXIF sulle foto in questo processo, quindi c'è un lavoro aggiuntivo che sottolinea la memoria. –
Io uso qualcosa di simile ed è molto, molto lento. Probabilmente c'è un modo migliore, di cui non sono a conoscenza ... Buona domanda. – Jordan