Mercurial > hg > orthanc-wsi
view ViewerPlugin/viewer.js @ 341:f14e81852a6c
first successful on-the-fly rendering
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Sat, 07 Dec 2024 15:05:17 +0100 |
parents | c42083d50ddf |
children |
line wrap: on
line source
/** * Orthanc - A Lightweight, RESTful DICOM Store * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics * Department, University Hospital of Liege, Belgium * Copyright (C) 2017-2023 Osimis S.A., Belgium * Copyright (C) 2024-2024 Orthanc Team SRL, Belgium * Copyright (C) 2021-2024 Sebastien Jodogne, ICTEAM UCLouvain, Belgium * * This program is free software: you can redistribute it and/or * modify it under the terms of the GNU Affero General Public License * as published by the Free Software Foundation, either version 3 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. **/ // For IE compatibility if (!window.console) window.console = {}; if (!window.console.log) window.console.log = function () { }; // http://stackoverflow.com/a/21903119/881731 function GetUrlParameter(sParam) { var sPageURL = decodeURIComponent(window.location.search.substring(1)); var sURLVariables = sPageURL.split('&'); var sParameterName; var i; for (i = 0; i < sURLVariables.length; i++) { sParameterName = sURLVariables[i].split('='); if (sParameterName[0] === sParam) { return sParameterName[1] === undefined ? '' : sParameterName[1]; } } return ''; }; function InitializePyramid(pyramid, tilesBaseUrl) { $('#map').css('background', pyramid['BackgroundColor']); // New in WSI 2.1 var width = pyramid['TotalWidth']; var height = pyramid['TotalHeight']; var countLevels = pyramid['Resolutions'].length; // Maps always need a projection, but Zoomify layers are not geo-referenced, and // are only measured in pixels. So, we create a fake projection that the map // can use to properly display the layer. var proj = new ol.proj.Projection({ code: 'pixel', units: 'pixels', extent: [0, 0, width, height] }); var extent = [0, -height, width, 0]; // Disable the rotation of the map, and inertia while panning // http://stackoverflow.com/a/25682186 var interactions = ol.interaction.defaults({ altShiftDragRotate : false, pinchRotate : false, dragPan: false }).extend([ new ol.interaction.DragPan({kinetic: false}) ]); var layer = new ol.layer.Tile({ extent: extent, source: new ol.source.TileImage({ projection: proj, tileUrlFunction: function(tileCoord, pixelRatio, projection) { return (tilesBaseUrl + (countLevels - 1 - tileCoord[0]) + '/' + tileCoord[1] + '/' + (-tileCoord[2] - 1)); }, tileGrid: new ol.tilegrid.TileGrid({ extent: extent, resolutions: pyramid['Resolutions'].reverse(), tileSizes: pyramid['TilesSizes'].reverse() }) }), wrapX: false, projection: proj }); var map = new ol.Map({ target: 'map', layers: [ layer ], view: new ol.View({ projection: proj, center: [width / 2, -height / 2], zoom: 0, minResolution: 1 // Do not interpelate over pixels }), interactions: interactions }); map.getView().fit(extent, map.getSize()); } $(document).ready(function() { var seriesId = GetUrlParameter('series'); var instanceId = GetUrlParameter('instance'); if (seriesId.length != 0) { $.ajax({ url : '../pyramids/' + seriesId, error: function() { alert('Error - Cannot get the pyramid structure of series: ' + seriesId); }, success : function(pyramid) { InitializePyramid(pyramid, '../tiles/' + seriesId + '/'); } }); } else if (instanceId.length != 0) { var frameNumber = GetUrlParameter('frame'); if (frameNumber.length == 0) { frameNumber = 0; } $.ajax({ url : '../frames-pyramids/' + instanceId + '/' + frameNumber, error: function() { alert('Error - Cannot get the pyramid structure of frame ' + frameNumber + ' of instance: ' + instanceId); }, success : function(pyramid) { InitializePyramid(pyramid, '../frames-tiles/' + instanceId + '/' + frameNumber + '/'); } }); } else { alert('Error - No series ID and no instance ID specified!'); } });