Compare commits

...

4 Commits

Author SHA1 Message Date
Xen0Xys
3571741f01 🐛 Fix image ArrayBuffer recovery 2024-05-31 11:27:40 +02:00
Xen0Xys
ce7d115d71 📝 Update changelog 2024-05-31 09:21:01 +02:00
Xen0Xys
9d978c780c 🎨 Change implementation from Buffer to ArrayBuffer 2024-05-30 15:34:01 +02:00
Xen0Xys
27bc342d27 Implement Aladin#getViewImageBuffer to get the view image as a nodejs Buffer 2024-05-30 14:45:06 +02:00
3 changed files with 56 additions and 22 deletions

View File

@@ -1,5 +1,9 @@
# Changelogs
## Unreleased
* [feat] Add new method `Aladin#getViewImageBuffer` to get the current view as a PNG buffer
## 3.3.3
* [feat] UI: add HiPS basic filter that filters the `hipsList` given
@@ -353,4 +357,4 @@ New in the API:
### Fin 2013
* ajout catalogue progressif
* ajout on select, objectClicked, objectHovered
* ajout on select, objectClicked, objectHovered

View File

@@ -26,6 +26,7 @@
* Author: Thomas Boch[CDS], Matthieu Baumann[CDS]
*
*****************************************************************************/
import { version } from "./../../package.json";
import { View } from "./View.js";
import { Utils } from "./Utils";
@@ -2159,6 +2160,7 @@ aladin.on("positionChanged", ({ra, dec}) => {
* * format (optional): 'image/png' or 'image/jpeg'
* * width: width in pixels of the image to output
* * height: height in pixels of the image to output
* * logo (optional): boolean to display the Aladin Lite logo
*
* @API
*/
@@ -2172,11 +2174,16 @@ aladin.on("positionChanged", ({ra, dec}) => {
const canvasDataURL = await this.view.getCanvasDataURL(
options.format,
options.width,
options.height
options.height,
options.logo
);
return canvasDataURL;
};
Aladin.prototype.getViewImageBuffer = async function (withLogo) {
return await this.view.getCanvasBuffer("image/png", null, null, withLogo);
}
/**
* Return the current view WCS as a key-value dictionary
* Can be useful in coordination with getViewDataURL

View File

@@ -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)) {