| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206 |
- /* Copyright (c) 2014-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.
- */
- #import <AsyncDisplayKit/ASImageNode.h>
- #import <AsyncDisplayKit/ASImageProtocols.h>
- @protocol ASMultiplexImageNodeDelegate;
- @protocol ASMultiplexImageNodeDataSource;
- extern NSString *const ASMultiplexImageNodeErrorDomain;
- /**
- * ASMultiplexImageNode error codes.
- */
- typedef NS_ENUM(NSUInteger, ASMultiplexImageNodeErrorCode) {
- /**
- * Indicates that the data source didn't provide a source for an image identifier.
- */
- ASMultiplexImageNodeErrorCodeNoSourceForImage = 0,
- /**
- * Indicates that the best image identifier changed before a download for a worse identifier began.
- */
- ASMultiplexImageNodeErrorCodeBestImageIdentifierChanged,
- };
- /**
- * @abstract ASMultiplexImageNode is an image node that can load and display multiple versions of an image. For
- * example, it can display a low-resolution version of an image while the high-resolution version is loading.
- *
- * @discussion ASMultiplexImageNode begins loading images when its <imageIdentifiers> property is set. For each image
- * identifier, the data source can either return a UIImage directly, or a URL the image node should load.
- */
- @interface ASMultiplexImageNode : ASImageNode
- /**
- * @abstract The designated initializer.
- * @param cache The object that implements a cache of images for the image node.
- * @param downloader The object that implements image downloading for the image node.
- * @discussion If `cache` is nil, the receiver will not attempt to retrieve images from a cache before downloading them.
- * @returns An initialized ASMultiplexImageNode.
- */
- - (instancetype)initWithCache:(id<ASImageCacheProtocol>)cache downloader:(id<ASImageDownloaderProtocol>)downloader NS_DESIGNATED_INITIALIZER;
- /**
- * @abstract The delegate, which must conform to the <ASMultiplexImageNodeDelegate> protocol.
- */
- @property (nonatomic, readwrite, weak) id <ASMultiplexImageNodeDelegate> delegate;
- /**
- * @abstract The data source, which must conform to the <ASMultiplexImageNodeDataSource> protocol.
- * @discussion This value is required for ASMultiplexImageNode to load images.
- */
- @property (nonatomic, readwrite, weak) id <ASMultiplexImageNodeDataSource> dataSource;
- /**
- * @abstract Whether the receiver should download more than just its highest-quality image. Defaults to NO.
- *
- * @discussion ASMultiplexImageNode immediately loads and displays the first image specified in <imageIdentifiers> (its
- * highest-quality image). If that image is not immediately available or cached, the node can download and display
- * lesser-quality images. Set `downloadsIntermediateImages` to YES to enable this behaviour.
- */
- @property (nonatomic, readwrite, assign) BOOL downloadsIntermediateImages;
- /**
- * @abstract An array of identifiers representing various versions of an image for ASMultiplexImageNode to display.
- *
- * @discussion An identifier can be any object that conforms to NSObject and NSCopying. The array should be in
- * decreasing order of image quality -- that is, the first identifier in the array represents the best version.
- *
- * @see <downloadsIntermediateImages> for more information on the image loading process.
- */
- @property (nonatomic, readwrite, copy) NSArray *imageIdentifiers;
- /**
- * @abstract Notify the receiver that its data source has new UIImages or NSURLs available for <imageIdentifiers>.
- *
- * @discussion If a higher-quality image than is currently displayed is now available, it will be loaded.
- */
- - (void)reloadImageIdentifierSources;
- /**
- * @abstract The identifier for the last image that the receiver loaded, or nil.
- *
- * @discussion This value may differ from <displayedImageIdentifier> if the image hasn't yet been displayed.
- */
- @property (nonatomic, readonly) id loadedImageIdentifier;
- /**
- * @abstract The identifier for the image that the receiver is currently displaying, or nil.
- */
- @property (nonatomic, readonly) id displayedImageIdentifier;
- @end
- #pragma mark -
- /**
- * The methods declared by the ASMultiplexImageNodeDelegate protocol allow the adopting delegate to respond to
- * notifications such as began, progressed and finished downloading, updated and displayed an image.
- */
- @protocol ASMultiplexImageNodeDelegate <NSObject>
- @optional
- /**
- * @abstract Notification that the image node began downloading an image.
- * @param imageNode The sender.
- * @param imageIdentifier The identifier for the image that is downloading.
- */
- - (void)multiplexImageNode:(ASMultiplexImageNode *)imageNode didStartDownloadOfImageWithIdentifier:(id)imageIdentifier;
- /**
- * @abstract Notification that the image node's download progressed.
- * @param imageNode The sender.
- * @param downloadProgress The progress of the download. Value is between 0.0 and 1.0.
- * @param imageIdentifier The identifier for the image that is downloading.
- */
- - (void)multiplexImageNode:(ASMultiplexImageNode *)imageNode
- didUpdateDownloadProgress:(CGFloat)downloadProgress
- forImageWithIdentifier:(id)imageIdentifier;
- /**
- * @abstract Notification that the image node's download has finished.
- * @param imageNode The sender.
- * @param imageIdentifier The identifier for the image that finished downloading.
- * @param error The error that occurred while downloading, if one occurred; nil otherwise.
- */
- - (void)multiplexImageNode:(ASMultiplexImageNode *)imageNode
- didFinishDownloadingImageWithIdentifier:(id)imageIdentifier
- error:(NSError *)error;
- /**
- * @abstract Notification that the image node's image was updated.
- * @param imageNode The sender.
- * @param image The new image, ready for display.
- * @param imageIdentifier The identifier for `image`.
- * @param previousImage The old, previously-loaded image.
- * @param previousImageIdentifier The identifier for `previousImage`.
- * @note This method does not indicate that `image` has been displayed.
- * @see <[ASMultiplexImageNodeDelegate multiplexImageNode:didDisplayUpdatedImage:withIdentifier:]>.
- */
- - (void)multiplexImageNode:(ASMultiplexImageNode *)imageNode
- didUpdateImage:(UIImage *)image
- withIdentifier:(id)imageIdentifier
- fromImage:(UIImage *)previousImage
- withIdentifier:(id)previousImageIdentifier;
- /**
- * @abstract Notification that the image node displayed a new image.
- * @param imageNode The sender.
- * @param image The new image, now being displayed.
- * @param imageIdentifier The identifier for `image`.
- * @discussion This method is only called when `image` changes, and not on subsequent redisplays of the same image.
- */
- - (void)multiplexImageNode:(ASMultiplexImageNode *)imageNode
- didDisplayUpdatedImage:(UIImage *)image
- withIdentifier:(id)imageIdentifier;
- /**
- * @abstract Notification that the image node finished displaying an image.
- * @param imageNode The sender.
- * @discussion This method is called every time an image is displayed, whether or not it has changed.
- */
- - (void)multiplexImageNodeDidFinishDisplay:(ASMultiplexImageNode *)imageNode;
- @end
- #pragma mark -
- /**
- * The ASMultiplexImageNodeDataSource protocol is adopted by an object that provides the multiplex image node,
- * for each image identifier, an image or a URL the image node should load.
- */
- @protocol ASMultiplexImageNodeDataSource <NSObject>
- @optional
- /**
- * @abstract An image for the specified identifier.
- * @param imageNode The sender.
- * @param imageIdentifier The identifier for the image that should be returned.
- * @discussion If the image is already available to the data source, this method should be used in lieu of providing the
- * URL to the image via -multiplexImageNode:URLForImageIdentifier:.
- * @returns A UIImage corresponding to `imageIdentifier`, or nil if none is available.
- */
- - (UIImage *)multiplexImageNode:(ASMultiplexImageNode *)imageNode imageForImageIdentifier:(id)imageIdentifier;
- /**
- * @abstract An image URL for the specified identifier.
- * @param imageNode The sender.
- * @param imageIdentifier The identifier for the image that will be downloaded.
- * @discussion Supported URLs include assets-library, Photo framework URLs (ph://), HTTP, HTTPS, and FTP URLs. If the
- * image is already available to the data source, it should be provided via <[ASMultiplexImageNodeDataSource
- * multiplexImageNode:imageForImageIdentifier:]> instead.
- * @returns An NSURL for the image identified by `imageIdentifier`, or nil if none is available.
- */
- - (NSURL *)multiplexImageNode:(ASMultiplexImageNode *)imageNode URLForImageIdentifier:(id)imageIdentifier;
- @end
|