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-01-29 17:10:49 -08:00
|
|
|
|
|
|
|
#import <UIKit/UIKit.h>
|
|
|
|
|
2015-02-03 16:15:20 -08:00
|
|
|
typedef void (^RCTDataDownloadBlock)(NSData *data, NSError *error);
|
2015-01-29 17:10:49 -08:00
|
|
|
typedef void (^RCTImageDownloadBlock)(UIImage *image, NSError *error);
|
|
|
|
|
|
|
|
@interface RCTImageDownloader : NSObject
|
|
|
|
|
2015-06-29 05:15:25 -07:00
|
|
|
+ (RCTImageDownloader *)sharedInstance;
|
2015-01-29 17:10:49 -08:00
|
|
|
|
2015-03-30 20:12:32 -07:00
|
|
|
/**
|
|
|
|
* Downloads a block of raw data and returns it. Note that the callback block
|
|
|
|
* will not be executed on the same thread you called the method from, nor on
|
|
|
|
* the main thread. Returns a token that can be used to cancel the download.
|
|
|
|
*/
|
2015-02-03 16:15:20 -08:00
|
|
|
- (id)downloadDataForURL:(NSURL *)url
|
|
|
|
block:(RCTDataDownloadBlock)block;
|
|
|
|
|
2015-03-30 20:12:32 -07:00
|
|
|
/**
|
|
|
|
* Downloads an image and decompresses it a the size specified. The compressed
|
|
|
|
* image will be cached in memory and to disk. Note that the callback block
|
|
|
|
* will not be executed on the same thread you called the method from, nor on
|
|
|
|
* the main thread. Returns a token that can be used to cancel the download.
|
|
|
|
*/
|
2015-01-29 17:10:49 -08:00
|
|
|
- (id)downloadImageForURL:(NSURL *)url
|
|
|
|
size:(CGSize)size
|
|
|
|
scale:(CGFloat)scale
|
2015-05-22 07:17:08 -07:00
|
|
|
resizeMode:(UIViewContentMode)resizeMode
|
|
|
|
backgroundColor:(UIColor *)backgroundColor
|
2015-01-29 17:10:49 -08:00
|
|
|
block:(RCTImageDownloadBlock)block;
|
|
|
|
|
2015-03-30 20:12:32 -07:00
|
|
|
/**
|
|
|
|
* Cancel an in-flight download. If multiple requets have been made for the
|
|
|
|
* same image, only the request that relates to the token passed will be
|
|
|
|
* cancelled.
|
|
|
|
*/
|
2015-01-29 17:10:49 -08:00
|
|
|
- (void)cancelDownload:(id)downloadToken;
|
|
|
|
|
|
|
|
@end
|