How to show an activity indicator in SDWebImage

后端 未结 6 932
一向
一向 2020-12-25 12:50

Currently i am integrating SDWebImage in my project by following below things

1)#import \"UIButton+WebCache.h\"

2)[button setImageWithURL:url placeholderImag

相关标签:
6条回答
  • 2020-12-25 13:33

    Works like a charm for me :

    Swift 3:

    imgView.setShowActivityIndicator(true)
    imgView.setIndicatorStyle(.gray)
    imgView.sd_setImage(with: URL(string: urlString), placeholderImage: UIImage(named: "placeholder"))
    

    Swift 4: (Edit : Updates)

    imgView.sd_setShowActivityIndicatorView(true)
    imgView.sd_setIndicatorStyle(.gray)
    imgView.sd_setImage(with: URL(string: urlString), placeholderImage: UIImage(named: "placeholder"))
    

    Swift 5: SDWebImage (5.x.x)

    imgView.sd_imageIndicator = SDWebImageActivityIndicator.gray
    imgView.sd_setImage(with: URL(string: urlString), placeholderImage: UIImage(named: "placeholder"))
    

    Updates: For UIButton use this

    yourButton.sd_setImage(with: URL(string: urlString), for: .normal)
    
    0 讨论(0)
  • 2020-12-25 13:40

    For swift 5

    //pass true for showing indicator View
    self.imageView.sd_setShowActivityIndicatorView(true)
    
    //give style value
    self.imageView.sd_setIndicatorStyle(UIActivityIndicatorView.Style.gray)
    
    //Set your image as you are want to do
    self.imageView.sd_setImage(with: URL(string: self.imageUrl), placeholderImage: UIImage())
    
    0 讨论(0)
  • Objective-C: SDWebImage (5.x.x)

    [imgView setSd_imageIndicator:SDWebImageActivityIndicator.grayIndicator];
    [imgView sd_setImageWithURL:[NSURL URLWithString: urlString] placeholderImage:nil];
    
    0 讨论(0)
  • 2020-12-25 13:48

    The best way I have found to do this is to use the SDWebImageManager class. Your view controller or some other class will then need to conform to the SDWebImageManagerDelegate protocol.

    SDWebImageManager *manager = [SDWebImageManager sharedManager];
    UIImage *cachedImage = [manager imageWithURL:url];
    
    if (cachedImage) {
        [button setImage:cachedImage];
        // stop or remove your UIActivityIndicatorView here
    }
    else {
        [manager downloadWithURL:url delegate:self];
    }
    

    Once the image has been downloaded the delegate method will be called:

    - (void)webImageManager:(SDWebImageManager *)imageManager didFinishWithImage:(UIImage *)image {
        [button setImage:image];
        // stop or remove your UIActivityIndicatorView here
    }
    

    There is also a delegate method for when an error occurs downloading an image

    - (void)webImageManager:(SDWebImageManager *)imageManager didFailWithError:(NSError *)error {
        // Handle error here
    }
    

    If you have more than one button you may have problems determining which image belongs to which button after the image has downloaded. In this case you may need to have a button subclass which handles the download as above and then updates its own image.

    Hope that helps.

    0 讨论(0)
  • 2020-12-25 13:48

    the best way is to add the activityIndicator in all "setImage" functions in UIImageView+WebCache.m, after that you remove it in "webImageManager:r didFinishWithImage:" , i test it in device and it work smoothly, her's an example :

      - (void)setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder
     {
    
    
    UIActivityIndicatorView *activity = [[UIActivityIndicatorView alloc]initWithActivityIndicatorStyle:(UIActivityIndicatorViewStyleWhiteLarge)];
    [activity startAnimating];
    [activity setCenter:self.center];
    [self addSubview:activity];
    [activity release];
    
    
    
    SDWebImageManager *manager = [SDWebImageManager sharedManager];
    
    UIImage *cachedImage = [manager imageWithURL:url];
    
    if (cachedImage)
    {
        // the image is cached -> remove activityIndicator from view
        for (UIView *v in [self subviews])
        {
            if ([v isKindOfClass:[UIActivityIndicatorView class]])
            {
                [activity removeFromSuperview];
            }
        }
    }
    
    [self setImageWithURL:url placeholderImage:placeholder options:0];
    }
    

    and you remove it with a fade animation ;) :

     - (void)webImageManager:(SDWebImageManager *)imageManager didFinishWithImage:(UIImage *)image
    { 
    
    for (UIView *v in [self subviews])
    {
        if ([v isKindOfClass:[UIActivityIndicatorView class]])
        {
           // NSLog(@"-didFinishWithImage-");
            [((UIActivityIndicatorView*)v) stopAnimating];
            [v removeFromSuperview];
        }
    }
    
    
    [UIView beginAnimations:@"fadeAnimation" context:NULL]; 
    [UIView setAnimationDuration:0.9];
    self.alpha = 0;
    self.image = image;
    self.alpha=1;
    //[UIView setAnimationTransition:UIViewAnimationTransitionFlipFromLeft forView:self cache:YES]; 
    [UIView commitAnimations];
    
     }
    
    0 讨论(0)
  • 2020-12-25 13:56

    Last solution

    You can download UIActivityIndicator-for-SDWebImage, which is easiest way to add a UIActivityView to your SDWebImage view. Using CocoaPods, just add this line to your podfile:

    pod 'UIActivityIndicator-for-SDWebImage'
    

    You can use one of these lines depending on your preferences:

    - (void)setImageWithURL:(NSURL *)url usingActivityIndicatorStyle:(UIActivityIndicatorViewStyle)activityStyle;
    - (void)setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder usingActivityIndicatorStyle:(UIActivityIndicatorViewStyle)activityStyle;
    - (void)setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options usingActivityIndicatorStyle:(UIActivityIndicatorViewStyle)activityStyle;
    - (void)setImageWithURL:(NSURL *)url completed:(SDWebImageCompletionBlock)completedBlock usingActivityIndicatorStyle:(UIActivityIndicatorViewStyle)activityStyle;
    - (void)setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder completed:(SDWebImageCompletionBlock)completedBlock usingActivityIndicatorStyle:(UIActivityIndicatorViewStyle)activityStyle;
    - (void)setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options completed:(SDWebImageCompletionBlock)completedBlock usingActivityIndicatorStyle:(UIActivityIndicatorViewStyle)activityStyle;
    - (void)setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options progress:(SDWebImageDownloaderProgressBlock)progressBlock completed:(SDWebImageCompletionBlock)completedBlock usingActivityIndicatorStyle:(UIActivityIndicatorViewStyle)activityStyle;
    

    Example of Use

    Just import

    #import <UIActivityIndicator-for-SDWebImage/UIImageView+UIActivityIndicatorForSDWebImage.h>
    

    and use this code

    [imageView setImageWithURL:[NSURL URLWithString:@"https://media.licdn.com/mpr/mpr/wc_200_200/p/1/005/07f/0a3/30cb8dd.jpg"] placeholderImage:[UIImage imageNamed:@"myImage.jpg"] usingActivityIndicatorStyle:UIActivityIndicatorViewStyleGray];
    
    0 讨论(0)
提交回复
热议问题