Merge pull request #2385 from dreampiggy/project_move_FLAnimatedImage
Remove all FLAnimatedImage from the Core SDWebImage repo. Move the code to SDWebImageFLPlugin repo
This commit is contained in:
commit
025af81bdf
|
@ -1,6 +1,3 @@
|
||||||
[submodule "Vendors/libwebp"]
|
[submodule "Vendors/libwebp"]
|
||||||
path = Vendors/libwebp
|
path = Vendors/libwebp
|
||||||
url = https://github.com/webmproject/libwebp
|
url = https://github.com/webmproject/libwebp
|
||||||
[submodule "Vendors/FLAnimatedImage"]
|
|
||||||
path = Vendors/FLAnimatedImage
|
|
||||||
url = https://github.com/Flipboard/FLAnimatedImage
|
|
||||||
|
|
|
@ -29,7 +29,7 @@ Pod::Spec.new do |s|
|
||||||
|
|
||||||
s.subspec 'Core' do |core|
|
s.subspec 'Core' do |core|
|
||||||
core.source_files = 'SDWebImage/*.{h,m}', 'WebImage/SDWebImage.h'
|
core.source_files = 'SDWebImage/*.{h,m}', 'WebImage/SDWebImage.h'
|
||||||
core.exclude_files = 'SDWebImage/MapKit/*.{h,m}', 'SDWebImage/WebP/*.{h,m}', 'SDWebImage/FLAnimatedImage/*.{h,m}'
|
core.exclude_files = 'SDWebImage/MapKit/*.{h,m}', 'SDWebImage/WebP/*.{h,m}'
|
||||||
end
|
end
|
||||||
|
|
||||||
s.subspec 'MapKit' do |mk|
|
s.subspec 'MapKit' do |mk|
|
||||||
|
@ -41,16 +41,6 @@ Pod::Spec.new do |s|
|
||||||
mk.dependency 'SDWebImage/Core'
|
mk.dependency 'SDWebImage/Core'
|
||||||
end
|
end
|
||||||
|
|
||||||
s.subspec 'GIF' do |gif|
|
|
||||||
gif.ios.deployment_target = '8.0'
|
|
||||||
gif.source_files = 'SDWebImage/FLAnimatedImage/*.{h,m}'
|
|
||||||
gif.dependency 'SDWebImage/Core'
|
|
||||||
gif.dependency 'FLAnimatedImage', '~> 1.0'
|
|
||||||
gif.xcconfig = {
|
|
||||||
'USER_HEADER_SEARCH_PATHS' => '$(inherited) $(SRCROOT)/FLAnimatedImage/FLAnimatedImage'
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
s.subspec 'WebP' do |webp|
|
s.subspec 'WebP' do |webp|
|
||||||
webp.source_files = 'SDWebImage/WebP/*.{h,m}'
|
webp.source_files = 'SDWebImage/WebP/*.{h,m}'
|
||||||
webp.xcconfig = {
|
webp.xcconfig = {
|
||||||
|
|
|
@ -783,24 +783,6 @@
|
||||||
43C892A31D9D6DDD0022038D /* demux.c in Sources */ = {isa = PBXBuildFile; fileRef = 43C892991D9D6DD70022038D /* demux.c */; };
|
43C892A31D9D6DDD0022038D /* demux.c in Sources */ = {isa = PBXBuildFile; fileRef = 43C892991D9D6DD70022038D /* demux.c */; };
|
||||||
43C892A41D9D6DDD0022038D /* demux.c in Sources */ = {isa = PBXBuildFile; fileRef = 43C892991D9D6DD70022038D /* demux.c */; };
|
43C892A41D9D6DDD0022038D /* demux.c in Sources */ = {isa = PBXBuildFile; fileRef = 43C892991D9D6DD70022038D /* demux.c */; };
|
||||||
43C892A51D9D6DDE0022038D /* demux.c in Sources */ = {isa = PBXBuildFile; fileRef = 43C892991D9D6DD70022038D /* demux.c */; };
|
43C892A51D9D6DDE0022038D /* demux.c in Sources */ = {isa = PBXBuildFile; fileRef = 43C892991D9D6DD70022038D /* demux.c */; };
|
||||||
43CE75761CFE9427006C64D0 /* FLAnimatedImage.h in Headers */ = {isa = PBXBuildFile; fileRef = 43CE75491CFE9427006C64D0 /* FLAnimatedImage.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
|
||||||
43CE75771CFE9427006C64D0 /* FLAnimatedImage.h in Headers */ = {isa = PBXBuildFile; fileRef = 43CE75491CFE9427006C64D0 /* FLAnimatedImage.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
|
||||||
43CE75781CFE9427006C64D0 /* FLAnimatedImage.h in Headers */ = {isa = PBXBuildFile; fileRef = 43CE75491CFE9427006C64D0 /* FLAnimatedImage.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
|
||||||
43CE75791CFE9427006C64D0 /* FLAnimatedImage.m in Sources */ = {isa = PBXBuildFile; fileRef = 43CE754A1CFE9427006C64D0 /* FLAnimatedImage.m */; };
|
|
||||||
43CE757A1CFE9427006C64D0 /* FLAnimatedImage.m in Sources */ = {isa = PBXBuildFile; fileRef = 43CE754A1CFE9427006C64D0 /* FLAnimatedImage.m */; };
|
|
||||||
43CE757B1CFE9427006C64D0 /* FLAnimatedImage.m in Sources */ = {isa = PBXBuildFile; fileRef = 43CE754A1CFE9427006C64D0 /* FLAnimatedImage.m */; };
|
|
||||||
43CE757C1CFE9427006C64D0 /* FLAnimatedImageView.h in Headers */ = {isa = PBXBuildFile; fileRef = 43CE754B1CFE9427006C64D0 /* FLAnimatedImageView.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
|
||||||
43CE757D1CFE9427006C64D0 /* FLAnimatedImageView.h in Headers */ = {isa = PBXBuildFile; fileRef = 43CE754B1CFE9427006C64D0 /* FLAnimatedImageView.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
|
||||||
43CE757E1CFE9427006C64D0 /* FLAnimatedImageView.h in Headers */ = {isa = PBXBuildFile; fileRef = 43CE754B1CFE9427006C64D0 /* FLAnimatedImageView.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
|
||||||
43CE757F1CFE9427006C64D0 /* FLAnimatedImageView.m in Sources */ = {isa = PBXBuildFile; fileRef = 43CE754C1CFE9427006C64D0 /* FLAnimatedImageView.m */; };
|
|
||||||
43CE75801CFE9427006C64D0 /* FLAnimatedImageView.m in Sources */ = {isa = PBXBuildFile; fileRef = 43CE754C1CFE9427006C64D0 /* FLAnimatedImageView.m */; };
|
|
||||||
43CE75811CFE9427006C64D0 /* FLAnimatedImageView.m in Sources */ = {isa = PBXBuildFile; fileRef = 43CE754C1CFE9427006C64D0 /* FLAnimatedImageView.m */; };
|
|
||||||
43CE75D01CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.h in Headers */ = {isa = PBXBuildFile; fileRef = 43CE75CE1CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
|
||||||
43CE75D11CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.h in Headers */ = {isa = PBXBuildFile; fileRef = 43CE75CE1CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
|
||||||
43CE75D21CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.h in Headers */ = {isa = PBXBuildFile; fileRef = 43CE75CE1CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
|
||||||
43CE75D31CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.m in Sources */ = {isa = PBXBuildFile; fileRef = 43CE75CF1CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.m */; };
|
|
||||||
43CE75D41CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.m in Sources */ = {isa = PBXBuildFile; fileRef = 43CE75CF1CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.m */; };
|
|
||||||
43CE75D51CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.m in Sources */ = {isa = PBXBuildFile; fileRef = 43CE75CF1CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.m */; };
|
|
||||||
4A2CAE041AB4BB5400B6BC39 /* SDWebImage.h in Headers */ = {isa = PBXBuildFile; fileRef = 4A2CAE031AB4BB5400B6BC39 /* SDWebImage.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
4A2CAE041AB4BB5400B6BC39 /* SDWebImage.h in Headers */ = {isa = PBXBuildFile; fileRef = 4A2CAE031AB4BB5400B6BC39 /* SDWebImage.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
||||||
4A2CAE181AB4BB6400B6BC39 /* SDWebImageCompat.h in Headers */ = {isa = PBXBuildFile; fileRef = 53922D88148C56230056699D /* SDWebImageCompat.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
4A2CAE181AB4BB6400B6BC39 /* SDWebImageCompat.h in Headers */ = {isa = PBXBuildFile; fileRef = 53922D88148C56230056699D /* SDWebImageCompat.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
||||||
4A2CAE191AB4BB6400B6BC39 /* SDWebImageCompat.m in Sources */ = {isa = PBXBuildFile; fileRef = 5340674F167780C40042B59E /* SDWebImageCompat.m */; };
|
4A2CAE191AB4BB6400B6BC39 /* SDWebImageCompat.m in Sources */ = {isa = PBXBuildFile; fileRef = 5340674F167780C40042B59E /* SDWebImageCompat.m */; };
|
||||||
|
@ -1652,12 +1634,6 @@
|
||||||
43A918631D8308FE00B3925F /* SDImageCacheConfig.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = SDImageCacheConfig.m; sourceTree = "<group>"; };
|
43A918631D8308FE00B3925F /* SDImageCacheConfig.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = SDImageCacheConfig.m; sourceTree = "<group>"; };
|
||||||
43C892981D9D6DD70022038D /* anim_decode.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = anim_decode.c; sourceTree = "<group>"; };
|
43C892981D9D6DD70022038D /* anim_decode.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = anim_decode.c; sourceTree = "<group>"; };
|
||||||
43C892991D9D6DD70022038D /* demux.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = demux.c; sourceTree = "<group>"; };
|
43C892991D9D6DD70022038D /* demux.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = demux.c; sourceTree = "<group>"; };
|
||||||
43CE75491CFE9427006C64D0 /* FLAnimatedImage.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = FLAnimatedImage.h; sourceTree = "<group>"; };
|
|
||||||
43CE754A1CFE9427006C64D0 /* FLAnimatedImage.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = FLAnimatedImage.m; sourceTree = "<group>"; };
|
|
||||||
43CE754B1CFE9427006C64D0 /* FLAnimatedImageView.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = FLAnimatedImageView.h; sourceTree = "<group>"; };
|
|
||||||
43CE754C1CFE9427006C64D0 /* FLAnimatedImageView.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = FLAnimatedImageView.m; sourceTree = "<group>"; };
|
|
||||||
43CE75CE1CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = "FLAnimatedImageView+WebCache.h"; sourceTree = "<group>"; };
|
|
||||||
43CE75CF1CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = "FLAnimatedImageView+WebCache.m"; sourceTree = "<group>"; };
|
|
||||||
4A2CADFF1AB4BB5300B6BC39 /* SDWebImage.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = SDWebImage.framework; sourceTree = BUILT_PRODUCTS_DIR; };
|
4A2CADFF1AB4BB5300B6BC39 /* SDWebImage.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = SDWebImage.framework; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
4A2CAE021AB4BB5400B6BC39 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
|
4A2CAE021AB4BB5400B6BC39 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
|
||||||
4A2CAE031AB4BB5400B6BC39 /* SDWebImage.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = SDWebImage.h; sourceTree = "<group>"; };
|
4A2CAE031AB4BB5400B6BC39 /* SDWebImage.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = SDWebImage.h; sourceTree = "<group>"; };
|
||||||
|
@ -2029,35 +2005,6 @@
|
||||||
path = demux;
|
path = demux;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
43CE75451CFE9427006C64D0 /* FLAnimatedImage */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
43CE75481CFE9427006C64D0 /* FLAnimatedImage */,
|
|
||||||
);
|
|
||||||
name = FLAnimatedImage;
|
|
||||||
path = Vendors/FLAnimatedImage;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
43CE75481CFE9427006C64D0 /* FLAnimatedImage */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
43CE75491CFE9427006C64D0 /* FLAnimatedImage.h */,
|
|
||||||
43CE754A1CFE9427006C64D0 /* FLAnimatedImage.m */,
|
|
||||||
43CE754B1CFE9427006C64D0 /* FLAnimatedImageView.h */,
|
|
||||||
43CE754C1CFE9427006C64D0 /* FLAnimatedImageView.m */,
|
|
||||||
);
|
|
||||||
path = FLAnimatedImage;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
43CE75CD1CFE98B3006C64D0 /* FLAnimatedImage */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
43CE75CE1CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.h */,
|
|
||||||
43CE75CF1CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.m */,
|
|
||||||
);
|
|
||||||
path = FLAnimatedImage;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
4A2CAE001AB4BB5300B6BC39 /* WebImage */ = {
|
4A2CAE001AB4BB5300B6BC39 /* WebImage */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
|
@ -2103,7 +2050,6 @@
|
||||||
53922D71148C55820056699D /* Frameworks */ = {
|
53922D71148C55820056699D /* Frameworks */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
43CE75451CFE9427006C64D0 /* FLAnimatedImage */,
|
|
||||||
DA577C121998E60B007367ED /* libwebp */,
|
DA577C121998E60B007367ED /* libwebp */,
|
||||||
53FB893F14D35D1A0020B787 /* CoreGraphics.framework */,
|
53FB893F14D35D1A0020B787 /* CoreGraphics.framework */,
|
||||||
53922D72148C55820056699D /* Foundation.framework */,
|
53922D72148C55820056699D /* Foundation.framework */,
|
||||||
|
@ -2127,7 +2073,6 @@
|
||||||
4369C2851D9811BB007E863A /* WebCache Categories */,
|
4369C2851D9811BB007E863A /* WebCache Categories */,
|
||||||
32FDE8792088871B008D7530 /* MapKit */,
|
32FDE8792088871B008D7530 /* MapKit */,
|
||||||
32FDE88420888726008D7530 /* WebP */,
|
32FDE88420888726008D7530 /* WebP */,
|
||||||
43CE75CD1CFE98B3006C64D0 /* FLAnimatedImage */,
|
|
||||||
);
|
);
|
||||||
path = SDWebImage;
|
path = SDWebImage;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
|
@ -2424,7 +2369,6 @@
|
||||||
4317395B1CDFC8B70008FEB9 /* types.h in Headers */,
|
4317395B1CDFC8B70008FEB9 /* types.h in Headers */,
|
||||||
80377C531F2F666300F89830 /* huffman_utils.h in Headers */,
|
80377C531F2F666300F89830 /* huffman_utils.h in Headers */,
|
||||||
32FDE8822088871B008D7530 /* MKAnnotationView+WebCache.h in Headers */,
|
32FDE8822088871B008D7530 /* MKAnnotationView+WebCache.h in Headers */,
|
||||||
43CE75D21CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.h in Headers */,
|
|
||||||
431739551CDFC8B70008FEB9 /* decode.h in Headers */,
|
431739551CDFC8B70008FEB9 /* decode.h in Headers */,
|
||||||
00733A731BC4880E00A5A117 /* SDWebImage.h in Headers */,
|
00733A731BC4880E00A5A117 /* SDWebImage.h in Headers */,
|
||||||
323F8B651F38EF770092B609 /* cost_enc.h in Headers */,
|
323F8B651F38EF770092B609 /* cost_enc.h in Headers */,
|
||||||
|
@ -2456,12 +2400,10 @@
|
||||||
32CF1C0A1FA496B000004BD1 /* SDImageCoderHelper.h in Headers */,
|
32CF1C0A1FA496B000004BD1 /* SDImageCoderHelper.h in Headers */,
|
||||||
80377C4D1F2F666300F89830 /* endian_inl_utils.h in Headers */,
|
80377C4D1F2F666300F89830 /* endian_inl_utils.h in Headers */,
|
||||||
431739581CDFC8B70008FEB9 /* format_constants.h in Headers */,
|
431739581CDFC8B70008FEB9 /* format_constants.h in Headers */,
|
||||||
43CE75781CFE9427006C64D0 /* FLAnimatedImage.h in Headers */,
|
|
||||||
00733A6E1BC4880E00A5A117 /* UIImage+MultiFormat.h in Headers */,
|
00733A6E1BC4880E00A5A117 /* UIImage+MultiFormat.h in Headers */,
|
||||||
323F8B891F38EF770092B609 /* histogram_enc.h in Headers */,
|
323F8B891F38EF770092B609 /* histogram_enc.h in Headers */,
|
||||||
80377EC21F2F66D500F89830 /* vp8i_dec.h in Headers */,
|
80377EC21F2F66D500F89830 /* vp8i_dec.h in Headers */,
|
||||||
80377EBA1F2F66D500F89830 /* common_dec.h in Headers */,
|
80377EBA1F2F66D500F89830 /* common_dec.h in Headers */,
|
||||||
43CE757E1CFE9427006C64D0 /* FLAnimatedImageView.h in Headers */,
|
|
||||||
3248476C201775F600AF9E5A /* SDAnimatedImageView.h in Headers */,
|
3248476C201775F600AF9E5A /* SDAnimatedImageView.h in Headers */,
|
||||||
32FDE89820888726008D7530 /* UIImage+WebP.h in Headers */,
|
32FDE89820888726008D7530 /* UIImage+WebP.h in Headers */,
|
||||||
80377C5F1F2F666300F89830 /* utils.h in Headers */,
|
80377C5F1F2F666300F89830 /* utils.h in Headers */,
|
||||||
|
@ -2789,7 +2731,6 @@
|
||||||
80377C3D1F2F666300F89830 /* quant_levels_utils.h in Headers */,
|
80377C3D1F2F666300F89830 /* quant_levels_utils.h in Headers */,
|
||||||
323F8B521F38EF770092B609 /* backward_references_enc.h in Headers */,
|
323F8B521F38EF770092B609 /* backward_references_enc.h in Headers */,
|
||||||
4317394F1CDFC8B70008FEB9 /* demux.h in Headers */,
|
4317394F1CDFC8B70008FEB9 /* demux.h in Headers */,
|
||||||
43CE757D1CFE9427006C64D0 /* FLAnimatedImageView.h in Headers */,
|
|
||||||
32D122202080B2EB003685A3 /* SDImageCacheDefine.h in Headers */,
|
32D122202080B2EB003685A3 /* SDImageCacheDefine.h in Headers */,
|
||||||
32B9B539206ED4230026769D /* SDWebImageDownloaderConfig.h in Headers */,
|
32B9B539206ED4230026769D /* SDWebImageDownloaderConfig.h in Headers */,
|
||||||
328BB6AC2081FEE500760D6C /* SDWebImageCacheSerializer.h in Headers */,
|
328BB6AC2081FEE500760D6C /* SDWebImageCacheSerializer.h in Headers */,
|
||||||
|
@ -2821,7 +2762,6 @@
|
||||||
4A2CAE181AB4BB6400B6BC39 /* SDWebImageCompat.h in Headers */,
|
4A2CAE181AB4BB6400B6BC39 /* SDWebImageCompat.h in Headers */,
|
||||||
32FDE8812088871B008D7530 /* MKAnnotationView+WebCache.h in Headers */,
|
32FDE8812088871B008D7530 /* MKAnnotationView+WebCache.h in Headers */,
|
||||||
80377D961F2F66A700F89830 /* msa_macro.h in Headers */,
|
80377D961F2F66A700F89830 /* msa_macro.h in Headers */,
|
||||||
43CE75D11CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.h in Headers */,
|
|
||||||
80377C391F2F666300F89830 /* huffman_utils.h in Headers */,
|
80377C391F2F666300F89830 /* huffman_utils.h in Headers */,
|
||||||
4A2CAE331AB4BB7500B6BC39 /* UIImageView+HighlightedWebCache.h in Headers */,
|
4A2CAE331AB4BB7500B6BC39 /* UIImageView+HighlightedWebCache.h in Headers */,
|
||||||
431739521CDFC8B70008FEB9 /* mux.h in Headers */,
|
431739521CDFC8B70008FEB9 /* mux.h in Headers */,
|
||||||
|
@ -2832,7 +2772,6 @@
|
||||||
323F8BDA1F38EF770092B609 /* vp8i_enc.h in Headers */,
|
323F8BDA1F38EF770092B609 /* vp8i_enc.h in Headers */,
|
||||||
4317394E1CDFC8B70008FEB9 /* decode.h in Headers */,
|
4317394E1CDFC8B70008FEB9 /* decode.h in Headers */,
|
||||||
80377C2C1F2F666300F89830 /* bit_reader_inl_utils.h in Headers */,
|
80377C2C1F2F666300F89830 /* bit_reader_inl_utils.h in Headers */,
|
||||||
43CE75771CFE9427006C64D0 /* FLAnimatedImage.h in Headers */,
|
|
||||||
4A2CAE2B1AB4BB7500B6BC39 /* UIButton+WebCache.h in Headers */,
|
4A2CAE2B1AB4BB7500B6BC39 /* UIButton+WebCache.h in Headers */,
|
||||||
4A2CAE251AB4BB7000B6BC39 /* SDWebImagePrefetcher.h in Headers */,
|
4A2CAE251AB4BB7000B6BC39 /* SDWebImagePrefetcher.h in Headers */,
|
||||||
80377C431F2F666300F89830 /* thread_utils.h in Headers */,
|
80377C431F2F666300F89830 /* thread_utils.h in Headers */,
|
||||||
|
@ -2906,7 +2845,6 @@
|
||||||
80377D0C1F2F66A100F89830 /* msa_macro.h in Headers */,
|
80377D0C1F2F66A100F89830 /* msa_macro.h in Headers */,
|
||||||
3290FA041FA478AF0047D20C /* SDImageFrame.h in Headers */,
|
3290FA041FA478AF0047D20C /* SDImageFrame.h in Headers */,
|
||||||
80377D1D1F2F66A100F89830 /* yuv.h in Headers */,
|
80377D1D1F2F66A100F89830 /* yuv.h in Headers */,
|
||||||
43CE75D01CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.h in Headers */,
|
|
||||||
807A12281F89636300EC2A9B /* SDImageCodersManager.h in Headers */,
|
807A12281F89636300EC2A9B /* SDImageCodersManager.h in Headers */,
|
||||||
32B9B537206ED4230026769D /* SDWebImageDownloaderConfig.h in Headers */,
|
32B9B537206ED4230026769D /* SDWebImageDownloaderConfig.h in Headers */,
|
||||||
80377C051F2F665300F89830 /* huffman_utils.h in Headers */,
|
80377C051F2F665300F89830 /* huffman_utils.h in Headers */,
|
||||||
|
@ -2953,7 +2891,6 @@
|
||||||
80377CFD1F2F66A100F89830 /* lossless_common.h in Headers */,
|
80377CFD1F2F66A100F89830 /* lossless_common.h in Headers */,
|
||||||
431738C01CDFC2660008FEB9 /* format_constants.h in Headers */,
|
431738C01CDFC2660008FEB9 /* format_constants.h in Headers */,
|
||||||
323F8B621F38EF770092B609 /* cost_enc.h in Headers */,
|
323F8B621F38EF770092B609 /* cost_enc.h in Headers */,
|
||||||
43CE75761CFE9427006C64D0 /* FLAnimatedImage.h in Headers */,
|
|
||||||
323F8BE41F38EF770092B609 /* vp8li_enc.h in Headers */,
|
323F8BE41F38EF770092B609 /* vp8li_enc.h in Headers */,
|
||||||
32FDE88F20888726008D7530 /* SDImageWebPCoder.h in Headers */,
|
32FDE88F20888726008D7530 /* SDImageWebPCoder.h in Headers */,
|
||||||
320CAE152086F50500CFFC80 /* SDWebImageError.h in Headers */,
|
320CAE152086F50500CFFC80 /* SDWebImageError.h in Headers */,
|
||||||
|
@ -2965,7 +2902,6 @@
|
||||||
32484763201775F600AF9E5A /* SDAnimatedImageView+WebCache.h in Headers */,
|
32484763201775F600AF9E5A /* SDAnimatedImageView+WebCache.h in Headers */,
|
||||||
80377E911F2F66D000F89830 /* vp8_dec.h in Headers */,
|
80377E911F2F66D000F89830 /* vp8_dec.h in Headers */,
|
||||||
323F8B6E1F38EF770092B609 /* delta_palettization_enc.h in Headers */,
|
323F8B6E1F38EF770092B609 /* delta_palettization_enc.h in Headers */,
|
||||||
43CE757C1CFE9427006C64D0 /* FLAnimatedImageView.h in Headers */,
|
|
||||||
32D1221E2080B2EB003685A3 /* SDImageCacheDefine.h in Headers */,
|
32D1221E2080B2EB003685A3 /* SDImageCacheDefine.h in Headers */,
|
||||||
80377E8A1F2F66D000F89830 /* common_dec.h in Headers */,
|
80377E8A1F2F66D000F89830 /* common_dec.h in Headers */,
|
||||||
AB615303192DA24600A2D8E9 /* UIView+WebCacheOperation.h in Headers */,
|
AB615303192DA24600A2D8E9 /* UIView+WebCacheOperation.h in Headers */,
|
||||||
|
@ -3222,7 +3158,6 @@
|
||||||
323F8BC91F38EF770092B609 /* syntax_enc.c in Sources */,
|
323F8BC91F38EF770092B609 /* syntax_enc.c in Sources */,
|
||||||
80377DC01F2F66A700F89830 /* enc_mips_dsp_r2.c in Sources */,
|
80377DC01F2F66A700F89830 /* enc_mips_dsp_r2.c in Sources */,
|
||||||
80377DA91F2F66A700F89830 /* alpha_processing_neon.c in Sources */,
|
80377DA91F2F66A700F89830 /* alpha_processing_neon.c in Sources */,
|
||||||
43CE75D51CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.m in Sources */,
|
|
||||||
320CAE1E2086F50500CFFC80 /* SDWebImageError.m in Sources */,
|
320CAE1E2086F50500CFFC80 /* SDWebImageError.m in Sources */,
|
||||||
80377DB71F2F66A700F89830 /* dec_mips_dsp_r2.c in Sources */,
|
80377DB71F2F66A700F89830 /* dec_mips_dsp_r2.c in Sources */,
|
||||||
80377DC31F2F66A700F89830 /* enc_neon.c in Sources */,
|
80377DC31F2F66A700F89830 /* enc_neon.c in Sources */,
|
||||||
|
@ -3315,7 +3250,6 @@
|
||||||
80377DC91F2F66A700F89830 /* filters_neon.c in Sources */,
|
80377DC91F2F66A700F89830 /* filters_neon.c in Sources */,
|
||||||
80377DC51F2F66A700F89830 /* enc_sse41.c in Sources */,
|
80377DC51F2F66A700F89830 /* enc_sse41.c in Sources */,
|
||||||
80377DE61F2F66A700F89830 /* upsampling_sse2.c in Sources */,
|
80377DE61F2F66A700F89830 /* upsampling_sse2.c in Sources */,
|
||||||
43CE75811CFE9427006C64D0 /* FLAnimatedImageView.m in Sources */,
|
|
||||||
80377C561F2F666300F89830 /* quant_levels_utils.c in Sources */,
|
80377C561F2F666300F89830 /* quant_levels_utils.c in Sources */,
|
||||||
323F8BCF1F38EF770092B609 /* token_enc.c in Sources */,
|
323F8BCF1F38EF770092B609 /* token_enc.c in Sources */,
|
||||||
80377DD11F2F66A700F89830 /* lossless_enc_sse2.c in Sources */,
|
80377DD11F2F66A700F89830 /* lossless_enc_sse2.c in Sources */,
|
||||||
|
@ -3349,7 +3283,6 @@
|
||||||
80377DB21F2F66A700F89830 /* cost_mips32.c in Sources */,
|
80377DB21F2F66A700F89830 /* cost_mips32.c in Sources */,
|
||||||
32EB6D90206D132E005CAEF6 /* SDAnimatedImageRep.m in Sources */,
|
32EB6D90206D132E005CAEF6 /* SDAnimatedImageRep.m in Sources */,
|
||||||
80377DC81F2F66A700F89830 /* filters_msa.c in Sources */,
|
80377DC81F2F66A700F89830 /* filters_msa.c in Sources */,
|
||||||
43CE757B1CFE9427006C64D0 /* FLAnimatedImage.m in Sources */,
|
|
||||||
00733A571BC4880000A5A117 /* SDImageCache.m in Sources */,
|
00733A571BC4880000A5A117 /* SDImageCache.m in Sources */,
|
||||||
4369C2811D9807EC007E863A /* UIView+WebCache.m in Sources */,
|
4369C2811D9807EC007E863A /* UIView+WebCache.m in Sources */,
|
||||||
00733A5E1BC4880000A5A117 /* UIImage+MultiFormat.m in Sources */,
|
00733A5E1BC4880000A5A117 /* UIImage+MultiFormat.m in Sources */,
|
||||||
|
@ -3905,14 +3838,12 @@
|
||||||
32F7C0772030114C00873181 /* SDImageTransformer.m in Sources */,
|
32F7C0772030114C00873181 /* SDImageTransformer.m in Sources */,
|
||||||
43C8929D1D9D6DD90022038D /* anim_decode.c in Sources */,
|
43C8929D1D9D6DD90022038D /* anim_decode.c in Sources */,
|
||||||
323F8B6A1F38EF770092B609 /* delta_palettization_enc.c in Sources */,
|
323F8B6A1F38EF770092B609 /* delta_palettization_enc.c in Sources */,
|
||||||
43CE75D41CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.m in Sources */,
|
|
||||||
323F8B5E1F38EF770092B609 /* cost_enc.c in Sources */,
|
323F8B5E1F38EF770092B609 /* cost_enc.c in Sources */,
|
||||||
80377D8A1F2F66A700F89830 /* lossless_enc_msa.c in Sources */,
|
80377D8A1F2F66A700F89830 /* lossless_enc_msa.c in Sources */,
|
||||||
80377EA91F2F66D400F89830 /* buffer_dec.c in Sources */,
|
80377EA91F2F66D400F89830 /* buffer_dec.c in Sources */,
|
||||||
80377C341F2F666300F89830 /* filters_utils.c in Sources */,
|
80377C341F2F666300F89830 /* filters_utils.c in Sources */,
|
||||||
80377D901F2F66A700F89830 /* lossless_msa.c in Sources */,
|
80377D901F2F66A700F89830 /* lossless_msa.c in Sources */,
|
||||||
80377DA61F2F66A700F89830 /* yuv.c in Sources */,
|
80377DA61F2F66A700F89830 /* yuv.c in Sources */,
|
||||||
43CE757A1CFE9427006C64D0 /* FLAnimatedImage.m in Sources */,
|
|
||||||
3237F9E820161AE000A88143 /* NSImage+Compatibility.m in Sources */,
|
3237F9E820161AE000A88143 /* NSImage+Compatibility.m in Sources */,
|
||||||
32C0FDE92013426C001B8F2D /* SDWebImageIndicator.m in Sources */,
|
32C0FDE92013426C001B8F2D /* SDWebImageIndicator.m in Sources */,
|
||||||
32F21B5920788D8C0036B1D5 /* SDWebImageDownloaderRequestModifier.m in Sources */,
|
32F21B5920788D8C0036B1D5 /* SDWebImageDownloaderRequestModifier.m in Sources */,
|
||||||
|
@ -4022,7 +3953,6 @@
|
||||||
80377D831F2F66A700F89830 /* filters_msa.c in Sources */,
|
80377D831F2F66A700F89830 /* filters_msa.c in Sources */,
|
||||||
4A2CAE341AB4BB7500B6BC39 /* UIImageView+HighlightedWebCache.m in Sources */,
|
4A2CAE341AB4BB7500B6BC39 /* UIImageView+HighlightedWebCache.m in Sources */,
|
||||||
4A2CAE201AB4BB6C00B6BC39 /* SDImageCache.m in Sources */,
|
4A2CAE201AB4BB6C00B6BC39 /* SDImageCache.m in Sources */,
|
||||||
43CE75801CFE9427006C64D0 /* FLAnimatedImageView.m in Sources */,
|
|
||||||
4369C2801D9807EC007E863A /* UIView+WebCache.m in Sources */,
|
4369C2801D9807EC007E863A /* UIView+WebCache.m in Sources */,
|
||||||
80377D8B1F2F66A700F89830 /* lossless_enc_neon.c in Sources */,
|
80377D8B1F2F66A700F89830 /* lossless_enc_neon.c in Sources */,
|
||||||
329A18611FFF5DFD008C9A2F /* UIImage+Metadata.m in Sources */,
|
329A18611FFF5DFD008C9A2F /* UIImage+Metadata.m in Sources */,
|
||||||
|
@ -4075,14 +4005,12 @@
|
||||||
43C8929A1D9D6DD70022038D /* anim_decode.c in Sources */,
|
43C8929A1D9D6DD70022038D /* anim_decode.c in Sources */,
|
||||||
32F7C0752030114C00873181 /* SDImageTransformer.m in Sources */,
|
32F7C0752030114C00873181 /* SDImageTransformer.m in Sources */,
|
||||||
323F8B681F38EF770092B609 /* delta_palettization_enc.c in Sources */,
|
323F8B681F38EF770092B609 /* delta_palettization_enc.c in Sources */,
|
||||||
43CE75D31CFE98E0006C64D0 /* FLAnimatedImageView+WebCache.m in Sources */,
|
|
||||||
323F8B5C1F38EF770092B609 /* cost_enc.c in Sources */,
|
323F8B5C1F38EF770092B609 /* cost_enc.c in Sources */,
|
||||||
80377D001F2F66A100F89830 /* lossless_enc_msa.c in Sources */,
|
80377D001F2F66A100F89830 /* lossless_enc_msa.c in Sources */,
|
||||||
80377E891F2F66D000F89830 /* buffer_dec.c in Sources */,
|
80377E891F2F66D000F89830 /* buffer_dec.c in Sources */,
|
||||||
80377C001F2F665300F89830 /* filters_utils.c in Sources */,
|
80377C001F2F665300F89830 /* filters_utils.c in Sources */,
|
||||||
80377D061F2F66A100F89830 /* lossless_msa.c in Sources */,
|
80377D061F2F66A100F89830 /* lossless_msa.c in Sources */,
|
||||||
80377D1C1F2F66A100F89830 /* yuv.c in Sources */,
|
80377D1C1F2F66A100F89830 /* yuv.c in Sources */,
|
||||||
43CE75791CFE9427006C64D0 /* FLAnimatedImage.m in Sources */,
|
|
||||||
80377CF71F2F66A100F89830 /* enc.c in Sources */,
|
80377CF71F2F66A100F89830 /* enc.c in Sources */,
|
||||||
3237F9EB20161AE000A88143 /* NSImage+Compatibility.m in Sources */,
|
3237F9EB20161AE000A88143 /* NSImage+Compatibility.m in Sources */,
|
||||||
32C0FDE72013426C001B8F2D /* SDWebImageIndicator.m in Sources */,
|
32C0FDE72013426C001B8F2D /* SDWebImageIndicator.m in Sources */,
|
||||||
|
@ -4192,7 +4120,6 @@
|
||||||
5D5B9145188EE8DD006D06BD /* NSData+ImageContentType.m in Sources */,
|
5D5B9145188EE8DD006D06BD /* NSData+ImageContentType.m in Sources */,
|
||||||
53EDFB8C17623F7C00698166 /* UIImage+MultiFormat.m in Sources */,
|
53EDFB8C17623F7C00698166 /* UIImage+MultiFormat.m in Sources */,
|
||||||
ABBE71A818C43B4D00B75E91 /* UIImageView+HighlightedWebCache.m in Sources */,
|
ABBE71A818C43B4D00B75E91 /* UIImageView+HighlightedWebCache.m in Sources */,
|
||||||
43CE757F1CFE9427006C64D0 /* FLAnimatedImageView.m in Sources */,
|
|
||||||
4369C27E1D9807EC007E863A /* UIView+WebCache.m in Sources */,
|
4369C27E1D9807EC007E863A /* UIView+WebCache.m in Sources */,
|
||||||
80377D011F2F66A100F89830 /* lossless_enc_neon.c in Sources */,
|
80377D011F2F66A100F89830 /* lossless_enc_neon.c in Sources */,
|
||||||
329A185F1FFF5DFD008C9A2F /* UIImage+Metadata.m in Sources */,
|
329A185F1FFF5DFD008C9A2F /* UIImage+Metadata.m in Sources */,
|
||||||
|
|
|
@ -1,168 +0,0 @@
|
||||||
/*
|
|
||||||
* This file is part of the SDWebImage package.
|
|
||||||
* (c) Olivier Poitrey <rs@dailymotion.com>
|
|
||||||
*
|
|
||||||
* For the full copyright and license information, please view the LICENSE
|
|
||||||
* file that was distributed with this source code.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import "SDWebImageCompat.h"
|
|
||||||
|
|
||||||
#if SD_UIKIT
|
|
||||||
|
|
||||||
#if __has_include(<FLAnimatedImage/FLAnimatedImage.h>)
|
|
||||||
#import <FLAnimatedImage/FLAnimatedImage.h>
|
|
||||||
#else
|
|
||||||
#import "FLAnimatedImage.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#import "SDWebImageManager.h"
|
|
||||||
|
|
||||||
/**
|
|
||||||
* FLAnimatedImage is not a subclass of UIImage, so it's not possible to store it into the memory cache currently. However, for performance issue and cell reuse on FLAnimatedImageView, we use associate object to bind a FLAnimatedImage into UIImage when an animated GIF image load. For most cases, you don't need to touch this.
|
|
||||||
*/
|
|
||||||
@interface UIImage (FLAnimatedImage)
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The FLAnimatedImage associated to the UIImage instance when an animated GIF image load.
|
|
||||||
* For most cases this is read-only and you should avoid manually setting this value. Util some cases like using placeholder with a `FLAnimatedImage`.
|
|
||||||
*/
|
|
||||||
@property (nonatomic, strong, nullable) FLAnimatedImage *sd_FLAnimatedImage;
|
|
||||||
|
|
||||||
@end
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A category for the FLAnimatedImage imageView class that hooks it to the SDWebImage system.
|
|
||||||
* Very similar to the base class category (UIImageView (WebCache))
|
|
||||||
*/
|
|
||||||
@interface FLAnimatedImageView (WebCache)
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Optimal frame cache size of FLAnimatedImage during initializer. (1.0.11 version later)
|
|
||||||
* This value will help you set `optimalFrameCacheSize` arg of FLAnimatedImage initializer after image load.
|
|
||||||
* Defaults to 0.
|
|
||||||
*/
|
|
||||||
@property (nonatomic, assign) NSUInteger sd_optimalFrameCacheSize;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Predrawing control of FLAnimatedImage during initializer. (1.0.11 version later)
|
|
||||||
* This value will help you set `predrawingEnabled` arg of FLAnimatedImage initializer after image load.
|
|
||||||
* Defaults to YES.
|
|
||||||
*/
|
|
||||||
@property (nonatomic, assign) BOOL sd_predrawingEnabled;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Cache control for associated FLAnimatedImage object for memory cache. When enabled, we will bind created FLAnimatedImage instance to UIImage, and store it into memory cache to avoid create this instance cause decoding performance. See `UIImage+FLAnimatedImage`.
|
|
||||||
* When enabled, this may consume more memory, if you are facing memory issue, disable it and let FLAnimatedImage been created just in time and dealloced as it not been used. However, when disabled, this may impact performance since we need query disk cache, create FLAnimatedImage and decoding even when the current GIF url is cached.
|
|
||||||
* Defatuls to YES;
|
|
||||||
*/
|
|
||||||
@property (nonatomic, assign) BOOL sd_cacheFLAnimatedImage;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Load the image at the given url (either from cache or download) and load it in this imageView. It works with both static and dynamic images
|
|
||||||
* The download is asynchronous and cached.
|
|
||||||
*
|
|
||||||
* @param url The url for the image.
|
|
||||||
*/
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url NS_REFINED_FOR_SWIFT;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Load the image at the given url (either from cache or download) and load it in this imageView. It works with both static and dynamic images
|
|
||||||
* The download is asynchronous and cached.
|
|
||||||
* Uses a placeholder until the request finishes.
|
|
||||||
*
|
|
||||||
* @param url The url for the image.
|
|
||||||
* @param placeholder The image to be set initially, until the image request finishes.
|
|
||||||
*/
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url
|
|
||||||
placeholderImage:(nullable UIImage *)placeholder NS_REFINED_FOR_SWIFT;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Load the image at the given url (either from cache or download) and load it in this imageView. It works with both static and dynamic images
|
|
||||||
* The download is asynchronous and cached.
|
|
||||||
* Uses a placeholder until the request finishes.
|
|
||||||
*
|
|
||||||
* @param url The url for the image.
|
|
||||||
* @param placeholder The image to be set initially, until the image request finishes.
|
|
||||||
* @param options The options to use when downloading the image. @see SDWebImageOptions for the possible values.
|
|
||||||
*/
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url
|
|
||||||
placeholderImage:(nullable UIImage *)placeholder
|
|
||||||
options:(SDWebImageOptions)options NS_REFINED_FOR_SWIFT;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Load the image at the given url (either from cache or download) and load it in this imageView. It works with both static and dynamic images
|
|
||||||
* The download is asynchronous and cached.
|
|
||||||
*
|
|
||||||
* @param url The url for the image.
|
|
||||||
* @param completedBlock A block called when operation has been completed. This block has no return value
|
|
||||||
* and takes the requested UIImage as first parameter. In case of error the image parameter
|
|
||||||
* is nil and the second parameter may contain an NSError. The third parameter is a Boolean
|
|
||||||
* indicating if the image was retrieved from the local cache or from the network.
|
|
||||||
* The fourth parameter is the original image url.
|
|
||||||
*/
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url
|
|
||||||
completed:(nullable SDExternalCompletionBlock)completedBlock;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Load the image at the given url (either from cache or download) and load it in this imageView. It works with both static and dynamic images
|
|
||||||
* The download is asynchronous and cached.
|
|
||||||
* Uses a placeholder until the request finishes.
|
|
||||||
*
|
|
||||||
* @param url The url for the image.
|
|
||||||
* @param placeholder The image to be set initially, until the image request finishes.
|
|
||||||
* @param completedBlock A block called when operation has been completed. This block has no return value
|
|
||||||
* and takes the requested UIImage as first parameter. In case of error the image parameter
|
|
||||||
* is nil and the second parameter may contain an NSError. The third parameter is a Boolean
|
|
||||||
* indicating if the image was retrieved from the local cache or from the network.
|
|
||||||
* The fourth parameter is the original image url.
|
|
||||||
*/
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url
|
|
||||||
placeholderImage:(nullable UIImage *)placeholder
|
|
||||||
completed:(nullable SDExternalCompletionBlock)completedBlock NS_REFINED_FOR_SWIFT;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Load the image at the given url (either from cache or download) and load it in this imageView. It works with both static and dynamic images
|
|
||||||
* The download is asynchronous and cached.
|
|
||||||
* Uses a placeholder until the request finishes.
|
|
||||||
*
|
|
||||||
* @param url The url for the image.
|
|
||||||
* @param placeholder The image to be set initially, until the image request finishes.
|
|
||||||
* @param options The options to use when downloading the image. @see SDWebImageOptions for the possible values.
|
|
||||||
* @param completedBlock A block called when operation has been completed. This block has no return value
|
|
||||||
* and takes the requested UIImage as first parameter. In case of error the image parameter
|
|
||||||
* is nil and the second parameter may contain an NSError. The third parameter is a Boolean
|
|
||||||
* indicating if the image was retrieved from the local cache or from the network.
|
|
||||||
* The fourth parameter is the original image url.
|
|
||||||
*/
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url
|
|
||||||
placeholderImage:(nullable UIImage *)placeholder
|
|
||||||
options:(SDWebImageOptions)options
|
|
||||||
completed:(nullable SDExternalCompletionBlock)completedBlock;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Load the image at the given url (either from cache or download) and load it in this imageView. It works with both static and dynamic images
|
|
||||||
* The download is asynchronous and cached.
|
|
||||||
* Uses a placeholder until the request finishes.
|
|
||||||
*
|
|
||||||
* @param url The url for the image.
|
|
||||||
* @param placeholder The image to be set initially, until the image request finishes.
|
|
||||||
* @param options The options to use when downloading the image. @see SDWebImageOptions for the possible values.
|
|
||||||
* @param progressBlock A block called while image is downloading
|
|
||||||
* @note the progress block is executed on a background queue
|
|
||||||
* @param completedBlock A block called when operation has been completed. This block has no return value
|
|
||||||
* and takes the requested UIImage as first parameter. In case of error the image parameter
|
|
||||||
* is nil and the second parameter may contain an NSError. The third parameter is a Boolean
|
|
||||||
* indicating if the image was retrieved from the local cache or from the network.
|
|
||||||
* The fourth parameter is the original image url.
|
|
||||||
*/
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url
|
|
||||||
placeholderImage:(nullable UIImage *)placeholder
|
|
||||||
options:(SDWebImageOptions)options
|
|
||||||
progress:(nullable SDImageLoaderProgressBlock)progressBlock
|
|
||||||
completed:(nullable SDExternalCompletionBlock)completedBlock;
|
|
||||||
|
|
||||||
@end
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -1,175 +0,0 @@
|
||||||
/*
|
|
||||||
* This file is part of the SDWebImage package.
|
|
||||||
* (c) Olivier Poitrey <rs@dailymotion.com>
|
|
||||||
*
|
|
||||||
* For the full copyright and license information, please view the LICENSE
|
|
||||||
* file that was distributed with this source code.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import "FLAnimatedImageView+WebCache.h"
|
|
||||||
|
|
||||||
#if SD_UIKIT
|
|
||||||
#import "objc/runtime.h"
|
|
||||||
#import "UIView+WebCacheOperation.h"
|
|
||||||
#import "UIView+WebCache.h"
|
|
||||||
#import "NSData+ImageContentType.h"
|
|
||||||
#import "UIImageView+WebCache.h"
|
|
||||||
|
|
||||||
@implementation UIImage (FLAnimatedImage)
|
|
||||||
|
|
||||||
- (FLAnimatedImage *)sd_FLAnimatedImage {
|
|
||||||
return objc_getAssociatedObject(self, @selector(sd_FLAnimatedImage));
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)setSd_FLAnimatedImage:(FLAnimatedImage *)sd_FLAnimatedImage {
|
|
||||||
objc_setAssociatedObject(self, @selector(sd_FLAnimatedImage), sd_FLAnimatedImage, OBJC_ASSOCIATION_RETAIN_NONATOMIC);
|
|
||||||
}
|
|
||||||
|
|
||||||
@end
|
|
||||||
|
|
||||||
@implementation FLAnimatedImageView (WebCache)
|
|
||||||
|
|
||||||
// These property based options will moved to `SDWebImageContext` in 5.x, to allow per-image-request level options instead of per-imageView-level options
|
|
||||||
- (NSUInteger)sd_optimalFrameCacheSize {
|
|
||||||
NSUInteger optimalFrameCacheSize = 0;
|
|
||||||
NSNumber *value = objc_getAssociatedObject(self, @selector(sd_optimalFrameCacheSize));
|
|
||||||
if ([value isKindOfClass:[NSNumber class]]) {
|
|
||||||
optimalFrameCacheSize = value.unsignedShortValue;
|
|
||||||
}
|
|
||||||
return optimalFrameCacheSize;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)setSd_optimalFrameCacheSize:(NSUInteger)sd_optimalFrameCacheSize {
|
|
||||||
objc_setAssociatedObject(self, @selector(sd_optimalFrameCacheSize), @(sd_optimalFrameCacheSize), OBJC_ASSOCIATION_RETAIN_NONATOMIC);
|
|
||||||
}
|
|
||||||
|
|
||||||
- (BOOL)sd_predrawingEnabled {
|
|
||||||
BOOL predrawingEnabled = YES;
|
|
||||||
NSNumber *value = objc_getAssociatedObject(self, @selector(sd_predrawingEnabled));
|
|
||||||
if ([value isKindOfClass:[NSNumber class]]) {
|
|
||||||
predrawingEnabled = value.boolValue;
|
|
||||||
}
|
|
||||||
return predrawingEnabled;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)setSd_predrawingEnabled:(BOOL)sd_predrawingEnabled {
|
|
||||||
objc_setAssociatedObject(self, @selector(sd_predrawingEnabled), @(sd_predrawingEnabled), OBJC_ASSOCIATION_RETAIN_NONATOMIC);
|
|
||||||
}
|
|
||||||
|
|
||||||
- (BOOL)sd_cacheFLAnimatedImage {
|
|
||||||
BOOL cacheFLAnimatedImage = YES;
|
|
||||||
NSNumber *value = objc_getAssociatedObject(self, @selector(sd_cacheFLAnimatedImage));
|
|
||||||
if ([value isKindOfClass:[NSNumber class]]) {
|
|
||||||
cacheFLAnimatedImage = value.boolValue;
|
|
||||||
}
|
|
||||||
return cacheFLAnimatedImage;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)setSd_cacheFLAnimatedImage:(BOOL)sd_cacheFLAnimatedImage {
|
|
||||||
objc_setAssociatedObject(self, @selector(sd_cacheFLAnimatedImage), @(sd_cacheFLAnimatedImage), OBJC_ASSOCIATION_RETAIN_NONATOMIC);
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url {
|
|
||||||
[self sd_setImageWithURL:url placeholderImage:nil options:0 progress:nil completed:nil];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url placeholderImage:(nullable UIImage *)placeholder {
|
|
||||||
[self sd_setImageWithURL:url placeholderImage:placeholder options:0 progress:nil completed:nil];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url placeholderImage:(nullable UIImage *)placeholder options:(SDWebImageOptions)options {
|
|
||||||
[self sd_setImageWithURL:url placeholderImage:placeholder options:options progress:nil completed:nil];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url completed:(nullable SDExternalCompletionBlock)completedBlock {
|
|
||||||
[self sd_setImageWithURL:url placeholderImage:nil options:0 progress:nil completed:completedBlock];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url placeholderImage:(nullable UIImage *)placeholder completed:(nullable SDExternalCompletionBlock)completedBlock {
|
|
||||||
[self sd_setImageWithURL:url placeholderImage:placeholder options:0 progress:nil completed:completedBlock];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url placeholderImage:(nullable UIImage *)placeholder options:(SDWebImageOptions)options completed:(nullable SDExternalCompletionBlock)completedBlock {
|
|
||||||
[self sd_setImageWithURL:url placeholderImage:placeholder options:options progress:nil completed:completedBlock];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options progress:(SDImageLoaderProgressBlock)progressBlock completed:(SDExternalCompletionBlock)completedBlock {
|
|
||||||
[self sd_setImageWithURL:url placeholderImage:placeholder options:options context:nil progress:progressBlock completed:completedBlock];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)sd_setImageWithURL:(nullable NSURL *)url
|
|
||||||
placeholderImage:(nullable UIImage *)placeholder
|
|
||||||
options:(SDWebImageOptions)options
|
|
||||||
context:(nullable SDWebImageContext *)context
|
|
||||||
progress:(nullable SDImageLoaderProgressBlock)progressBlock
|
|
||||||
completed:(nullable SDExternalCompletionBlock)completedBlock {
|
|
||||||
dispatch_group_t group = dispatch_group_create();
|
|
||||||
SDWebImageMutableContext *mutableContext;
|
|
||||||
if (context) {
|
|
||||||
mutableContext = [context mutableCopy];
|
|
||||||
} else {
|
|
||||||
mutableContext = [NSMutableDictionary dictionary];
|
|
||||||
}
|
|
||||||
mutableContext[SDWebImageContextSetImageGroup] = group;
|
|
||||||
__weak typeof(self)weakSelf = self;
|
|
||||||
[self sd_internalSetImageWithURL:url
|
|
||||||
placeholderImage:placeholder
|
|
||||||
options:options
|
|
||||||
context:mutableContext
|
|
||||||
setImageBlock:^(UIImage *image, NSData *imageData) {
|
|
||||||
// We could not directlly create the animated image on bacakground queue because it's time consuming, by the time we set it back, the current runloop has passed and the placeholder has been rendered and then replaced with animated image, this cause a flashing.
|
|
||||||
// Previously we use a trick to firstly set the static poster image, then set animated image back to avoid flashing, but this trick fail when using with custom UIView transition. Core Animation will use the current layer state to do rendering, so even we later set it back, the transition will not update. (it's recommended to use `SDWebImageTransition` instead)
|
|
||||||
// So we have no choice to force store the FLAnimatedImage into memory cache using a associated object binding to UIImage instance. This consumed memory is adoptable and much smaller than `_UIAnimatedImage` for big GIF
|
|
||||||
FLAnimatedImage *associatedAnimatedImage = image.sd_FLAnimatedImage;
|
|
||||||
if (associatedAnimatedImage) {
|
|
||||||
// Asscociated animated image exist
|
|
||||||
weakSelf.animatedImage = associatedAnimatedImage;
|
|
||||||
weakSelf.image = nil;
|
|
||||||
if (group) {
|
|
||||||
dispatch_group_leave(group);
|
|
||||||
}
|
|
||||||
} else if ([NSData sd_imageFormatForImageData:imageData] == SDImageFormatGIF) {
|
|
||||||
// Firstly set the static poster image to avoid flashing
|
|
||||||
UIImage *posterImage = image.images ? image.images.firstObject : image;
|
|
||||||
weakSelf.image = posterImage;
|
|
||||||
weakSelf.animatedImage = nil;
|
|
||||||
// Secondly create FLAnimatedImage in global queue because it's time consuming, then set it back
|
|
||||||
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0), ^{
|
|
||||||
FLAnimatedImage *animatedImage;
|
|
||||||
// Compatibility in 4.x for lower version FLAnimatedImage.
|
|
||||||
if ([FLAnimatedImage respondsToSelector:@selector(initWithAnimatedGIFData:optimalFrameCacheSize:predrawingEnabled:)]) {
|
|
||||||
animatedImage = [[FLAnimatedImage alloc] initWithAnimatedGIFData:imageData optimalFrameCacheSize:weakSelf.sd_optimalFrameCacheSize predrawingEnabled:weakSelf.sd_predrawingEnabled];
|
|
||||||
} else {
|
|
||||||
animatedImage = [[FLAnimatedImage alloc] initWithAnimatedGIFData:imageData];
|
|
||||||
}
|
|
||||||
dispatch_async(dispatch_get_main_queue(), ^{
|
|
||||||
if (weakSelf.sd_cacheFLAnimatedImage) {
|
|
||||||
image.sd_FLAnimatedImage = animatedImage;
|
|
||||||
}
|
|
||||||
weakSelf.animatedImage = animatedImage;
|
|
||||||
weakSelf.image = nil;
|
|
||||||
if (group) {
|
|
||||||
dispatch_group_leave(group);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
// Not animated image
|
|
||||||
weakSelf.image = image;
|
|
||||||
weakSelf.animatedImage = nil;
|
|
||||||
if (group) {
|
|
||||||
dispatch_group_leave(group);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
progress:progressBlock
|
|
||||||
completed:^(UIImage * _Nullable image, NSData * _Nullable data, NSError * _Nullable error, SDImageCacheType cacheType, BOOL finished, NSURL * _Nullable imageURL) {
|
|
||||||
if (completedBlock) {
|
|
||||||
completedBlock(image, error, cacheType, imageURL);
|
|
||||||
}
|
|
||||||
}];
|
|
||||||
}
|
|
||||||
|
|
||||||
@end
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -17,7 +17,7 @@
|
||||||
|
|
||||||
Note: the `coders` getter will return the coders in their reversed order
|
Note: the `coders` getter will return the coders in their reversed order
|
||||||
Example:
|
Example:
|
||||||
- by default we internally set coders = `IOCoder`, `WebPCoder`. (`GIFCoder` is not recommended to add only if you want to get GIF support without `FLAnimatedImage`)
|
- by default we internally set coders = `IOCoder`, `GIFCoder`, `APNGCoder` and `WebPCoder` (When WebP subspec is available).
|
||||||
- calling `coders` will return `@[WebPCoder, IOCoder]`
|
- calling `coders` will return `@[WebPCoder, IOCoder]`
|
||||||
- call `[addCoder:[MyCrazyCoder new]]`
|
- call `[addCoder:[MyCrazyCoder new]]`
|
||||||
- calling `coders` now returns `@[MyCrazyCoder, WebPCoder, IOCoder]`
|
- calling `coders` now returns `@[MyCrazyCoder, WebPCoder, IOCoder]`
|
||||||
|
|
|
@ -14,7 +14,7 @@
|
||||||
|
|
||||||
GIF
|
GIF
|
||||||
Also supports static GIF (meaning will only handle the 1st frame).
|
Also supports static GIF (meaning will only handle the 1st frame).
|
||||||
For a full GIF support, we recommend `FLAnimatedImage` or our less performant `SDImageGIFCoder`
|
For a full GIF support, we recommend `SDAnimatedImageView` to keep both CPU and memory balanced.
|
||||||
|
|
||||||
HEIC
|
HEIC
|
||||||
This coder also supports HEIC format because ImageIO supports it natively. But it depends on the system capabilities, so it won't work on all devices, see: https://devstreaming-cdn.apple.com/videos/wwdc/2017/511tj33587vdhds/511/511_working_with_heif_and_hevc.pdf
|
This coder also supports HEIC format because ImageIO supports it natively. But it depends on the system capabilities, so it won't work on all devices, see: https://devstreaming-cdn.apple.com/videos/wwdc/2017/511tj33587vdhds/511/511_working_with_heif_and_hevc.pdf
|
||||||
|
|
|
@ -11,7 +11,6 @@ target 'Tests' do
|
||||||
pod 'KVOController'
|
pod 'KVOController'
|
||||||
pod 'SDWebImage/WebP', :path => '../'
|
pod 'SDWebImage/WebP', :path => '../'
|
||||||
pod 'SDWebImage/MapKit', :path => '../'
|
pod 'SDWebImage/MapKit', :path => '../'
|
||||||
pod 'SDWebImage/GIF', :path => '../'
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -362,7 +362,7 @@
|
||||||
"${SRCROOT}/Pods/Target Support Files/Pods-Tests Mac/Pods-Tests Mac-frameworks.sh",
|
"${SRCROOT}/Pods/Target Support Files/Pods-Tests Mac/Pods-Tests Mac-frameworks.sh",
|
||||||
"${BUILT_PRODUCTS_DIR}/Expecta-macOS/Expecta.framework",
|
"${BUILT_PRODUCTS_DIR}/Expecta-macOS/Expecta.framework",
|
||||||
"${BUILT_PRODUCTS_DIR}/KVOController-macOS/KVOController.framework",
|
"${BUILT_PRODUCTS_DIR}/KVOController-macOS/KVOController.framework",
|
||||||
"${BUILT_PRODUCTS_DIR}/SDWebImage-Core-MapKit-WebP/SDWebImage.framework",
|
"${BUILT_PRODUCTS_DIR}/SDWebImage-macOS/SDWebImage.framework",
|
||||||
"${BUILT_PRODUCTS_DIR}/libwebp-macOS/libwebp.framework",
|
"${BUILT_PRODUCTS_DIR}/libwebp-macOS/libwebp.framework",
|
||||||
);
|
);
|
||||||
name = "[CP] Embed Pods Frameworks";
|
name = "[CP] Embed Pods Frameworks";
|
||||||
|
@ -436,15 +436,13 @@
|
||||||
inputPaths = (
|
inputPaths = (
|
||||||
"${SRCROOT}/Pods/Target Support Files/Pods-Tests/Pods-Tests-frameworks.sh",
|
"${SRCROOT}/Pods/Target Support Files/Pods-Tests/Pods-Tests-frameworks.sh",
|
||||||
"${BUILT_PRODUCTS_DIR}/Expecta-iOS/Expecta.framework",
|
"${BUILT_PRODUCTS_DIR}/Expecta-iOS/Expecta.framework",
|
||||||
"${BUILT_PRODUCTS_DIR}/FLAnimatedImage/FLAnimatedImage.framework",
|
|
||||||
"${BUILT_PRODUCTS_DIR}/KVOController-iOS/KVOController.framework",
|
"${BUILT_PRODUCTS_DIR}/KVOController-iOS/KVOController.framework",
|
||||||
"${BUILT_PRODUCTS_DIR}/SDWebImage-Core-GIF-MapKit-WebP/SDWebImage.framework",
|
"${BUILT_PRODUCTS_DIR}/SDWebImage-iOS/SDWebImage.framework",
|
||||||
"${BUILT_PRODUCTS_DIR}/libwebp-iOS/libwebp.framework",
|
"${BUILT_PRODUCTS_DIR}/libwebp-iOS/libwebp.framework",
|
||||||
);
|
);
|
||||||
name = "[CP] Embed Pods Frameworks";
|
name = "[CP] Embed Pods Frameworks";
|
||||||
outputPaths = (
|
outputPaths = (
|
||||||
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/Expecta.framework",
|
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/Expecta.framework",
|
||||||
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/FLAnimatedImage.framework",
|
|
||||||
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/KVOController.framework",
|
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/KVOController.framework",
|
||||||
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/SDWebImage.framework",
|
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/SDWebImage.framework",
|
||||||
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/libwebp.framework",
|
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/libwebp.framework",
|
||||||
|
|
|
@ -100,7 +100,7 @@
|
||||||
isAnimatedImage:YES];
|
isAnimatedImage:YES];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)test20ThatOurGIFCoderWorksNotFLAnimatedImage {
|
- (void)test20ThatOurGIFCoderWorks {
|
||||||
NSURL *gifURL = [[NSBundle bundleForClass:[self class]] URLForResource:@"TestImage" withExtension:@"gif"];
|
NSURL *gifURL = [[NSBundle bundleForClass:[self class]] URLForResource:@"TestImage" withExtension:@"gif"];
|
||||||
[self verifyCoder:[SDImageGIFCoder sharedCoder]
|
[self verifyCoder:[SDImageGIFCoder sharedCoder]
|
||||||
withLocalImageURL:gifURL
|
withLocalImageURL:gifURL
|
||||||
|
|
|
@ -117,24 +117,6 @@
|
||||||
}];
|
}];
|
||||||
[self waitForExpectationsWithCommonTimeout];
|
[self waitForExpectationsWithCommonTimeout];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)testFLAnimatedImageViewSetImageWithURL {
|
|
||||||
XCTestExpectation *expectation = [self expectationWithDescription:@"FLAnimatedImageView setImageWithURL"];
|
|
||||||
|
|
||||||
FLAnimatedImageView *imageView = [[FLAnimatedImageView alloc] init];
|
|
||||||
NSURL *originalImageURL = [NSURL URLWithString:@"https://www.interntheory.com/img/loading-small.gif"];
|
|
||||||
|
|
||||||
[imageView sd_setImageWithURL:originalImageURL
|
|
||||||
completed:^(UIImage * _Nullable image, NSError * _Nullable error, SDImageCacheType cacheType, NSURL * _Nullable imageURL) {
|
|
||||||
expect(image).toNot.beNil();
|
|
||||||
expect(error).to.beNil();
|
|
||||||
expect(originalImageURL).to.equal(imageURL);
|
|
||||||
|
|
||||||
expect(imageView.animatedImage).toNot.beNil();
|
|
||||||
[expectation fulfill];
|
|
||||||
}];
|
|
||||||
[self waitForExpectationsWithCommonTimeout];
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
- (void)testUIViewImageProgressKVOWork {
|
- (void)testUIViewImageProgressKVOWork {
|
||||||
|
|
|
@ -1 +0,0 @@
|
||||||
Subproject commit 25307796cfcf66cb5b98774e050e93f64e0f2cde
|
|
|
@ -81,12 +81,6 @@ FOUNDATION_EXPORT const unsigned char WebImageVersionString[];
|
||||||
#import <SDWebImage/MKAnnotationView+WebCache.h>
|
#import <SDWebImage/MKAnnotationView+WebCache.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
// GIF
|
|
||||||
#if __has_include(<SDWebImage/FLAnimatedImageView+WebCache.h>)
|
|
||||||
#import <SDWebImage/FLAnimatedImageView+WebCache.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// WebP
|
// WebP
|
||||||
#if __has_include(<SDWebImage/UIImage+WebP.h>)
|
#if __has_include(<SDWebImage/UIImage+WebP.h>)
|
||||||
#import <SDWebImage/UIImage+WebP.h>
|
#import <SDWebImage/UIImage+WebP.h>
|
||||||
|
|
Loading…
Reference in New Issue