2015-03-23 15:07:33 -07:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the BSD-style license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
|
|
*/
|
2015-03-10 19:11:28 -07:00
|
|
|
|
2015-07-14 04:06:17 -07:00
|
|
|
#import <UIKit/UIKit.h>
|
2015-03-10 19:11:28 -07:00
|
|
|
|
2015-07-27 08:48:31 -07:00
|
|
|
#import "RCTBridge.h"
|
2015-09-02 08:25:10 -07:00
|
|
|
#import "RCTURLRequestHandler.h"
|
2015-07-27 08:48:31 -07:00
|
|
|
|
2015-03-10 19:11:28 -07:00
|
|
|
@class ALAssetsLibrary;
|
|
|
|
|
2015-07-27 13:46:59 -07:00
|
|
|
typedef void (^RCTImageLoaderProgressBlock)(int64_t progress, int64_t total);
|
2015-09-04 04:35:44 -07:00
|
|
|
typedef void (^RCTImageLoaderCompletionBlock)(NSError *error, UIImage *image);
|
2015-07-15 19:17:13 -01:00
|
|
|
typedef void (^RCTImageLoaderCancellationBlock)(void);
|
|
|
|
|
2015-09-04 04:35:44 -07:00
|
|
|
@interface UIImage (React)
|
|
|
|
|
|
|
|
@property (nonatomic, copy) CAKeyframeAnimation *reactKeyframeAnimation;
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
2015-09-02 08:25:10 -07:00
|
|
|
@interface RCTImageLoader : NSObject <RCTBridgeModule, RCTURLRequestHandler>
|
2015-05-11 13:08:39 -07:00
|
|
|
|
|
|
|
/**
|
2015-07-27 08:48:31 -07:00
|
|
|
* Loads the specified image at the highest available resolution.
|
|
|
|
* Can be called from any thread, will always call callback on main thread.
|
2015-05-11 13:08:39 -07:00
|
|
|
*/
|
2015-07-27 08:48:31 -07:00
|
|
|
- (RCTImageLoaderCancellationBlock)loadImageWithTag:(NSString *)imageTag
|
2015-07-15 19:17:13 -01:00
|
|
|
callback:(RCTImageLoaderCompletionBlock)callback;
|
2015-03-10 19:11:28 -07:00
|
|
|
|
2015-07-14 04:06:17 -07:00
|
|
|
/**
|
|
|
|
* As above, but includes target size, scale and resizeMode, which are used to
|
|
|
|
* select the optimal dimensions for the loaded image.
|
|
|
|
*/
|
2015-07-27 08:48:31 -07:00
|
|
|
- (RCTImageLoaderCancellationBlock)loadImageWithTag:(NSString *)imageTag
|
2015-07-15 19:17:13 -01:00
|
|
|
size:(CGSize)size
|
|
|
|
scale:(CGFloat)scale
|
|
|
|
resizeMode:(UIViewContentMode)resizeMode
|
2015-07-27 13:46:59 -07:00
|
|
|
progressBlock:(RCTImageLoaderProgressBlock)progressBlock
|
|
|
|
completionBlock:(RCTImageLoaderCompletionBlock)completionBlock;
|
2015-07-14 04:06:17 -07:00
|
|
|
|
|
|
|
/**
|
2015-09-02 08:25:10 -07:00
|
|
|
* Finds an appropriate image decoder and passes the target size, scale and
|
|
|
|
* resizeMode for optimal image decoding.
|
2015-07-14 04:06:17 -07:00
|
|
|
*/
|
2015-09-02 08:25:10 -07:00
|
|
|
- (RCTImageLoaderCancellationBlock)decodeImageData:(NSData *)imageData
|
|
|
|
size:(CGSize)size
|
|
|
|
scale:(CGFloat)scale
|
|
|
|
resizeMode:(UIViewContentMode)resizeMode
|
|
|
|
completionBlock:(RCTImageLoaderCompletionBlock)completionBlock;
|
2015-07-15 19:17:13 -01:00
|
|
|
|
2015-03-10 19:11:28 -07:00
|
|
|
@end
|
2015-07-27 08:48:31 -07:00
|
|
|
|
|
|
|
@interface RCTBridge (RCTImageLoader)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The shared image loader instance
|
|
|
|
*/
|
|
|
|
@property (nonatomic, readonly) RCTImageLoader *imageLoader;
|
|
|
|
|
2015-09-02 08:25:10 -07:00
|
|
|
@end
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Provides the interface needed to register an image data loader. Image data
|
|
|
|
* loaders are also bridge modules, so should be registered using
|
|
|
|
* RCT_EXPORT_MODULE().
|
|
|
|
*/
|
|
|
|
@protocol RCTImageURLLoader <RCTBridgeModule>
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Indicates whether this data loader is capable of processing the specified
|
|
|
|
* request URL. Typically the handler would examine the scheme/protocol of the
|
|
|
|
* URL to determine this.
|
|
|
|
*/
|
|
|
|
- (BOOL)canLoadImageURL:(NSURL *)requestURL;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Send a network request to load the request URL. The method should call the
|
|
|
|
* progressHandler (if applicable) and the completionHandler when the request
|
|
|
|
* has finished. The method should also return a cancellation block, if
|
|
|
|
* applicable.
|
|
|
|
*/
|
|
|
|
- (RCTImageLoaderCancellationBlock)loadImageForURL:(NSURL *)imageURL size:(CGSize)size scale:(CGFloat)scale resizeMode:(UIViewContentMode)resizeMode progressHandler:(RCTImageLoaderProgressBlock)progressHandler completionHandler:(RCTImageLoaderCompletionBlock)completionHandler;
|
|
|
|
|
|
|
|
@optional
|
|
|
|
|
|
|
|
/**
|
|
|
|
* If more than one RCTImageURLLoader responds YES to `-canLoadImageURL:`
|
|
|
|
* then `imageLoaderPriority` is used to determine which one to use. The handler
|
|
|
|
* with the highest priority will be selected. Default priority is zero. If
|
|
|
|
* two or more valid handlers have the same priority, the selection order is
|
|
|
|
* undefined.
|
|
|
|
*/
|
|
|
|
- (float)imageLoaderPriority;
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Provides the interface needed to register an image decoder. Image decoders
|
|
|
|
* are also bridge modules, so should be registered using RCT_EXPORT_MODULE().
|
|
|
|
*/
|
|
|
|
@protocol RCTImageDecoder <RCTBridgeModule>
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Indicates whether this handler is capable of decoding the specified data.
|
|
|
|
* Typically the handler would examine some sort of header data to determine
|
|
|
|
* this.
|
|
|
|
*/
|
|
|
|
- (BOOL)canDecodeImageData:(NSData *)imageData;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Decode an image from the data object. The method should call the
|
|
|
|
* completionHandler when the decoding operation has finished. The method
|
|
|
|
* should also return a cancellation block, if applicable.
|
|
|
|
*/
|
|
|
|
- (RCTImageLoaderCancellationBlock)decodeImageData:(NSData *)imageData size:(CGSize)size scale:(CGFloat)scale resizeMode:(UIViewContentMode)resizeMode completionHandler:(RCTImageLoaderCompletionBlock)completionHandler;
|
|
|
|
|
|
|
|
@optional
|
|
|
|
|
2015-07-27 08:48:31 -07:00
|
|
|
/**
|
2015-09-02 08:25:10 -07:00
|
|
|
* If more than one RCTImageDecoder responds YES to `-canDecodeImageData:`
|
|
|
|
* then `imageDecoderPriority` is used to determine which one to use. The
|
|
|
|
* handler with the highest priority will be selected. Default priority is zero.
|
|
|
|
* If two or more valid handlers have the same priority, the selection order is
|
|
|
|
* undefined.
|
2015-07-27 08:48:31 -07:00
|
|
|
*/
|
2015-09-02 08:25:10 -07:00
|
|
|
- (float)imageDecoderPriority;
|
2015-07-27 08:48:31 -07:00
|
|
|
|
|
|
|
@end
|