Update the documentation coverage for jazzy. Use the correct format to provide class/protocol/type API Documentation

This commit is contained in:
DreamPiggy 2019-05-10 17:20:49 +08:00
parent 6c16889628
commit 0783287f95
40 changed files with 252 additions and 59 deletions

View File

@ -12,6 +12,9 @@
#import "SDWebImageManager.h" #import "SDWebImageManager.h"
/**
* Integrates SDWebImage async downloading and caching of remote images with NSButton.
*/
@interface NSButton (WebCache) @interface NSButton (WebCache)
#pragma mark - Image #pragma mark - Image

View File

@ -24,6 +24,9 @@ static const SDImageFormat SDImageFormatWebP = 4;
static const SDImageFormat SDImageFormatHEIC = 5; static const SDImageFormat SDImageFormatHEIC = 5;
static const SDImageFormat SDImageFormatHEIF = 6; static const SDImageFormat SDImageFormatHEIF = 6;
/**
NSData category about the image content type and UTI
*/
@interface NSData (ImageContentType) @interface NSData (ImageContentType)
/** /**

View File

@ -8,10 +8,11 @@
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
// This category is provided to easily write cross-platform(AppKit/UIKit) code. For common usage, see `UIImage+Metadata.h`.
#if SD_MAC #if SD_MAC
/**
This category is provided to easily write cross-platform(AppKit/UIKit) code. For common usage, see `UIImage+Metadata.h`.
*/
@interface NSImage (Compatibility) @interface NSImage (Compatibility)
/** /**

View File

@ -59,6 +59,9 @@
@end @end
/**
The image class which supports animating on `SDAnimatedImageView`. You can also use it on normal UIImageView/NSImageView
*/
@interface SDAnimatedImage : UIImage <SDAnimatedImage> @interface SDAnimatedImage : UIImage <SDAnimatedImage>
// This class override these methods from UIImage(NSImage), and it supports NSSecureCoding. // This class override these methods from UIImage(NSImage), and it supports NSSecureCoding.

View File

@ -10,10 +10,11 @@
#if SD_MAC #if SD_MAC
// A subclass of `NSBitmapImageRep` to fix that GIF loop count issue because `NSBitmapImageRep` will reset `NSImageCurrentFrameDuration` by using `kCGImagePropertyGIFDelayTime` but not `kCGImagePropertyGIFUnclampedDelayTime`. /**
// Built in GIF coder use this instead of `NSBitmapImageRep` for better GIF rendering. If you do not want this, only enable `SDImageIOCoder`, which just call `NSImage` API and actually use `NSBitmapImageRep` for GIF image. A subclass of `NSBitmapImageRep` to fix that GIF loop count issue because `NSBitmapImageRep` will reset `NSImageCurrentFrameDuration` by using `kCGImagePropertyGIFDelayTime` but not `kCGImagePropertyGIFUnclampedDelayTime`.
// This also support APNG format using `SDImageAPNGCoder`. Which provide full alpha-channel support and the correct duration match the `kCGImagePropertyAPNGUnclampedDelayTime`. Built in GIF coder use this instead of `NSBitmapImageRep` for better GIF rendering. If you do not want this, only enable `SDImageIOCoder`, which just call `NSImage` API and actually use `NSBitmapImageRep` for GIF image.
This also support APNG format using `SDImageAPNGCoder`. Which provide full alpha-channel support and the correct duration match the `kCGImagePropertyAPNGUnclampedDelayTime`.
*/
@interface SDAnimatedImageRep : NSBitmapImageRep @interface SDAnimatedImageRep : NSBitmapImageRep
@end @end

View File

@ -12,6 +12,9 @@
#import "SDWebImageManager.h" #import "SDWebImageManager.h"
/**
Integrates SDWebImage async downloading and caching of remote images with SDAnimatedImageView.
*/
@interface SDAnimatedImageView (WebCache) @interface SDAnimatedImageView (WebCache)
/** /**

View File

@ -9,7 +9,9 @@
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
@class SDImageCacheConfig; @class SDImageCacheConfig;
// A protocol to allow custom disk cache used in SDImageCache. /**
A protocol to allow custom disk cache used in SDImageCache.
*/
@protocol SDDiskCache <NSObject> @protocol SDDiskCache <NSObject>
// All of these method are called from the same global queue to avoid blocking on main queue and thread-safe problem. But it's also recommend to ensure thread-safe yourself using lock or other ways. // All of these method are called from the same global queue to avoid blocking on main queue and thread-safe problem. But it's also recommend to ensure thread-safe yourself using lock or other ways.
@ -97,9 +99,13 @@
@end @end
// The built-in disk cache /**
The built-in disk cache
*/
@interface SDDiskCache : NSObject <SDDiskCache> @interface SDDiskCache : NSObject <SDDiskCache>
/**
Cache Config object - storing all kind of settings.
*/
@property (nonatomic, strong, readonly, nonnull) SDImageCacheConfig *config; @property (nonatomic, strong, readonly, nonnull) SDImageCacheConfig *config;
- (nonnull instancetype)init NS_UNAVAILABLE; - (nonnull instancetype)init NS_UNAVAILABLE;

View File

@ -12,6 +12,7 @@
#import "SDImageCacheConfig.h" #import "SDImageCacheConfig.h"
#import "SDImageCacheDefine.h" #import "SDImageCacheDefine.h"
/// Image Cache Options
typedef NS_OPTIONS(NSUInteger, SDImageCacheOptions) { typedef NS_OPTIONS(NSUInteger, SDImageCacheOptions) {
/** /**
* By default, we do not query image data when the image is already cached in memory. This mask can force to query image data at the same time. However, this query is asynchronously unless you specify `SDImageCacheQueryMemoryDataSync` * By default, we do not query image data when the image is already cached in memory. This mask can force to query image data at the same time. However, this query is asynchronously unless you specify `SDImageCacheQueryMemoryDataSync`

View File

@ -9,6 +9,7 @@
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
/// Image Cache Expire Type
typedef NS_ENUM(NSUInteger, SDImageCacheConfigExpireType) { typedef NS_ENUM(NSUInteger, SDImageCacheConfigExpireType) {
/** /**
* When the image is accessed it will update this value * When the image is accessed it will update this value
@ -20,7 +21,10 @@ typedef NS_ENUM(NSUInteger, SDImageCacheConfigExpireType) {
SDImageCacheConfigExpireTypeModificationDate SDImageCacheConfigExpireTypeModificationDate
}; };
// This class conform to NSCopying, make sure to add the property in `copyWithZone:` as well. /**
The class contains all the config for image cache
@note This class conform to NSCopying, make sure to add the property in `copyWithZone:` as well.
*/
@interface SDImageCacheConfig : NSObject <NSCopying> @interface SDImageCacheConfig : NSObject <NSCopying>
/** /**

View File

@ -11,6 +11,7 @@
#import "SDWebImageOperation.h" #import "SDWebImageOperation.h"
#import "SDWebImageDefine.h" #import "SDWebImageDefine.h"
/// Image Cache Type
typedef NS_ENUM(NSInteger, SDImageCacheType) { typedef NS_ENUM(NSInteger, SDImageCacheType) {
/** /**
* For query and contains op in response, means the image isn't available in the image cache * For query and contains op in response, means the image isn't available in the image cache

View File

@ -9,6 +9,7 @@
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>
#import "SDImageCacheDefine.h" #import "SDImageCacheDefine.h"
/// Policy for cache operation
typedef NS_ENUM(NSUInteger, SDImageCachesManagerOperationPolicy) { typedef NS_ENUM(NSUInteger, SDImageCachesManagerOperationPolicy) {
SDImageCachesManagerOperationPolicySerial, // process all caches serially (from the highest priority to the lowest priority cache by order) SDImageCachesManagerOperationPolicySerial, // process all caches serially (from the highest priority to the lowest priority cache by order)
SDImageCachesManagerOperationPolicyConcurrent, // process all caches concurrently SDImageCachesManagerOperationPolicyConcurrent, // process all caches concurrently
@ -16,6 +17,9 @@ typedef NS_ENUM(NSUInteger, SDImageCachesManagerOperationPolicy) {
SDImageCachesManagerOperationPolicyLowestOnly // process the lowest priority cache only SDImageCachesManagerOperationPolicyLowestOnly // process the lowest priority cache only
}; };
/**
A caches manager to manage multiple caches
*/
@interface SDImageCachesManager : NSObject <SDImageCache> @interface SDImageCachesManager : NSObject <SDImageCache>
/** /**

View File

@ -10,6 +10,9 @@
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
#import "SDImageFrame.h" #import "SDImageFrame.h"
/**
Provide some common helper methods for building the image decoder/encoder
*/
@interface SDImageCoderHelper : NSObject @interface SDImageCoderHelper : NSObject
/** /**

View File

@ -9,10 +9,12 @@
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
/**
This class is used for creating animated images via `animatedImageWithFrames` in `SDImageCoderHelper`.
@note Attention if you need to specify animated images loop count, use `sd_imageLoopCount` property in `UIImage+Metadata.h`.
*/
@interface SDImageFrame : NSObject @interface SDImageFrame : NSObject
// This class is used for creating animated images via `animatedImageWithFrames` in `SDImageCoderHelper`. Attention if you need to specify animated images loop count, use `sd_imageLoopCount` property in `UIImage+Metadata.h`.
/** /**
The image of current frame. You should not set an animated image. The image of current frame. You should not set an animated image.
*/ */

View File

@ -14,8 +14,14 @@
For UIKit, these methods just call the same method in `UIGraphics.h`. See the documentation for usage. For UIKit, these methods just call the same method in `UIGraphics.h`. See the documentation for usage.
For AppKit, these methods use `NSGraphicsContext` to create image context and match the behavior like UIKit. For AppKit, these methods use `NSGraphicsContext` to create image context and match the behavior like UIKit.
*/ */
/// Returns the current graphics context.
FOUNDATION_EXPORT CGContextRef __nullable SDGraphicsGetCurrentContext(void) CF_RETURNS_NOT_RETAINED; FOUNDATION_EXPORT CGContextRef __nullable SDGraphicsGetCurrentContext(void) CF_RETURNS_NOT_RETAINED;
/// Creates a bitmap-based graphics context and makes it the current context.
FOUNDATION_EXPORT void SDGraphicsBeginImageContext(CGSize size); FOUNDATION_EXPORT void SDGraphicsBeginImageContext(CGSize size);
/// Creates a bitmap-based graphics context with the specified options.
FOUNDATION_EXPORT void SDGraphicsBeginImageContextWithOptions(CGSize size, BOOL opaque, CGFloat scale); FOUNDATION_EXPORT void SDGraphicsBeginImageContextWithOptions(CGSize size, BOOL opaque, CGFloat scale);
/// Removes the current bitmap-based graphics context from the top of the stack.
FOUNDATION_EXPORT void SDGraphicsEndImageContext(void); FOUNDATION_EXPORT void SDGraphicsEndImageContext(void);
/// Returns an image based on the contents of the current bitmap-based graphics context.
FOUNDATION_EXPORT UIImage * __nullable SDGraphicsGetImageFromCurrentImageContext(void); FOUNDATION_EXPORT UIImage * __nullable SDGraphicsGetImageFromCurrentImageContext(void);

View File

@ -52,11 +52,12 @@ FOUNDATION_EXPORT UIImage * _Nullable SDImageLoaderDecodeProgressiveImageData(NS
#pragma mark - SDImageLoader #pragma mark - SDImageLoader
// This is the protocol to specify custom image load process. You can create your own class to conform this protocol and use as a image loader to load image from network or any avaiable remote resources defined by yourself. /**
// If you want to implement custom loader for image download from network or local file, you just need to concentrate on image data download only. After the download finish, call `SDImageLoaderDecodeImageData` or `SDImageLoaderDecodeProgressiveImageData` to use the built-in decoding process and produce image (Remember to call in the global queue). And finally callback the completion block. This is the protocol to specify custom image load process. You can create your own class to conform this protocol and use as a image loader to load image from network or any avaiable remote resources defined by yourself.
// If you directlly get the image instance using some third-party SDKs, such as image directlly from Photos framework. You can process the image data and image instance by yourself without that built-in decoding process. And finally callback the completion block. If you want to implement custom loader for image download from network or local file, you just need to concentrate on image data download only. After the download finish, call `SDImageLoaderDecodeImageData` or `SDImageLoaderDecodeProgressiveImageData` to use the built-in decoding process and produce image (Remember to call in the global queue). And finally callback the completion block.
// @note It's your responsibility to load the image in the desired global queue(to avoid block main queue). We do not dispatch these method call in a global queue but just from the call queue (For `SDWebImageManager`, it typically call from the main queue). If you directlly get the image instance using some third-party SDKs, such as image directlly from Photos framework. You can process the image data and image instance by yourself without that built-in decoding process. And finally callback the completion block.
@note It's your responsibility to load the image in the desired global queue(to avoid block main queue). We do not dispatch these method call in a global queue but just from the call queue (For `SDWebImageManager`, it typically call from the main queue).
*/
@protocol SDImageLoader <NSObject> @protocol SDImageLoader <NSObject>
/** /**

View File

@ -8,6 +8,9 @@
#import "SDImageLoader.h" #import "SDImageLoader.h"
/**
A loaders manager to manage multiple loaders
*/
@interface SDImageLoadersManager : NSObject <SDImageLoader> @interface SDImageLoadersManager : NSObject <SDImageLoader>
/** /**

View File

@ -47,10 +47,15 @@ FOUNDATION_EXPORT NSString * _Nullable SDTransformedKeyForKey(NSString * _Nullab
#pragma mark - Pipeline #pragma mark - Pipeline
// Pipeline transformer. Which you can bind multiple transformers together to let the image to be transformed one by one in order and generate the final image. /**
// Because transformers are lightweight, if you want to append or arrange transfomers, create another pipeline transformer instead. This class is considered as immutable. Pipeline transformer. Which you can bind multiple transformers together to let the image to be transformed one by one in order and generate the final image.
@note Because transformers are lightweight, if you want to append or arrange transfomers, create another pipeline transformer instead. This class is considered as immutable.
*/
@interface SDImagePipelineTransformer : NSObject <SDImageTransformer> @interface SDImagePipelineTransformer : NSObject <SDImageTransformer>
/**
All transformers in pipeline
*/
@property (nonatomic, copy, readonly, nonnull) NSArray<id<SDImageTransformer>> *transformers; @property (nonatomic, copy, readonly, nonnull) NSArray<id<SDImageTransformer>> *transformers;
- (nonnull instancetype)init NS_UNAVAILABLE; - (nonnull instancetype)init NS_UNAVAILABLE;
@ -62,12 +67,32 @@ FOUNDATION_EXPORT NSString * _Nullable SDTransformedKeyForKey(NSString * _Nullab
// Because transformers are lightweight, these class are considered as immutable. // Because transformers are lightweight, these class are considered as immutable.
#pragma mark - Image Geometry #pragma mark - Image Geometry
// Image round corner transformer /**
Image round corner transformer
*/
@interface SDImageRoundCornerTransformer: NSObject <SDImageTransformer> @interface SDImageRoundCornerTransformer: NSObject <SDImageTransformer>
/**
The radius of each corner oval. Values larger than half the
rectangle's width or height are clamped appropriately to
half the width or height.
*/
@property (nonatomic, assign, readonly) CGFloat cornerRadius; @property (nonatomic, assign, readonly) CGFloat cornerRadius;
/**
A bitmask value that identifies the corners that you want
rounded. You can use this parameter to round only a subset
of the corners of the rectangle.
*/
@property (nonatomic, assign, readonly) SDRectCorner corners; @property (nonatomic, assign, readonly) SDRectCorner corners;
/**
The inset border line width. Values larger than half the rectangle's
width or height are clamped appropriately to half the width
or height.
*/
@property (nonatomic, assign, readonly) CGFloat borderWidth; @property (nonatomic, assign, readonly) CGFloat borderWidth;
/**
The border stroke color. nil means clear color.
*/
@property (nonatomic, strong, readonly, nullable) UIColor *borderColor; @property (nonatomic, strong, readonly, nullable) UIColor *borderColor;
- (nonnull instancetype)init NS_UNAVAILABLE; - (nonnull instancetype)init NS_UNAVAILABLE;
@ -75,10 +100,18 @@ FOUNDATION_EXPORT NSString * _Nullable SDTransformedKeyForKey(NSString * _Nullab
@end @end
// Image resizing transformer /**
Image resizing transformer
*/
@interface SDImageResizingTransformer : NSObject <SDImageTransformer> @interface SDImageResizingTransformer : NSObject <SDImageTransformer>
/**
The new size to be resized, values should be positive.
*/
@property (nonatomic, assign, readonly) CGSize size; @property (nonatomic, assign, readonly) CGSize size;
/**
The scale mode for image content.
*/
@property (nonatomic, assign, readonly) SDImageScaleMode scaleMode; @property (nonatomic, assign, readonly) SDImageScaleMode scaleMode;
- (nonnull instancetype)init NS_UNAVAILABLE; - (nonnull instancetype)init NS_UNAVAILABLE;
@ -86,9 +119,14 @@ FOUNDATION_EXPORT NSString * _Nullable SDTransformedKeyForKey(NSString * _Nullab
@end @end
// Image cropping transformer /**
Image cropping transformer
*/
@interface SDImageCroppingTransformer : NSObject <SDImageTransformer> @interface SDImageCroppingTransformer : NSObject <SDImageTransformer>
/**
Image's inner rect.
*/
@property (nonatomic, assign, readonly) CGRect rect; @property (nonatomic, assign, readonly) CGRect rect;
- (nonnull instancetype)init NS_UNAVAILABLE; - (nonnull instancetype)init NS_UNAVAILABLE;
@ -96,10 +134,18 @@ FOUNDATION_EXPORT NSString * _Nullable SDTransformedKeyForKey(NSString * _Nullab
@end @end
// Image flipping transformer /**
Image flipping transformer
*/
@interface SDImageFlippingTransformer : NSObject <SDImageTransformer> @interface SDImageFlippingTransformer : NSObject <SDImageTransformer>
/**
YES to flip the image horizontally.
*/
@property (nonatomic, assign, readonly) BOOL horizontal; @property (nonatomic, assign, readonly) BOOL horizontal;
/**
YES to flip the image vertically.
*/
@property (nonatomic, assign, readonly) BOOL vertical; @property (nonatomic, assign, readonly) BOOL vertical;
- (nonnull instancetype)init NS_UNAVAILABLE; - (nonnull instancetype)init NS_UNAVAILABLE;
@ -107,10 +153,19 @@ FOUNDATION_EXPORT NSString * _Nullable SDTransformedKeyForKey(NSString * _Nullab
@end @end
// Image rotation transformer /**
Image rotation transformer
*/
@interface SDImageRotationTransformer : NSObject <SDImageTransformer> @interface SDImageRotationTransformer : NSObject <SDImageTransformer>
/**
Rotated radians in counterclockwise.
*/
@property (nonatomic, assign, readonly) CGFloat angle; @property (nonatomic, assign, readonly) CGFloat angle;
/**
YES: new image's size is extend to fit all content.
NO: image's size will not change, content may be clipped.
*/
@property (nonatomic, assign, readonly) BOOL fitSize; @property (nonatomic, assign, readonly) BOOL fitSize;
- (nonnull instancetype)init NS_UNAVAILABLE; - (nonnull instancetype)init NS_UNAVAILABLE;
@ -120,9 +175,14 @@ FOUNDATION_EXPORT NSString * _Nullable SDTransformedKeyForKey(NSString * _Nullab
#pragma mark - Image Blending #pragma mark - Image Blending
// Image tint color transformer /**
Image tint color transformer
*/
@interface SDImageTintTransformer : NSObject <SDImageTransformer> @interface SDImageTintTransformer : NSObject <SDImageTransformer>
/**
The tint color.
*/
@property (nonatomic, strong, readonly, nonnull) UIColor *tintColor; @property (nonatomic, strong, readonly, nonnull) UIColor *tintColor;
- (nonnull instancetype)init NS_UNAVAILABLE; - (nonnull instancetype)init NS_UNAVAILABLE;
@ -132,9 +192,14 @@ FOUNDATION_EXPORT NSString * _Nullable SDTransformedKeyForKey(NSString * _Nullab
#pragma mark - Image Effect #pragma mark - Image Effect
// Image blur effect transformer /**
Image blur effect transformer
*/
@interface SDImageBlurTransformer : NSObject <SDImageTransformer> @interface SDImageBlurTransformer : NSObject <SDImageTransformer>
/**
The radius of the blur in points, 0 means no blur effect.
*/
@property (nonatomic, assign, readonly) CGFloat blurRadius; @property (nonatomic, assign, readonly) CGFloat blurRadius;
- (nonnull instancetype)init NS_UNAVAILABLE; - (nonnull instancetype)init NS_UNAVAILABLE;
@ -143,9 +208,14 @@ FOUNDATION_EXPORT NSString * _Nullable SDTransformedKeyForKey(NSString * _Nullab
@end @end
#if SD_UIKIT || SD_MAC #if SD_UIKIT || SD_MAC
// Core Image filter transformer /**
Core Image filter transformer
*/
@interface SDImageFilterTransformer: NSObject <SDImageTransformer> @interface SDImageFilterTransformer: NSObject <SDImageTransformer>
/**
The CIFilter to be applied to the image.
*/
@property (nonatomic, strong, readonly, nonnull) CIFilter *filter; @property (nonatomic, strong, readonly, nonnull) CIFilter *filter;
- (nonnull instancetype)init NS_UNAVAILABLE; - (nonnull instancetype)init NS_UNAVAILABLE;

View File

@ -9,7 +9,9 @@
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
@class SDImageCacheConfig; @class SDImageCacheConfig;
// A protocol to allow custom memory cache used in SDImageCache. /**
A protocol to allow custom memory cache used in SDImageCache.
*/
@protocol SDMemoryCache <NSObject> @protocol SDMemoryCache <NSObject>
@required @required
@ -65,7 +67,9 @@
@end @end
// A memory cache which auto purge the cache on memory warning and support weak cache. /**
A memory cache which auto purge the cache on memory warning and support weak cache.
*/
@interface SDMemoryCache <KeyType, ObjectType> : NSCache <KeyType, ObjectType> <SDMemoryCache> @interface SDMemoryCache <KeyType, ObjectType> : NSCache <KeyType, ObjectType> <SDMemoryCache>
@property (nonatomic, strong, nonnull, readonly) SDImageCacheConfig *config; @property (nonatomic, strong, nonnull, readonly) SDImageCacheConfig *config;

View File

@ -11,13 +11,19 @@
typedef NSString * _Nullable(^SDWebImageCacheKeyFilterBlock)(NSURL * _Nonnull url); typedef NSString * _Nullable(^SDWebImageCacheKeyFilterBlock)(NSURL * _Nonnull url);
// This is the protocol for cache key filter. We can use a block to specify the cache key filter. But Using protocol can make this extensible, and allow Swift user to use it easily instead of using `@convention(block)` to store a block into context options. /**
This is the protocol for cache key filter.
We can use a block to specify the cache key filter. But Using protocol can make this extensible, and allow Swift user to use it easily instead of using `@convention(block)` to store a block into context options.
*/
@protocol SDWebImageCacheKeyFilter <NSObject> @protocol SDWebImageCacheKeyFilter <NSObject>
- (nullable NSString *)cacheKeyForURL:(nonnull NSURL *)url; - (nullable NSString *)cacheKeyForURL:(nonnull NSURL *)url;
@end @end
/**
A cache key filter class with block.
*/
@interface SDWebImageCacheKeyFilter : NSObject <SDWebImageCacheKeyFilter> @interface SDWebImageCacheKeyFilter : NSObject <SDWebImageCacheKeyFilter>
- (nonnull instancetype)initWithBlock:(nonnull SDWebImageCacheKeyFilterBlock)block; - (nonnull instancetype)initWithBlock:(nonnull SDWebImageCacheKeyFilterBlock)block;

View File

@ -11,13 +11,18 @@
typedef NSData * _Nullable(^SDWebImageCacheSerializerBlock)(UIImage * _Nonnull image, NSData * _Nullable data, NSURL * _Nullable imageURL); typedef NSData * _Nullable(^SDWebImageCacheSerializerBlock)(UIImage * _Nonnull image, NSData * _Nullable data, NSURL * _Nullable imageURL);
// This is the protocol for cache serializer. We can use a block to specify the cache serializer. But Using protocol can make this extensible, and allow Swift user to use it easily instead of using `@convention(block)` to store a block into context options. /**
This is the protocol for cache serializer.
We can use a block to specify the cache serializer. But Using protocol can make this extensible, and allow Swift user to use it easily instead of using `@convention(block)` to store a block into context options. */
@protocol SDWebImageCacheSerializer <NSObject> @protocol SDWebImageCacheSerializer <NSObject>
- (nullable NSData *)cacheDataWithImage:(nonnull UIImage *)image originalData:(nullable NSData *)data imageURL:(nullable NSURL *)imageURL; - (nullable NSData *)cacheDataWithImage:(nonnull UIImage *)image originalData:(nullable NSData *)data imageURL:(nullable NSURL *)imageURL;
@end @end
/**
A cache serializer class with block.
*/
@interface SDWebImageCacheSerializer : NSObject <SDWebImageCacheSerializer> @interface SDWebImageCacheSerializer : NSObject <SDWebImageCacheSerializer>
- (nonnull instancetype)initWithBlock:(nonnull SDWebImageCacheSerializerBlock)block; - (nonnull instancetype)initWithBlock:(nonnull SDWebImageCacheSerializerBlock)block;

View File

@ -48,6 +48,7 @@ FOUNDATION_EXPORT UIImage * _Nullable SDScaledImageForScaleFactor(CGFloat scale,
#pragma mark - WebCache Options #pragma mark - WebCache Options
/// WebCache options
typedef NS_OPTIONS(NSUInteger, SDWebImageOptions) { typedef NS_OPTIONS(NSUInteger, SDWebImageOptions) {
/** /**
* By default, when a URL fail to be downloaded, the URL is blacklisted so the library won't keep trying. * By default, when a URL fail to be downloaded, the URL is blacklisted so the library won't keep trying.

View File

@ -14,6 +14,7 @@
#import "SDWebImageDownloaderRequestModifier.h" #import "SDWebImageDownloaderRequestModifier.h"
#import "SDImageLoader.h" #import "SDImageLoader.h"
/// Downloader options
typedef NS_OPTIONS(NSUInteger, SDWebImageDownloaderOptions) { typedef NS_OPTIONS(NSUInteger, SDWebImageDownloaderOptions) {
/** /**
* Put the download in the low queue priority and task priority. * Put the download in the low queue priority and task priority.

View File

@ -9,6 +9,7 @@
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
/// Operation execution order
typedef NS_ENUM(NSInteger, SDWebImageDownloaderExecutionOrder) { typedef NS_ENUM(NSInteger, SDWebImageDownloaderExecutionOrder) {
/** /**
* Default value. All download operations will execute in queue style (first-in-first-out). * Default value. All download operations will execute in queue style (first-in-first-out).
@ -21,6 +22,10 @@ typedef NS_ENUM(NSInteger, SDWebImageDownloaderExecutionOrder) {
SDWebImageDownloaderLIFOExecutionOrder SDWebImageDownloaderLIFOExecutionOrder
}; };
/**
The class contains all the config for image downloader
@note This class conform to NSCopying, make sure to add the property in `copyWithZone:` as well.
*/
@interface SDWebImageDownloaderConfig : NSObject <NSCopying> @interface SDWebImageDownloaderConfig : NSObject <NSCopying>
/** /**

View File

@ -42,6 +42,9 @@
@end @end
/**
The download operation class for SDWebImageDownloader.
*/
@interface SDWebImageDownloaderOperation : NSOperation <SDWebImageDownloaderOperation> @interface SDWebImageDownloaderOperation : NSOperation <SDWebImageDownloaderOperation>
/** /**

View File

@ -11,13 +11,19 @@
typedef NSURLRequest * _Nullable (^SDWebImageDownloaderRequestModifierBlock)(NSURLRequest * _Nonnull request); typedef NSURLRequest * _Nullable (^SDWebImageDownloaderRequestModifierBlock)(NSURLRequest * _Nonnull request);
// This is the protocol for downloader request modifier. We can use a block to specify the downloader request modifier. But Using protocol can make this extensible, and allow Swift user to use it easily instead of using `@convention(block)` to store a block into context options. /**
This is the protocol for downloader request modifier.
We can use a block to specify the downloader request modifier. But Using protocol can make this extensible, and allow Swift user to use it easily instead of using `@convention(block)` to store a block into context options.
*/
@protocol SDWebImageDownloaderRequestModifier <NSObject> @protocol SDWebImageDownloaderRequestModifier <NSObject>
- (nullable NSURLRequest *)modifiedRequestWithRequest:(nonnull NSURLRequest *)request; - (nullable NSURLRequest *)modifiedRequestWithRequest:(nonnull NSURLRequest *)request;
@end @end
/**
A downloader request modifier class with block.
*/
@interface SDWebImageDownloaderRequestModifier : NSObject <SDWebImageDownloaderRequestModifier> @interface SDWebImageDownloaderRequestModifier : NSObject <SDWebImageDownloaderRequestModifier>
- (nonnull instancetype)initWithBlock:(nonnull SDWebImageDownloaderRequestModifierBlock)block; - (nonnull instancetype)initWithBlock:(nonnull SDWebImageDownloaderRequestModifierBlock)block;

View File

@ -11,8 +11,10 @@
FOUNDATION_EXPORT NSErrorDomain const _Nonnull SDWebImageErrorDomain; FOUNDATION_EXPORT NSErrorDomain const _Nonnull SDWebImageErrorDomain;
/// The HTTP status code for invalid download response (NSNumber *)
FOUNDATION_EXPORT NSErrorUserInfoKey const _Nonnull SDWebImageErrorDownloadStatusCodeKey; FOUNDATION_EXPORT NSErrorUserInfoKey const _Nonnull SDWebImageErrorDownloadStatusCodeKey;
/// SDWebImage error domain and codes
typedef NS_ERROR_ENUM(SDWebImageErrorDomain, SDWebImageError) { typedef NS_ERROR_ENUM(SDWebImageErrorDomain, SDWebImageError) {
SDWebImageErrorInvalidURL = 1000, // The URL is invalid, such as nil URL or corrupted URL SDWebImageErrorInvalidURL = 1000, // The URL is invalid, such as nil URL or corrupted URL
SDWebImageErrorBadImageData = 1001, // The image data can not be decoded to image, or the image data is empty SDWebImageErrorBadImageData = 1001, // The image data can not be decoded to image, or the image data is empty

View File

@ -10,8 +10,10 @@
#if SD_UIKIT || SD_MAC #if SD_UIKIT || SD_MAC
// A protocol to custom the indicator during the image loading /**
// All of these methods are called from main queue A protocol to custom the indicator during the image loading
All of these methods are called from main queue
*/
@protocol SDWebImageIndicator <NSObject> @protocol SDWebImageIndicator <NSObject>
@required @required
@ -42,9 +44,11 @@
#pragma mark - Activity Indicator #pragma mark - Activity Indicator
// Activity indicator class /**
// for UIKit(macOS), it use a `UIActivityIndicatorView` Activity indicator class
// for AppKit(macOS), it use a `NSProgressIndicator` with the spinning style for UIKit(macOS), it use a `UIActivityIndicatorView`
for AppKit(macOS), it use a `NSProgressIndicator` with the spinning style
*/
@interface SDWebImageActivityIndicator : NSObject <SDWebImageIndicator> @interface SDWebImageActivityIndicator : NSObject <SDWebImageIndicator>
#if SD_UIKIT #if SD_UIKIT
@ -55,7 +59,9 @@
@end @end
// Convenience way to use activity indicator. /**
Convenience way to use activity indicator.
*/
@interface SDWebImageActivityIndicator (Conveniences) @interface SDWebImageActivityIndicator (Conveniences)
/// gray-style activity indicator /// gray-style activity indicator
@ -71,9 +77,11 @@
#pragma mark - Progress Indicator #pragma mark - Progress Indicator
// Progress indicator class /**
// for UIKit(macOS), it use a `UIProgressView` Progress indicator class
// for AppKit(macOS), it use a `NSProgressIndicator` with the bar style for UIKit(macOS), it use a `UIProgressView`
for AppKit(macOS), it use a `NSProgressIndicator` with the bar style
*/
@interface SDWebImageProgressIndicator : NSObject <SDWebImageIndicator> @interface SDWebImageProgressIndicator : NSObject <SDWebImageIndicator>
#if SD_UIKIT #if SD_UIKIT
@ -84,7 +92,9 @@
@end @end
// Convenience way to create progress indicator. Remember to specify the indicator width or use layout constraint if need. /**
Convenience way to create progress indicator. Remember to specify the indicator width or use layout constraint if need.
*/
@interface SDWebImageProgressIndicator (Conveniences) @interface SDWebImageProgressIndicator (Conveniences)
/// default-style progress indicator /// default-style progress indicator

View File

@ -18,7 +18,9 @@ typedef void(^SDExternalCompletionBlock)(UIImage * _Nullable image, NSError * _N
typedef void(^SDInternalCompletionBlock)(UIImage * _Nullable image, NSData * _Nullable data, NSError * _Nullable error, SDImageCacheType cacheType, BOOL finished, NSURL * _Nullable imageURL); typedef void(^SDInternalCompletionBlock)(UIImage * _Nullable image, NSData * _Nullable data, NSError * _Nullable error, SDImageCacheType cacheType, BOOL finished, NSURL * _Nullable imageURL);
// A combined operation representing the cache and loader operation. You can use it to cancel the load process. /**
A combined operation representing the cache and loader operation. You can use it to cancel the load process.
*/
@interface SDWebImageCombinedOperation : NSObject <SDWebImageOperation> @interface SDWebImageCombinedOperation : NSObject <SDWebImageOperation>
/** /**
@ -41,6 +43,9 @@ typedef void(^SDInternalCompletionBlock)(UIImage * _Nullable image, NSData * _Nu
@class SDWebImageManager; @class SDWebImageManager;
/**
The manager delegate protocol
*/
@protocol SDWebImageManagerDelegate <NSObject> @protocol SDWebImageManagerDelegate <NSObject>
@optional @optional

View File

@ -8,13 +8,14 @@
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>
/// A protocol represents cancelable operation
@protocol SDWebImageOperation <NSObject> @protocol SDWebImageOperation <NSObject>
- (void)cancel; - (void)cancel;
@end @end
// NSOperation conform to `SDWebImageOperation` /// NSOperation conform to `SDWebImageOperation`
@interface NSOperation (SDWebImageOperation) <SDWebImageOperation> @interface NSOperation (SDWebImageOperation) <SDWebImageOperation>
@end @end

View File

@ -11,6 +11,9 @@
@class SDWebImagePrefetcher; @class SDWebImagePrefetcher;
/**
A token represents a list of URLs, can be used to cancel the download.
*/
@interface SDWebImagePrefetchToken : NSObject <SDWebImageOperation> @interface SDWebImagePrefetchToken : NSObject <SDWebImageOperation>
/** /**
@ -25,6 +28,9 @@
@end @end
/**
The prefetcher delegate protocol
*/
@protocol SDWebImagePrefetcherDelegate <NSObject> @protocol SDWebImagePrefetcherDelegate <NSObject>
@optional @optional

View File

@ -11,11 +11,6 @@
#if SD_UIKIT || SD_MAC #if SD_UIKIT || SD_MAC
#import "SDImageCache.h" #import "SDImageCache.h"
// This class is used to provide a transition animation after the view category load image finished. Use this on `sd_imageTransition` in UIView+WebCache.h
// for UIKit(iOS & tvOS), we use `+[UIView transitionWithView:duration:options:animations:completion]` for transition animation.
// for AppKit(macOS), we use `+[NSAnimationContext runAnimationGroup:completionHandler:]` for transition animation. You can call `+[NSAnimationContext currentContext]` to grab the context during animations block.
// These transition are provided for basic usage. If you need complicated animation, consider to directly use Core Animation or use `SDWebImageAvoidAutoSetImage` and implement your own after image load finished.
#if SD_UIKIT #if SD_UIKIT
typedef UIViewAnimationOptions SDWebImageAnimationOptions; typedef UIViewAnimationOptions SDWebImageAnimationOptions;
#else #else
@ -28,6 +23,12 @@ typedef void (^SDWebImageTransitionPreparesBlock)(__kindof UIView * _Nonnull vie
typedef void (^SDWebImageTransitionAnimationsBlock)(__kindof UIView * _Nonnull view, UIImage * _Nullable image); typedef void (^SDWebImageTransitionAnimationsBlock)(__kindof UIView * _Nonnull view, UIImage * _Nullable image);
typedef void (^SDWebImageTransitionCompletionBlock)(BOOL finished); typedef void (^SDWebImageTransitionCompletionBlock)(BOOL finished);
/**
This class is used to provide a transition animation after the view category load image finished. Use this on `sd_imageTransition` in UIView+WebCache.h
for UIKit(iOS & tvOS), we use `+[UIView transitionWithView:duration:options:animations:completion]` for transition animation.
for AppKit(macOS), we use `+[NSAnimationContext runAnimationGroup:completionHandler:]` for transition animation. You can call `+[NSAnimationContext currentContext]` to grab the context during animations block.
@note These transition are provided for basic usage. If you need complicated animation, consider to directly use Core Animation or use `SDWebImageAvoidAutoSetImage` and implement your own after image load finished.
*/
@interface SDWebImageTransition : NSObject @interface SDWebImageTransition : NSObject
/** /**
@ -61,10 +62,11 @@ typedef void (^SDWebImageTransitionCompletionBlock)(BOOL finished);
@end @end
// Convenience way to create transition. Remember to specify the duration if needed. /**
// for UIKit, these transition just use the correspond `animationOptions`. By default we enable `UIViewAnimationOptionAllowUserInteraction` to allow user interaction during transition. Convenience way to create transition. Remember to specify the duration if needed.
// for AppKit, these transition use Core Animation in `animations`. So your view must be layer-backed. Set `wantsLayer = YES` before you apply it. for UIKit, these transition just use the correspond `animationOptions`. By default we enable `UIViewAnimationOptionAllowUserInteraction` to allow user interaction during transition.
for AppKit, these transition use Core Animation in `animations`. So your view must be layer-backed. Set `wantsLayer = YES` before you apply it.
*/
@interface SDWebImageTransition (Conveniences) @interface SDWebImageTransition (Conveniences)
/// Fade transition. /// Fade transition.

View File

@ -13,7 +13,7 @@
#import "SDWebImageManager.h" #import "SDWebImageManager.h"
/** /**
* Integrates SDWebImage async downloading and caching of remote images with UIButtonView. * Integrates SDWebImage async downloading and caching of remote images with UIButton.
*/ */
@interface UIButton (WebCache) @interface UIButton (WebCache)

View File

@ -8,6 +8,9 @@
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
/**
UIImage category about force decode feature (avoid Image/IO's lazy decoding during rendering behavior)
*/
@interface UIImage (ForceDecode) @interface UIImage (ForceDecode)
/** /**

View File

@ -9,7 +9,9 @@
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
// This category is just use as a convenience method. For more detail control, use methods in `UIImage+MultiFormat.h` or directlly use `SDImageCoder` /**
This category is just use as a convenience method. For more detail control, use methods in `UIImage+MultiFormat.h` or directlly use `SDImageCoder`
*/
@interface UIImage (GIF) @interface UIImage (GIF)
/** /**

View File

@ -8,6 +8,9 @@
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
/**
UIImage category for memory cache cost
*/
@interface UIImage (MemoryCacheCost) @interface UIImage (MemoryCacheCost)
/** /**

View File

@ -9,6 +9,9 @@
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
#import "NSData+ImageContentType.h" #import "NSData+ImageContentType.h"
/**
UIImage category for image metadata, including animation, loop count, format, incremental, etc.
*/
@interface UIImage (Metadata) @interface UIImage (Metadata)
/** /**

View File

@ -9,6 +9,9 @@
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
#import "NSData+ImageContentType.h" #import "NSData+ImageContentType.h"
/**
UIImage category for convenient image format decoding/encoding
*/
@interface UIImage (MultiFormat) @interface UIImage (MultiFormat)
#pragma mark - Decode #pragma mark - Decode
/** /**

View File

@ -10,8 +10,6 @@
#import "SDWebImageManager.h" #import "SDWebImageManager.h"
/** /**
* Integrates SDWebImage async downloading and caching of remote images with UIImageView.
*
* Usage with a UITableViewCell sub-class: * Usage with a UITableViewCell sub-class:
* *
* @code * @code
@ -41,6 +39,10 @@
* @endcode * @endcode
*/ */
/**
* Integrates SDWebImage async downloading and caching of remote images with UIImageView.
*/
@interface UIImageView (WebCache) @interface UIImageView (WebCache)
/** /**

View File

@ -19,6 +19,9 @@ FOUNDATION_EXPORT const int64_t SDWebImageProgressUnitCountUnknown; /* 1LL */
typedef void(^SDSetImageBlock)(UIImage * _Nullable image, NSData * _Nullable imageData, SDImageCacheType cacheType, NSURL * _Nullable imageURL); typedef void(^SDSetImageBlock)(UIImage * _Nullable image, NSData * _Nullable imageData, SDImageCacheType cacheType, NSURL * _Nullable imageURL);
/**
Integrates SDWebImage async downloading and caching of remote images with UIView subclass.
*/
@interface UIView (WebCache) @interface UIView (WebCache)
/** /**

View File

@ -9,8 +9,10 @@
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
#import "SDWebImageOperation.h" #import "SDWebImageOperation.h"
// These methods are used to support canceling for UIView image loading, it's designed to be used internal but not external. /**
// All the stored operations are weak, so it will be dalloced after image loading finished. If you need to store operations, use your own class to keep a strong reference for them. These methods are used to support canceling for UIView image loading, it's designed to be used internal but not external.
All the stored operations are weak, so it will be dalloced after image loading finished. If you need to store operations, use your own class to keep a strong reference for them.
*/
@interface UIView (WebCacheOperation) @interface UIView (WebCacheOperation)
/** /**