From adeab7a3f926e1f7b8a3fa15b221d466f531a8d8 Mon Sep 17 00:00:00 2001 From: Thomas Boch Date: Wed, 22 Mar 2023 16:49:02 +0100 Subject: [PATCH] WIP: planetary features pointer --- src/js/View.js | 72 ++++++++++++++++++++++++++++---------------------- 1 file changed, 41 insertions(+), 31 deletions(-) diff --git a/src/js/View.js b/src/js/View.js index cb05a5c0..91551fbf 100644 --- a/src/js/View.js +++ b/src/js/View.js @@ -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; ipixIdx0) { + 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 = [];