From ff0e03eb7516d8f122dede113d6eaab10dfb47bf Mon Sep 17 00:00:00 2001 From: Khanh Pham Date: Wed, 19 Dec 2018 22:03:29 +0800 Subject: [PATCH] Fix UI API called on a background thread --- Classes/IDMPhoto.m | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/Classes/IDMPhoto.m b/Classes/IDMPhoto.m index a2959d5c..98aa2563 100644 --- a/Classes/IDMPhoto.m +++ b/Classes/IDMPhoto.m @@ -139,10 +139,19 @@ - (void)loadUnderlyingImageAndNotify { [[SDWebImageManager sharedManager] loadImageWithURL:_photoURL options:SDWebImageRetryFailed progress:^(NSInteger receivedSize, NSInteger expectedSize, NSURL * _Nullable targetURL) { CGFloat progress = ((CGFloat)receivedSize)/((CGFloat)expectedSize); - - if (self.progressUpdateBlock) { - self.progressUpdateBlock(progress); - } + + if ([NSThread isMainThread]) { + if (self.progressUpdateBlock) { + self.progressUpdateBlock(progress); + } + } else { + __weak typeof(self) weakSelf = self; + dispatch_async(dispatch_get_main_queue(), ^{ + if (weakSelf.progressUpdateBlock) { + weakSelf.progressUpdateBlock(progress); + } + }); + } } completed:^(UIImage * _Nullable image, NSData * _Nullable data, NSError * _Nullable error, SDImageCacheType cacheType, BOOL finished, NSURL * _Nullable imageURL) { if (image) { self.underlyingImage = image;