Loading images for animation in UIImageView – iOS

I have around 300 images to be loaded for animation the images are named loading001.png, loading002.png, loading003.png, loading004.png………loading300.png

I am doing it in the following way.

  • Xcode Imageview Aspect Fit Remove Extra Space
  • Merge two imageViews into one and save iOS swift
  • iPhone/Xcode: UIImage and UIImageView won't get with the program
  • Load images from NSURL async with RestKit
  • clipsToBounds causes UIImage to not display in iOS10 & XCode 8
  • App running slowly because of UIImageViews
  • .h file

        #import <UIKit/UIKit.h>
        @interface CenterViewController : UIViewController  {
            UIImageView *imgView;

    .m file

    @implementation CenterViewController
    - (void)viewDidLoad {
        [super viewDidLoad];
        imgView = [[UIImageView alloc] init];
        imgView.animationImages = [[NSArray alloc] initWithObjects:
                                   [UIImage imageNamed:@"loading001.png"],
                                   [UIImage imageNamed:@"loading002.png"],
                                   [UIImage imageNamed:@"loading003.png"],
                                   [UIImage imageNamed:@"loading004.png"],
    - (IBAction)startAnimation:(id)sender{
        [imgView startAnimating];

    Is there a efficient way to load the images into a array.
    I had tried it with for loop but was not able to figure it out.

    4 Solutions Collect From Internet About “Loading images for animation in UIImageView – iOS”

    You may try out the following code to load images into an array in a better way

    - (void)viewDidLoad {
        [super viewDidLoad];
        NSMutableArray *imgListArray = [NSMutableArray array];
        for (int i=1; i <= 300; i++) {
            NSString *strImgeName = [NSString stringWithFormat:@"loading%03d.png", i];
            UIImage *image = [UIImage imageNamed:strImgeName];
                if (!image) {
                    NSLog(@"Could not load image named: %@", strImgeName);
                else {
                    [imgListArray addObject:image];
        imgView = [[UIImageView alloc] init];
        [imgView setAnimationImages:imgListArray];

    There is an easier way to do this. You can simply use:

    [UIImage animatedImageNamed:@"loading" duration:1.0f]

    Where 1.0f is the duration to animate all the images. For this to work though, your images must be named like this:


    That is, without padding with 0.

    The function animatedImageNamed is available from iOS 5.0 onwards.

    Depending on the size of your images, a 300 image animation sequence may be quite the memory hog. Using a a movie might be a better solution.

    Your code will crash when run on the device, it is just not possible to decompress that many images into memory on iOS. You will get memory warnings and then your app will be killed by the OS. See my answer to how-to-do-animations-using-images-efficiently-in-ios for a solution that will not crash on the device.