Я пытаюсь создать веб-приложение, которое потребует извлечения и отображения изображений TIFF в браузере.Используя tiff.js (https://github.com/seikichi/tiff.js/tree/master) и пример проекта, найденный здесь (https://github.com/johnthad/tiff-demo),), я могу успешно получить и отобразить изображение с моего локального компьютера с помощью Chrome Web Server, но только с JavaScript, написанным нана стороне клиента. Я не могу заставить это работать с узла! Тот же код в узле возвращает NULL при установке атрибута изображения.
Вот код, написанный на стороне клиента (это работает):
<!doctype html>
<html>
<head>
<title>tiff.js demo</title>
</head>
<body>
<script src="tiff.min.js"></script>
<script type="text/javascript">
let loadImage = function (filename) {
let xhr = new XMLHttpRequest();
xhr.responseType = 'arraybuffer';
xhr.open('GET', filename);
xhr.send();
xhr.onload = function (e) {
let tiff = new Tiff({buffer: xhr.response});
let width = 6 * tiff.width();
let height = 6 * tiff.height();
let canvas = tiff.toCanvas();
if (canvas) {
canvas.setAttribute('style', 'width:' + (width*0.3) +
'px; height: ' + (height*0.3) + 'px');
let elem = document.createElement("div");
elem.innerHTML ='<div><a href="' + filename + '">' + filename +
' (width: ' + width + ', height:' + height + ')' +
'</a></div>';
document.body.append(elem);
document.body.append(canvas);
}
};
}
loadImage('http://127.0.0.1:8887/sample.tif');
</script>
</body>
</html>
Вот код, написанный для node.js (это не работает):
const express = require('express');
const hbs = require('express-handlebars');
const open = require('open')
const path = require('path');
const Tiff = require('tiff.js')
const XMLHttpRequest = require("xmlhttprequest").XMLHttpRequest;
app.use(express.static(path.join(__dirname, 'dist')));
app.use(express.static(path.join(__dirname, 'images')));
app.set('view engine', 'hbs');
app.engine('hbs', hbs({
extname: 'hbs',
defaultView: 'default',
layoutsDir: path.join(__dirname, 'views/pages/'),
partialsDir: path.join(__dirname, 'views/partials/')
}))
app.get('/', function(req, res) {
let canvas, elem;
let loadImage = function (filename) {
let xhr = new XMLHttpRequest();
xhr.responseType = 'arraybuffer';
xhr.open('GET', filename);
xhr.send();
xhr.onload = function (e) {
console.log("------HERE------");
let image = new Tiff({ buffer: xhr.response });
let width = 6 * image.width();
let height = 6 * image.height();
canvas = image.toCanvas();
if (canvas) {
canvas.setAttribute('style', 'width:' + (width*0.3) +
'px; height: ' + (height*0.3) + 'px');
elem = document.createElement("div");
elem.innerHTML = '<div><a href="' + filename + '">' + filename +
' (width: ' + width + ', height:' + height + ')' +
'</a></div>'
res.render('indexMain', { canvas, elem });
}
};
xhr.onerror = function (e) {
console.log("DIDN'T WORK!");
}
}
loadImage('http://127.0.0.1:8887/sample.tif');
})
app.listen(port, function(err) {
if (err) {
console.log(err);
} else {
open('http://localhost:' + port);
console.log("Server listening on " + port);
}
})
Вот вывод ошибки:
1.Tiff: Cannot read TIFF header.
/mnt/c/Development/qc_assist/wtv/node_modules/tiff.js/tiff.min.js:104
(module.exports=F);process.on("uncaughtException",function(r){if(!(r instanceof of))throw r;});F.inspect=function(){return"[Emscripten Module object]"}}else if(ah)F.print||(F.print=print),"undefined"!=typeof printErr&&(F.printErr=printErr),F.read="undefined"!=typeof read?read:function(){throw"no read() available (jsc?)";},F.readBinary=function(r){if("function"===typeof readbuffer)return new Uint8Array(readbuffer(r));r=read(r,"binary");fb("object"===typeof r);return r},"undefined"!=typeof scriptArgs?
^
Tiff.Exception: The function TIFFOpen returns NULL