From df40f482b02b57bb8c8314ef31da2a70e30f7612 Mon Sep 17 00:00:00 2001 From: Tore Hanssen Date: Mon, 16 May 2016 10:58:16 -0700 Subject: [PATCH] Callback with image height and width from IOSImagePicker Reviewed By: javache Differential Revision: D3301645 fbshipit-source-id: c771d491447f8ed9dc6c8685e273b99656336b0a --- Libraries/CameraRoll/RCTImagePickerManager.m | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/Libraries/CameraRoll/RCTImagePickerManager.m b/Libraries/CameraRoll/RCTImagePickerManager.m index e772ce081..a86062fab 100644 --- a/Libraries/CameraRoll/RCTImagePickerManager.m +++ b/Libraries/CameraRoll/RCTImagePickerManager.m @@ -108,8 +108,15 @@ didFinishPickingMediaWithInfo:(NSDictionary *)info BOOL isMovie = [mediaType isEqualToString:(NSString *)kUTTypeMovie]; NSString *key = isMovie ? UIImagePickerControllerMediaURL : UIImagePickerControllerReferenceURL; NSURL *imageURL = info[key]; + UIImage *image = info[UIImagePickerControllerOriginalImage]; + NSNumber *width = 0; + NSNumber *height = 0; + if (image) { + height = @(image.size.height); + width = @(image.size.width); + } if (imageURL) { - [self _dismissPicker:picker args:@[imageURL.absoluteString]]; + [self _dismissPicker:picker args:@[imageURL.absoluteString, RCTNullIfNil(height), RCTNullIfNil(width)]]; return; } @@ -120,7 +127,7 @@ didFinishPickingMediaWithInfo:(NSDictionary *)info // WARNING: Using ImageStoreManager may cause a memory leak because the // image isn't automatically removed from store once we're done using it. [_bridge.imageStoreManager storeImage:originalImage withBlock:^(NSString *tempImageTag) { - [self _dismissPicker:picker args:tempImageTag ? @[tempImageTag] : nil]; + [self _dismissPicker:picker args:tempImageTag ? @[tempImageTag, height, width] : nil]; }]; }