Display all frames of a GIF as a single image

1.6k Views Asked by At

I'm using gif-frames (https://www.npmjs.com/package/gif-frames) to extract frames from animated GIFS. I'd like to save all the frames as a single image.

I know I can use something like https://www.npmjs.com/package/merge-img but I don't know how to use frameData output of gif-frames and use it as input for mergeImg. Can you please help?

1

There are 1 best solutions below

0
On

The easiest way I found to do that is the following, but I'm sure there are better ways.

gifFrames(

  { url: 'img.gif', frames: '0-2', outputType: 'jpg', cumulative: true },
  function (err, frameData) {
    if (err) {
      throw err;
    }

    frameData.forEach(function (frame) {
      frame.getImage().pipe(fs.createWriteStream(
        'image-' + frame.frameIndex + '.png'
      ));
      all_imgs.push('image-' + frame.frameIndex + '.png');
    });
    mergeImg(all_imgs).then((img) => {
      // Save image as file
      img.write('out.png', () => console.log('done'));
    });
  }
);