question-mark
Stuck on an issue?

Lightrun Answers was designed to reduce the constant googling that comes with debugging 3rd party libraries. It collects links to all the places you might be looking at while hunting down a tough bug.

And, if you’re still stuck at the end, we’re happy to hop on a call to see how we can help out.

Gif does not appear when inserted into document

See original GitHub issue

Bug Report

Description of the problem

I have a GIF image which I wish to embed in a pdf document(I cannot compromise, it must be a GIF, and cannot be converted to png or jpeg). For some reason, I cannot insert this GIF image into a document without an error stating “Error: Unknown image format.” I do not know why this is happening, but it seems like PDFKit cannot support images in the GIF format, this error exists both on the live editor, my ubuntu desktop and ubuntu server. I’ll attach some code below which you can try in the PDFKit live demo, and see for yourself what’s wrong. Try starting with only the png image, then uncomment the GIF image and see what happens. http://pdfkit.org/demo/browser.html

Code sample

var doc = new PDFDocument();
var stream = doc.pipe(blobStream());

doc.image("",0,0)
// .image("",100,100)
;

doc.end();
stream.on('finish', function() {
  iframe.src = stream.toBlobURL('application/pdf');
});

Your environment

  • Node version: v10.15.2
  • Browser version (if applicable): Version 80.0.3987.100
  • Operating System: Ubuntu server edition

Issue Analytics

  • State:open
  • Created 4 years ago
  • Comments:8 (3 by maintainers)

github_iconTop GitHub Comments

1reaction
Whobeucommented, Sep 10, 2021

I see the last comment is over 1 1/2 years old but this might still be relevant. I ran into this problem trying to embed some GIF’s from the National Weather Service in a document (rather annoying as most of the images I want are PNG but a few are still GIF). Of course, before I actually re-read the documentation and saw that GIF’s were not supported, I got an error from PDFKit about the unsupported format. I spent time looking around trying to find a solution and eventually wound up rolling my own based on a GIF conversion module I found on npm that works entirely with JavaScript.

The following code takes a URL, retrieves the GIF, converts the first frame to PNG format (other formats are supported like JPG but I wanted PNG) and returns a Buffer containing the PNG. That Buffer can then be inserted into the PDF with the PDFKit .image() method. It has been working fine in my Windows and Linux environments without any native code dependencies.

"use strict";

const gifFrames = require("gif-frames");
const { WritableStreamBuffer } = require("stream-buffers");

const InitialBufferSize = 800;
const OneK = 1024;

/**
 * @param {string} url URL to retrieve GIF from
 * @returns {Promise<Buffer>} a Promise with a Buffer
 */
exports.convertGifToPng = (url) => {
  return new Promise((resolve) => {
    const writer = new WritableStreamBuffer({ initialSize: InitialBufferSize * OneK });

    gifFrames({
      url,
      frames: 0,
      outputType: "PNG"
    }).then((frameData) => {
      frameData.shift().getImage().pipe(writer);
    });

    writer.on("finish", () => {
      resolve(writer.getContents());
    });
  });
};

0reactions
Whobeucommented, Sep 10, 2021

I also wanted to write the above code in Typescript but there were no type definitions so I wound up rolling my own. Due to my use of the newer “intrinsic” available in Typescript 4.1+, I did not bother submitting to DefinitelyTyped as they current have a minimum support of Typescript 3.7 (plus I only got about 1/3 of the way through their submission requirements and went into TL;DR mode):

/**
 * Typescript definitions for gif-frames (gif-frames.d.ts)
 *
 * @see https://www.npmjs.com/package/gif-frames
 */

declare module "gif-frames" {
  import { WriteStream } from "fs";

  interface FrameInfo {
    /** Image Left position */
    x: number,
    /** Image Top position */
    y: number,
    /** Image Width */
    width: number,
    /** Image Height */
    height: number,
    /** Image local palette presentation flag */
    has_local_palette: boolean,
    /** Image palette offset */
    palette_offset: number,
    /** Image palette size */
    palette_size: number,
    /** Image data offset */
    data_offset: number,
    /** Image data length */
    data_length: number,
    /** Transparent Color Index */
    transparent_index: number,
    /** Interlace Flag */
    interlaced: boolean,
    /** Delay Time (1/100ths of a second) */
    delay: number,
    /** Disposal method */
    disposal: number
  }

  type FrameData = Array<{ getImage(): WriteStream | HTMLCanvasElement, frameIndex: number, frameInfo: FrameInfo }>;

  /**
   * @description supported output types by module save-pixels-jpeg-js-upgrade.
   */

  type OutputTypes = "JPG" | ".JPG" | "JPEG" | ".JPEG" | "JPE" | ".JPE" | "GIF" | ".GIF" | "PNG" | ".PNG" | "CANVAS";

  // See https://newbedev.com/typescript-type-ignore-case for information on
  // case insensitivity support using Uppercase<>. Requires Typescript 4.1+ for
  // intrinsic support.

  export function gifFrames<T extends string>({ url, frames, outputType, quality, cumulative }: { url: string, frames: number | string, outputType?: Uppercase<T> extends OutputTypes ? T : OutputTypes, quality?: number, cumulative?: boolean }, callback?: (error: Error, frameData: FrameData) => void): Promise<FrameData>;
}
Read more comments on GitHub >

github_iconTop Results From Across the Web

Insert a Gif into a word doc - Microsoft Community
-In word, select the location to embed the gif file. When you double click the gif's icon and open it, your browser will...
Read more >
How to insert animated GIF in Word document
Launch Microsoft Word. · Click the Insert tab, click Picture, and choose This Device. · Select the GIF you have downloaded and click...
Read more >
How to Insert an Animated GIF Into a Word ... - groovyPost
Click on the GIF you wish to insert. Select Insert to add the GIF to your document.
Read more >
2 Methods to Insert an Animated GIF Image into Your Word ...
Given to the fact that they are more vivid than usual images, how about insert gif images into our Word documents? What a...
Read more >
After inserting a gif into Word, it doesn't work (it doesn't move ...
Word is intended to create documents for printing, you can't print something animated so it makes no sense for word to support animated...
Read more >

github_iconTop Related Medium Post

No results found

github_iconTop Related StackOverflow Question

No results found

github_iconTroubleshoot Live Code

Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free

github_iconTop Related Reddit Thread

No results found

github_iconTop Related Hackernoon Post

No results found

github_iconTop Related Tweet

No results found

github_iconTop Related Dev.to Post

No results found

github_iconTop Related Hashnode Post

No results found