WIP: planetary features pointer

This commit is contained in:
Thomas Boch
2023-03-22 16:49:02 +01:00
parent 2d87c818f3
commit adeab7a3f9

View File

@@ -22,11 +22,11 @@
/******************************************************************************
* Aladin Lite project
*
*
* File View.js
*
*
* Author: Thomas Boch[CDS]
*
*
*****************************************************************************/
import { Aladin } from "./Aladin.js";
@@ -36,6 +36,7 @@ import { ProjectionEnum } from "./ProjectionEnum.js";
import { AladinUtils } from "./AladinUtils.js";
import { Utils, dropHandler } from "./Utils.js";
import { SimbadPointer } from "./SimbadPointer.js";
import { PlanetaryFeaturesPointer } from "./PlanetaryFeaturesPointer.js";
import { Stats } from "./libs/Stats.js";
import { Footprint } from "./Footprint.js";
import { Circle } from "./Circle.js";
@@ -232,12 +233,12 @@ export let View = (function () {
init(this);
// listen to window resize and reshape canvases
this.resizeTimer = null;
let resizeObserver = new ResizeObserver(() => {
let resizeObserver = new ResizeObserver(() => {
self.fixLayoutDimensions();
self.requestRedraw();
});
resizeObserver.observe(this.aladinDiv);
resizeObserver.observe(this.aladinDiv);
//$(window).resize(() => {
self.fixLayoutDimensions();
//self.requestRedraw();
@@ -268,7 +269,7 @@ export let View = (function () {
View.TOOL_SIMBAD_POINTER = 2;
// TODO: should be put as an option at layer level
// TODO: should be put as an option at layer level
View.DRAW_SOURCES_WHILE_DRAGGING = true;
View.DRAW_MOCS_WHILE_DRAGGING = true;
@@ -391,7 +392,7 @@ export let View = (function () {
return loadImage("")
.then((img) => {
imgType = imgType || "image/png";
const canvas = this.wasm.canvas();
var c = document.createElement('canvas');
@@ -400,7 +401,7 @@ export let View = (function () {
c.height = height || (this.height * dpi);
var ctx = c.getContext('2d');
ctx.drawImage(canvas, 0, 0, c.width, c.height);
ctx.drawImage(this.catalogCanvas, 0, 0, c.width, c.height);
@@ -445,7 +446,7 @@ export let View = (function () {
}
$(view.catalogCanvas).bind("contextmenu", function (e) {
// do something here...
// do something here...
e.preventDefault();
}, false);
@@ -522,7 +523,7 @@ export let View = (function () {
}
});
$(view.catalogCanvas).bind("click mouseout touchend", function (e) { // reacting on 'click' rather on 'mouseup' is more reliable when panning the view
$(view.catalogCanvas).bind("click mouseout touchend", function (e) { // reacting on 'click' rather on 'mouseup' is more reliable when panning the view
if (e.type === 'touchend' && view.pinchZoomParameters.isPinching) {
view.pinchZoomParameters.isPinching = false;
view.pinchZoomParameters.initialFov = view.pinchZoomParameters.initialDistance = undefined;
@@ -594,7 +595,16 @@ export let View = (function () {
view.setMode(View.PAN);
view.setCursor('wait');
if (radec) {
SimbadPointer.query(radec[0], radec[1], Math.min(1, 15 * view.fov / view.largestDim), view.aladin);
// sky case
if (view.aladin.getBaseImageLayer().properties.hipsBody === false) {
SimbadPointer.query(radec[0], radec[1], Math.min(1, 15 * view.fov / view.largestDim), view.aladin);
}
// planetary body case
else {
// TODO: replace with actual value
const body = 'mars';
PlanetaryFeaturesPointer.query(radec[0], radec[1], Math.min(80, view.fov / 10.0), body, view.aladin);
}
} else {
console.log("Cannot unproject at the location you clicked on")
}
@@ -852,7 +862,7 @@ export let View = (function () {
view.decreaseZoom(amount);
}
};
if (isTouchPadDefined) {
if (isTouchPad) {
// touchpad
@@ -863,7 +873,7 @@ export let View = (function () {
oldTime = new Date().getTime();
}
} else {
// mouse
// mouse
triggerZoom(0.007);
}
}
@@ -1191,7 +1201,7 @@ export let View = (function () {
var nside = Math.pow(2, norder); // TODO : to be modified
var npix = 12 * nside * nside;
var ipixCenter = null;
// build list of pixels
var pixList = this.getVisiblePixList(norder)
var ipix;
@@ -1199,7 +1209,7 @@ export let View = (function () {
var corners;
for (var ipixIdx=0, len=pixList.length; ipixIdx<len; ipixIdx++) {
ipix = pixList[ipixIdx];
if (ipix==ipixCenter && ipixIdx>0) {
if (ipix==ipixCenter && ipixIdx>0) {
continue;
}
var cornersXYView = [];
@@ -1247,7 +1257,7 @@ export let View = (function () {
!AladinUtils.counterClockwiseTriangle(cornersXYView[0].vx, cornersXYView[0].vy, cornersXYView[2].vx, cornersXYView[2].vy, cornersXYView[3].vx, cornersXYView[3].vy)) {
continue;
}
if (this.projection == ProjectionEnum.HPX) {
const triIdxInCollignonZone = ((p) => {
const x = ((p.vx / this.catalogCanvas.clientWidth) - 0.5) * this.zoomFactor;
@@ -1270,11 +1280,11 @@ export let View = (function () {
}
}
}
cornersXYView.ipix = ipix;
cells.push(cornersXYView);
}
return cells;*/
return this.wasm.getVisibleCells(norder);
};
@@ -1496,7 +1506,7 @@ export let View = (function () {
// no promises to launch!
const idxServiceUrl = Math.round(Math.random());
const dssUrl = Aladin.DEFAULT_OPTIONS.surveyUrl[idxServiceUrl]
self.aladin.setBaseImageLayer(dssUrl);
} else {
// there is surveys that have been queried
@@ -1538,7 +1548,7 @@ export let View = (function () {
View.prototype.swapLayers = function(firstLayer, secondLayer) {
// Throw an exception if either the first or the second layers are not in the stack
this.wasm.swapLayers(firstLayer, secondLayer);
// Swap in overlaylayers
const idxFirstLayer = this.overlayLayers.findIndex(overlayLayer => overlayLayer == firstLayer);
const idxSecondLayer = this.overlayLayers.findIndex(overlayLayer => overlayLayer == secondLayer);
@@ -1566,7 +1576,7 @@ export let View = (function () {
if (idxOverlaidLayer == -1) {
// layer not found
return;
}
}
// Delete it
this.imageLayers.delete(layer);
@@ -1593,7 +1603,7 @@ export let View = (function () {
// no promises to launch!
const idxServiceUrl = Math.round(Math.random());
const dssUrl = Aladin.DEFAULT_OPTIONS.surveyUrl[idxServiceUrl]
this.aladin.setBaseImageLayer(dssUrl);
}
};
@@ -1620,10 +1630,10 @@ export let View = (function () {
View.prototype.setProjection = function (projectionName) {
this.fovLimit = 1000.0;
/*
TAN: {id: 1, fov: 180},
STG: {id: 2, fov: 360},
SIN: {id: 3, fov: 180},
ZEA: {id: 4, fov: 360},
TAN: {id: 1, fov: 180},
STG: {id: 2, fov: 360},
SIN: {id: 3, fov: 180},
ZEA: {id: 4, fov: 360},
FEYE: {id: 5, fov: 190},
AIR: {id: 6, fov: 360},
//AZP: {fov: 180},
@@ -1711,7 +1721,7 @@ export let View = (function () {
this.fovLimit = 360.0;
break;
default:
break;
break;
}
// Change the projection here
this.wasm.setProjection(projectionName);
@@ -1779,13 +1789,13 @@ export let View = (function () {
};
/**
*
*
* @API Point to a specific location in ICRSJ2000
*
*
* @param ra ra expressed in ICRS J2000 frame
* @param dec dec expressed in ICRS J2000 frame
* @param options
*
*
*/
View.prototype.pointTo = function (ra, dec, options) {
options = options || {};
@@ -1920,7 +1930,7 @@ export let View = (function () {
};
// update objLookup, lookup table
// update objLookup, lookup table
View.prototype.updateObjectsLookup = function () {
this.objLookup = [];