Skip to content

tiff.js is a port of LibTIFF by compiling the LibTIFF C code with Emscripten.

License

Notifications You must be signed in to change notification settings

kozenumezawa/tiff.js

Repository files navigation

tiff.js

tiff.js is a port of LibTIFF by compiling the LibTIFF C code with Emscripten.

Demo

  • views small TIFF files
  • views a large TIFF file using a web worker
  • views a multipage TIFF file

Usage

Use tiff.min.js:

var xhr = new XMLHttpRequest();
xhr.responseType = 'arraybuffer';
xhr.open('GET', "tiff-image-url");
xhr.onload = function (e) {
    var tiff = new Tiff({buffer: xhr.response});
    var width = tiff.width();
    var height = tiff.height();
    console.log('width:', width);
    console.log('height:', height);
    var arrayBuffer = tiff.readRGBAImage();

    var canvas = createCanvasFromArrayBuffer(arrayBuffer, width, height);
    document.body.append(canvas);
};
xhr.send();

function createCanvasFromArrayBuffer(buffer, width, height) {
    var canvas = document.createElement('canvas');
    var context = canvas.getContext('2d');
    canvas.width = width;
    canvas.height = height;
    var imageData = context.createImageData(width, height);
    imageData.data.set(new Uint8Array(buffer));
    context.putImageData(imageData, 0, 0);
    return canvas;
}

API

see tiff.d.ts

Note

  • This library does not support JPEG-based compressed TIFF files -- I failed to link a JPEG library ...
  • When you load large tiff file, you will see the error message "Cannot enlarge memory arrays in asm.js"

-- TIFFOpen, TIFFClose, TIFFGetField, TIFFReadRGBAImage, TIFFSetDirectory, TIFFCurrentDirectory, TIFFLastDirectory

License

LibTIFF is LibTIFF Software License, zlib and additional code are zlib License.

About

tiff.js is a port of LibTIFF by compiling the LibTIFF C code with Emscripten.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 99.4%
  • Other 0.6%