|
|
|
|
@@ -446,42 +446,65 @@ export let View = (function () {
|
|
|
|
|
this.catalogCanvas.style.cursor = cursor;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* return dataURL string corresponding to the current view
|
|
|
|
|
*/
|
|
|
|
|
View.prototype.getCanvasDataURL = async function (imgType, width, height) {
|
|
|
|
|
View.prototype.getCanvasContext = async function (imgType, width, height, withLogo=true) {
|
|
|
|
|
const loadImage = function (url) {
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
|
var image = new Image()
|
|
|
|
|
const image = new Image()
|
|
|
|
|
image.src = url
|
|
|
|
|
image.onload = () => resolve(image)
|
|
|
|
|
image.onerror = () => reject(new Error('could not load image'))
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return loadImage("")
|
|
|
|
|
.then((img) => {
|
|
|
|
|
imgType = imgType || "image/png";
|
|
|
|
|
imgType = imgType || "image/png";
|
|
|
|
|
|
|
|
|
|
const canvas = this.wasm.canvas();
|
|
|
|
|
const canvas = this.wasm.canvas();
|
|
|
|
|
|
|
|
|
|
var c = document.createElement('canvas');
|
|
|
|
|
c.width = width || (this.width * window.devicePixelRatio);
|
|
|
|
|
c.height = height || (this.height * window.devicePixelRatio);
|
|
|
|
|
const c = document.createElement('canvas');
|
|
|
|
|
c.width = width || (this.width * window.devicePixelRatio);
|
|
|
|
|
c.height = height || (this.height * window.devicePixelRatio);
|
|
|
|
|
|
|
|
|
|
var ctx = c.getContext('2d');
|
|
|
|
|
const ctx = c.getContext('2d');
|
|
|
|
|
|
|
|
|
|
ctx.drawImage(canvas, 0, 0, c.width, c.height);
|
|
|
|
|
ctx.drawImage(this.catalogCanvas, 0, 0, c.width, c.height);
|
|
|
|
|
ctx.drawImage(canvas, 0, 0, c.width, c.height);
|
|
|
|
|
ctx.drawImage(this.catalogCanvas, 0, 0, c.width, c.height);
|
|
|
|
|
|
|
|
|
|
const offX = c.width - img.width;
|
|
|
|
|
const offY = c.height - img.height;
|
|
|
|
|
ctx.drawImage(img, offX, offY);
|
|
|
|
|
if(withLogo) {
|
|
|
|
|
const logo = await loadImage("");
|
|
|
|
|
const offX = c.width - logo.width;
|
|
|
|
|
const offY = c.height - logo.height;
|
|
|
|
|
ctx.drawImage(logo, offX, offY);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return c.toDataURL(imgType);
|
|
|
|
|
});
|
|
|
|
|
return c;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* return dataURL string corresponding to the current view
|
|
|
|
|
*/
|
|
|
|
|
View.prototype.getCanvasDataURL = async function (imgType, width, height, withLogo=true) {
|
|
|
|
|
const c = await this.getCanvasContext(imgType, width, height, withLogo);
|
|
|
|
|
return c.toDataURL(imgType);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* return ArrayBuffer corresponding to the current view
|
|
|
|
|
*/
|
|
|
|
|
View.prototype.getCanvasBuffer = async function (imgType, width, height, withLogo=true) {
|
|
|
|
|
const c = await this.getCanvasContext(imgType, width, height, withLogo);
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
|
c.toBlob(blob => {
|
|
|
|
|
if (blob) {
|
|
|
|
|
const reader = new FileReader();
|
|
|
|
|
reader.onloadend = () => resolve(reader.result);
|
|
|
|
|
reader.onerror = () => reject(new Error('Error reading blob as ArrayBuffer'));
|
|
|
|
|
reader.readAsArrayBuffer(blob);
|
|
|
|
|
} else {
|
|
|
|
|
reject(new Error('Canvas toBlob failed'));
|
|
|
|
|
}
|
|
|
|
|
}, imgType);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
View.prototype.selectLayer = function (layer) {
|
|
|
|
|
if (!this.imageLayers.has(layer)) {
|
|
|
|
|
|