mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-08-18 19:40:19 +00:00
197 lines
8.1 KiB
Objective-C
197 lines
8.1 KiB
Objective-C
/* 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 -
|
|
@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 -
|
|
@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
|